UNPKG

3.63 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _extends2 = require("babel-runtime/helpers/extends");
8
9var _extends3 = _interopRequireDefault(_extends2);
10
11var _objectWithoutProperties2 = require("babel-runtime/helpers/objectWithoutProperties");
12
13var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
14
15var _taggedTemplateLiteral2 = require("babel-runtime/helpers/taggedTemplateLiteral");
16
17var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2);
18
19var _templateObject = (0, _taggedTemplateLiteral3.default)(["\n opacity: 0.06;\n height: 100%;\n width: 100%;\n fill: ", ";\n"], ["\n opacity: 0.06;\n height: 100%;\n width: 100%;\n fill: ", ";\n"]),
20 _templateObject2 = (0, _taggedTemplateLiteral3.default)(["\n opacity: 0.55;\n fill: none;\n stroke: ", ";\n stroke-width: 2;\n"], ["\n opacity: 0.55;\n fill: none;\n stroke: ", ";\n stroke-width: 2;\n"]),
21 _templateObject3 = (0, _taggedTemplateLiteral3.default)(["\n opacity: 0;\n position: absolute;\n :checked + svg ", " {\n opacity: 1;\n }\n :checked + svg ", " {\n opacity: 1;\n }\n"], ["\n opacity: 0;\n position: absolute;\n :checked + svg ", " {\n opacity: 1;\n }\n :checked + svg ", " {\n opacity: 1;\n }\n"]),
22 _templateObject4 = (0, _taggedTemplateLiteral3.default)(["\n display: grid;\n height: 100%;\n"], ["\n display: grid;\n height: 100%;\n"]);
23
24var _react = require("react");
25
26var _react2 = _interopRequireDefault(_react);
27
28var _styledComponents = require("styled-components");
29
30var _styledComponents2 = _interopRequireDefault(_styledComponents);
31
32function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
33
34var DOT = _styledComponents2.default.circle(_templateObject, function (_ref) {
35 var theme = _ref.theme;
36 return theme ? theme.alpha : "#000";
37});
38var OUTLINE = _styledComponents2.default.circle(_templateObject2, function (_ref2) {
39 var theme = _ref2.theme;
40 return theme ? theme.beta : "#000";
41});
42var RADIO = _styledComponents2.default.input(_templateObject3, DOT, OUTLINE);
43var BODY = _styledComponents2.default.div(_templateObject4);
44var RadioButton = function RadioButton(_ref3) {
45 var checked = _ref3.checked,
46 onChange = _ref3.onChange,
47 id = _ref3.id,
48 className = _ref3.className,
49 _ref3$dotRatio = _ref3.dotRatio,
50 dotRatio = _ref3$dotRatio === undefined ? 0.45 : _ref3$dotRatio,
51 _ref3$outlineRatio = _ref3.outlineRatio,
52 outlineRatio = _ref3$outlineRatio === undefined ? 0.75 : _ref3$outlineRatio,
53 _ref3$size = _ref3.size,
54 size = _ref3$size === undefined ? 12 : _ref3$size,
55 props = (0, _objectWithoutProperties3.default)(_ref3, ["checked", "onChange", "id", "className", "dotRatio", "outlineRatio", "size"]);
56
57 return _react2.default.createElement(
58 BODY,
59 { className: className },
60 _react2.default.createElement(RADIO, (0, _extends3.default)({
61 onChange: onChange,
62 checked: checked,
63 type: "radio",
64 id: id
65 }, props)),
66 _react2.default.createElement(
67 "svg",
68 {
69 className: "svg",
70 fill: "currentColor",
71 preserveAspectRatio: "xMidYMid meet",
72 height: size * 2,
73 width: size * 2,
74 viewBox: "0 0 " + size * 2 + " " + size * 2
75 },
76 _react2.default.createElement(OUTLINE, {
77 cx: size,
78 cy: size,
79 r: size * outlineRatio
80 }),
81 _react2.default.createElement(DOT, {
82 cx: size,
83 cy: size,
84 r: size * dotRatio
85 })
86 )
87 );
88};
89
90exports.default = RadioButton;
\No newline at end of file