@uiw/react-native
Version:
UIW for React Native
191 lines (162 loc) • 15.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _reactNative = require("react-native");
var _Icon = _interopRequireDefault(require("../Icon"));
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; }
class ToastContainer extends _react.Component {
constructor(props) {
super(props);
this.anim = void 0;
this.renderIcon = () => {
const {
type
} = this.props;
let icon = this.props.icon;
let color = '';
if (!icon) {
switch (type) {
case 'success':
icon = 'circle-check';
color = '#28a745';
break;
case 'warning':
icon = 'warning';
color = '#ffc107';
break;
case 'info':
icon = 'information';
color = '#008ef0';
break;
case 'error':
icon = 'circle-close';
color = '#dc3545';
break;
default:
break;
}
}
return {
icon,
color
};
};
this.state = {
fadeAnim: new _reactNative.Animated.Value(1)
};
}
componentDidMount() {
const {
onClose,
onAnimationEnd
} = this.props;
const duration = this.props.duration;
const timing = _reactNative.Animated.timing;
if (this.anim) {
this.anim = null;
}
const animArr = [timing(this.state.fadeAnim, {
toValue: 1,
duration: 200,
useNativeDriver: true
}), _reactNative.Animated.delay(duration * 1000)];
if (duration > 0) {
animArr.push(timing(this.state.fadeAnim, {
toValue: 0,
duration: 200,
useNativeDriver: true
}));
}
this.anim = _reactNative.Animated.sequence(animArr);
this.anim.start(() => {
if (duration > 0) {
this.anim = null;
if (onClose) {
onClose();
}
if (onAnimationEnd) {
onAnimationEnd();
}
}
});
}
componentWillUnmount() {
if (this.anim) {
this.anim.stop();
this.anim = null;
}
}
render() {
const {
content,
type,
style
} = this.props;
return <_reactNative.View style={[styles.container, style]}>
<_reactNative.View style={[styles.innerContainer]}>
<_reactNative.Animated.View style={{
opacity: this.state.fadeAnim
}}>
<_reactNative.View style={[styles.content, styles[type]]}>
<_Icon.default name={this.renderIcon().icon} size={16} style={[styles.icon]} color={this.renderIcon().color} />
<_reactNative.Text>{content}</_reactNative.Text>
</_reactNative.View>
</_reactNative.Animated.View>
</_reactNative.View>
</_reactNative.View>;
}
}
exports.default = ToastContainer;
ToastContainer.defaultProps = {
duration: 3,
type: 'info'
};
const styles = _reactNative.StyleSheet.create({
container: {
flex: 1,
position: 'absolute',
left: 0,
top: 100,
right: 0
},
innerContainer: {
display: 'flex',
flex: 1,
justifyContent: 'center',
alignContent: 'center',
flexDirection: 'row'
},
icon: {
marginRight: 5
},
content: {
paddingLeft: 10,
paddingBottom: 5,
paddingRight: 10,
paddingTop: 5,
display: 'flex',
flexDirection: 'row',
alignContent: 'center'
},
info: {
backgroundColor: '#bde4ff',
color: '#008ef0'
},
success: {
backgroundColor: '#afecbd',
color: '#28a745'
},
error: {
backgroundColor: '#fae3e5'
},
warning: {
backgroundColor: '#fff4d3'
}
});
module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Toast/ToastContainer.tsx"],"names":["ToastContainer","Component","constructor","props","anim","renderIcon","type","icon","color","state","fadeAnim","Animated","Value","componentDidMount","onClose","onAnimationEnd","duration","timing","animArr","toValue","useNativeDriver","delay","push","sequence","start","componentWillUnmount","stop","render","content","style","styles","container","innerContainer","opacity","defaultProps","StyleSheet","create","flex","position","left","top","right","display","justifyContent","alignContent","flexDirection","marginRight","paddingLeft","paddingBottom","paddingRight","paddingTop","info","backgroundColor","success","error","warning"],"mappings":"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","sourcesContent":["import React, { Component } from 'react';\nimport { View, Text, StyleSheet, Animated, StyleProp, ViewStyle } from 'react-native';\nimport Icon, { IconsName } from '../Icon';\n\nexport interface ToastProps {\n  type: 'info' | 'success' | 'warning' | 'error';\n  content: string;\n  duration?: number;\n  showIcon?: boolean;\n  icon?: IconsName;\n  onClose?: () => void;\n  onAnimationEnd?: () => void;\n  style?: StyleProp<ViewStyle>;\n}\n\nexport default class ToastContainer extends Component<ToastProps, any> {\n  static defaultProps = {\n    duration: 3,\n    type: 'info',\n  };\n\n  anim: Animated.CompositeAnimation | null | undefined;\n\n  constructor(props: ToastProps) {\n    super(props);\n    this.state = {\n      fadeAnim: new Animated.Value(1),\n    };\n  }\n  componentDidMount() {\n    const { onClose, onAnimationEnd } = this.props;\n    const duration = this.props.duration as number;\n    const timing = Animated.timing;\n    if (this.anim) {\n      this.anim = null;\n    }\n    const animArr = [\n      timing(this.state.fadeAnim, {\n        toValue: 1,\n        duration: 200,\n        useNativeDriver: true,\n      }),\n      Animated.delay(duration * 1000),\n    ];\n    if (duration > 0) {\n      animArr.push(\n        timing(this.state.fadeAnim, {\n          toValue: 0,\n          duration: 200,\n          useNativeDriver: true,\n        }),\n      );\n    }\n    this.anim = Animated.sequence(animArr);\n    this.anim.start(() => {\n      if (duration > 0) {\n        this.anim = null;\n        if (onClose) {\n          onClose();\n        }\n        if (onAnimationEnd) {\n          onAnimationEnd();\n        }\n      }\n    });\n  }\n\n  componentWillUnmount() {\n    if (this.anim) {\n      this.anim.stop();\n      this.anim = null;\n    }\n  }\n\n  renderIcon = () => {\n    const { type } = this.props;\n    let icon = this.props.icon;\n    let color = '';\n    if (!icon) {\n      switch (type) {\n        case 'success':\n          icon = 'circle-check';\n          color = '#28a745';\n          break;\n        case 'warning':\n          icon = 'warning';\n          color = '#ffc107';\n          break;\n        case 'info':\n          icon = 'information';\n          color = '#008ef0';\n          break;\n        case 'error':\n          icon = 'circle-close';\n          color = '#dc3545';\n          break;\n        default:\n          break;\n      }\n    }\n    return { icon, color };\n  };\n\n  render() {\n    const { content, type, style } = this.props;\n\n    return (\n      <View style={[styles.container, style]}>\n        <View style={[styles.innerContainer]}>\n          <Animated.View style={{ opacity: this.state.fadeAnim }}>\n            <View style={[styles.content, styles[type]]}>\n              <Icon name={this.renderIcon().icon} size={16} style={[styles.icon]} color={this.renderIcon().color} />\n              <Text>{content}</Text>\n            </View>\n          </Animated.View>\n        </View>\n      </View>\n    );\n  }\n}\n\nconst styles = StyleSheet.create({\n  container: {\n    flex: 1,\n    position: 'absolute',\n    left: 0,\n    top: 100,\n    right: 0,\n  },\n  innerContainer: {\n    display: 'flex',\n    flex: 1,\n    justifyContent: 'center',\n    alignContent: 'center',\n    flexDirection: 'row',\n  },\n  icon: {\n    marginRight: 5,\n  },\n  content: {\n    paddingLeft: 10,\n    paddingBottom: 5,\n    paddingRight: 10,\n    paddingTop: 5,\n    display: 'flex',\n    flexDirection: 'row',\n    alignContent: 'center',\n  },\n  info: {\n    backgroundColor: '#bde4ff',\n    color: '#008ef0',\n  },\n  success: {\n    backgroundColor: '#afecbd',\n    color: '#28a745',\n  },\n  error: {\n    backgroundColor: '#fae3e5',\n  },\n  warning: {\n    backgroundColor: '#fff4d3',\n  },\n});\n"]}