LocaleReceiver.js
3.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useLocaleReceiver = useLocaleReceiver;
exports["default"] = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
var React = _interopRequireWildcard(require("react"));
var _default = _interopRequireDefault(require("./default"));
var _context = _interopRequireDefault(require("./context"));
var LocaleReceiver = /*#__PURE__*/function (_React$Component) {
(0, _inherits2["default"])(LocaleReceiver, _React$Component);
var _super = (0, _createSuper2["default"])(LocaleReceiver);
function LocaleReceiver() {
(0, _classCallCheck2["default"])(this, LocaleReceiver);
return _super.apply(this, arguments);
}
(0, _createClass2["default"])(LocaleReceiver, [{
key: "getLocale",
value: function getLocale() {
var _this$props = this.props,
componentName = _this$props.componentName,
defaultLocale = _this$props.defaultLocale;
var locale = defaultLocale || _default["default"][componentName || 'global'];
var antLocale = this.context;
var localeFromContext = componentName && antLocale ? antLocale[componentName] : {};
return (0, _extends2["default"])((0, _extends2["default"])({}, typeof locale === 'function' ? locale() : locale), localeFromContext || {});
}
}, {
key: "getLocaleCode",
value: function getLocaleCode() {
var antLocale = this.context;
var localeCode = antLocale && antLocale.locale; // Had use LocaleProvide but didn't set locale
if (antLocale && antLocale.exist && !localeCode) {
return _default["default"].locale;
}
return localeCode;
}
}, {
key: "render",
value: function render() {
return this.props.children(this.getLocale(), this.getLocaleCode(), this.context);
}
}]);
return LocaleReceiver;
}(React.Component);
exports["default"] = LocaleReceiver;
LocaleReceiver.defaultProps = {
componentName: 'global'
};
LocaleReceiver.contextType = _context["default"];
function useLocaleReceiver(componentName, defaultLocale) {
var antLocale = React.useContext(_context["default"]);
var componentLocale = React.useMemo(function () {
var locale = defaultLocale || _default["default"][componentName || 'global'];
var localeFromContext = componentName && antLocale ? antLocale[componentName] : {};
return (0, _extends2["default"])((0, _extends2["default"])({}, typeof locale === 'function' ? locale() : locale), localeFromContext || {});
}, [componentName, defaultLocale, antLocale]);
return [componentLocale];
}