@r3l/app
Version:
130 lines (108 loc) • 5.9 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styled = require("../../styled");
var _styles = require("../../../styles");
var _tooltip = _interopRequireDefault(require("../../tooltip/tooltip.component"));
var _layout = require("../../../styles/layout");
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var BUTTON_IMAGES = {
UPVOTE: {
white: require("../../../../public/img/vote_buttons/upvote-white.png"),
default: require("../../../../public/img/vote_buttons/upvote-grey-outline.png"),
active: require("../../../../public/img/vote_buttons/upvote-blue.png"),
hover: require("../../../../public/img/vote_buttons/upvote-blue-outline.png")
},
DOWNVOTE: {
white: require("../../../../public/img/vote_buttons/downvote-white.png"),
default: require("../../../../public/img/vote_buttons/downvote-grey-outline.png"),
active: require("../../../../public/img/vote_buttons/downvote-red.png"),
hover: require("../../../../public/img/vote_buttons/downvote-red-outline.png")
}
};
var transition = !_styles.isNative ? {
transitionProperty: 'all',
transitionDuration: '0.2s',
transitionTimingFunction: 'ease'
} : {};
var ButtonImage = (0, _styled.styled)(_styled.Image)(function (p) {
return _objectSpread(_objectSpread({}, transition), {}, {
transform: p.hover && !p.active && !p.disabled && !_styles.isNative ? 'scale(1.1)' : []
});
});
PostButton.propTypes = {
color: _propTypes.default.string,
alt: _propTypes.default.string,
isActive: _propTypes.default.bool,
imageSet: _propTypes.default.oneOf(['DOWNVOTE', 'UPVOTE']),
onPress: _propTypes.default.func,
tooltipData: _propTypes.default.object
};
function PostButton(_ref) {
var alt = _ref.alt,
isActive = _ref.isActive,
imageSet = _ref.imageSet,
onPress = _ref.onPress,
color = _ref.color,
tooltipData = _ref.tooltipData;
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
hover = _useState2[0],
setHover = _useState2[1];
var _useState3 = (0, _react.useState)(false),
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
active = _useState4[0],
setActive = _useState4[1];
var images = BUTTON_IMAGES[imageSet];
var defaultState = images[color] || images.default;
var source = isActive && images.active || hover && images.hover || defaultState;
return /*#__PURE__*/_react.default.createElement(_tooltip.default, {
data: tooltipData,
name: "voteDesk"
}, /*#__PURE__*/_react.default.createElement(_styled.Touchable, {
onPress: onPress,
hitSlop: {
top: 6,
left: 6,
right: 6,
bottom: 6
}
}, /*#__PURE__*/_react.default.createElement(ButtonImage, {
sx: {
width: _layout.VOTE_BUTTON_SIZE,
height: _layout.VOTE_BUTTON_SIZE
},
alt: alt,
resizeMode: "contain",
source: source,
hover: hover,
active: active,
onMouseDown: function onMouseDown() {
return setActive(1);
},
onMouseUp: function onMouseUp() {
return setActive(0);
},
onMouseEnter: function onMouseEnter() {
return setHover(1);
},
onMouseLeave: function onMouseLeave() {
setHover(0);
setActive(0);
}
})));
}
var _default = /*#__PURE__*/(0, _react.memo)(PostButton);
exports.default = _default;
//# sourceMappingURL=postbutton.js.map