@alicloud/alfa-react 1.4.0-alpha.5 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -70,7 +70,7 @@ var getWidgetDeps = /*#__PURE__*/function () {
70
70
  var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(config, option) {
71
71
  var _objectSpread2;
72
72
 
73
- var _yield$getWidgetVersi, entryUrl, version, _yield$getWidgetVersi2, messageVersion, resp, _yield$getWidgetVersi3, oldVersion, components, injectedWidgetUtils;
73
+ var _yield$getWidgetVersi, _yield$getWidgetVersi2, entryUrl, version, _yield$getWidgetVersi3, _yield$getWidgetVersi4, messageVersion, resp, _yield$getWidgetVersi5, oldVersion, components, injectedWidgetUtils;
74
74
 
75
75
  return _regenerator.default.wrap(function _callee$(_context) {
76
76
  while (1) {
@@ -84,54 +84,56 @@ var getWidgetDeps = /*#__PURE__*/function () {
84
84
 
85
85
  case 2:
86
86
  _yield$getWidgetVersi = _context.sent;
87
- entryUrl = _yield$getWidgetVersi.entryUrl;
87
+ _yield$getWidgetVersi2 = _yield$getWidgetVersi.entryUrl;
88
+ entryUrl = _yield$getWidgetVersi2 === void 0 ? '' : _yield$getWidgetVersi2;
88
89
  version = _yield$getWidgetVersi.version;
89
- _context.next = 7;
90
+ _context.next = 8;
90
91
  return (0, _getWidgetVersionById.getWidgetVersionById)({
91
92
  name: WIDGET_WIND_MESSAGE_ID,
92
93
  version: '0.x'
93
94
  });
94
95
 
95
- case 7:
96
- _yield$getWidgetVersi2 = _context.sent;
97
- messageVersion = _yield$getWidgetVersi2.version;
96
+ case 8:
97
+ _yield$getWidgetVersi3 = _context.sent;
98
+ _yield$getWidgetVersi4 = _yield$getWidgetVersi3.version;
99
+ messageVersion = _yield$getWidgetVersi4 === void 0 ? '0.0.8' : _yield$getWidgetVersi4;
98
100
 
99
101
  if (cachedMessage) {
100
- _context.next = 19;
102
+ _context.next = 21;
101
103
  break;
102
104
  }
103
105
 
104
- _context.prev = 10;
105
- _context.next = 13;
106
+ _context.prev = 12;
107
+ _context.next = 15;
106
108
  return _axios.default.get("https://g.alicdn.com/one-mcms/wind-v2/".concat(messageVersion, "/wind-v2_").concat((widgetUtils.getLocale() || 'en-US').toLowerCase(), ".json"));
107
109
 
108
- case 13:
110
+ case 15:
109
111
  resp = _context.sent;
110
112
  cachedMessage = resp.data;
111
- _context.next = 19;
113
+ _context.next = 21;
112
114
  break;
113
115
 
114
- case 17:
115
- _context.prev = 17;
116
- _context.t0 = _context["catch"](10);
117
-
118
116
  case 19:
119
- _context.next = 21;
117
+ _context.prev = 19;
118
+ _context.t0 = _context["catch"](12);
119
+
120
+ case 21:
121
+ _context.next = 23;
120
122
  return (0, _getWidgetVersionById.getWidgetVersionById)({
121
123
  name: WIDGET_RUNTIME_ID,
122
124
  version: '1.x'
123
125
  });
124
126
 
125
- case 21:
126
- _yield$getWidgetVersi3 = _context.sent;
127
- oldVersion = _yield$getWidgetVersi3.version;
127
+ case 23:
128
+ _yield$getWidgetVersi5 = _context.sent;
129
+ oldVersion = _yield$getWidgetVersi5.version;
128
130
 
129
131
  if (cachedRuntime[version]) {
130
- _context.next = 29;
132
+ _context.next = 31;
131
133
  break;
132
134
  }
133
135
 
134
- _context.next = 26;
136
+ _context.next = 28;
135
137
  return (0, _consoleOsLoader.loadBundle)({
136
138
  id: WIDGET_RUNTIME_ID,
137
139
  url: entryUrl,
@@ -156,14 +158,14 @@ var getWidgetDeps = /*#__PURE__*/function () {
156
158
  }
157
159
  });
158
160
 
159
- case 26:
161
+ case 28:
160
162
  cachedRuntime[version] = _context.sent;
161
163
  components = cachedRuntime[version].default['@ali/wind'];
162
164
  Object.keys(components).forEach(function (key) {
163
165
  cachedRuntime[version].default["@ali/wind/lib/".concat((0, _kebabCase.default)(key).toLowerCase())] = components[key];
164
166
  });
165
167
 
166
- case 29:
168
+ case 31:
167
169
  injectedWidgetUtils = _objectSpread(_objectSpread({}, widgetUtils), {}, {
168
170
  getChannelLink: widgetUtils.channelLinkFactory(function () {
169
171
  return config.links[widgetUtils.getChannel() || 'OFFICIAL'];
@@ -188,12 +190,12 @@ var getWidgetDeps = /*#__PURE__*/function () {
188
190
  axios: _axios.default
189
191
  }, cachedRuntime[version].default), {}, (_objectSpread2 = {}, (0, _defineProperty2.default)(_objectSpread2, WIDGET_UTILS_PKG_NAME, injectedWidgetUtils), (0, _defineProperty2.default)(_objectSpread2, '@ali/widget-utils-config', injectedWidgetUtils), (0, _defineProperty2.default)(_objectSpread2, '@ali/widget-loader', createWidget), _objectSpread2)));
190
192
 
191
- case 31:
193
+ case 33:
192
194
  case "end":
193
195
  return _context.stop();
194
196
  }
195
197
  }
196
- }, _callee, null, [[10, 17]]);
198
+ }, _callee, null, [[12, 19]]);
197
199
  }));
198
200
 
199
201
  return function getWidgetDeps(_x, _x2) {
@@ -11,17 +11,21 @@ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"))
11
11
 
12
12
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
13
13
 
14
- var _axios = _interopRequireDefault(require("axios"));
15
-
16
14
  var _template = _interopRequireDefault(require("lodash/template"));
17
15
 
16
+ var _alfaCore = require("@alicloud/alfa-core");
17
+
18
18
  var _env = require("./env");
19
19
 
20
+ var _ALIYUN_CONSOLE_CONFI;
21
+
20
22
  var cachedRelease = null;
21
23
  exports.cachedRelease = cachedRelease;
22
24
  var WIDGET_ENTRY_URL = 'https://g.alicdn.com/${id}/${version}/index.js';
25
+ var uid = (_ALIYUN_CONSOLE_CONFI = window.ALIYUN_CONSOLE_CONFIG) === null || _ALIYUN_CONSOLE_CONFI === void 0 ? void 0 : _ALIYUN_CONSOLE_CONFI.MAIN_ACCOUNT_PK;
23
26
 
24
27
  var normalizeEntryUrl = function normalizeEntryUrl(id, version, resourceUrl) {
28
+ if (!version) throw new Error('No Version for Widget');
25
29
  var gitRepoId = id.replace('@ali/', '').replace('widget-', 'widget/');
26
30
  return (0, _template.default)(resourceUrl)({
27
31
  id: gitRepoId,
@@ -31,52 +35,108 @@ var normalizeEntryUrl = function normalizeEntryUrl(id, version, resourceUrl) {
31
35
 
32
36
  var getWidgetVersionById = /*#__PURE__*/function () {
33
37
  var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(option) {
34
- var env, resp, version;
38
+ var _release$distTags, _release$distTags2, _release$nextVersion;
39
+
40
+ var name, _option$central, central, env, Release, version, entryUrl, _resp, _cachedRelease$option, _cachedRelease$option2, latestVersion, _nextVersion, gray, resp, release, nextVersion, sampling;
41
+
35
42
  return _regenerator.default.wrap(function _callee$(_context) {
36
43
  while (1) {
37
44
  switch (_context.prev = _context.next) {
38
45
  case 0:
39
- env = _env.ENV[option.env || (0, _env.getConsoleEnv)()];
46
+ name = option.name, _option$central = option.central, central = _option$central === void 0 ? true : _option$central, env = option.env;
47
+ Release = central ? _env.ENV[env || (0, _env.getConsoleEnv)()] : _env.DIS_ENV[env || (0, _env.getConsoleEnv)()];
40
48
 
41
49
  if (option.version) {
42
- _context.next = 3;
50
+ _context.next = 4;
43
51
  break;
44
52
  }
45
53
 
46
54
  throw new Error('No Version for Widget');
47
55
 
48
- case 3:
56
+ case 4:
49
57
  if (option.version.endsWith('.x')) {
50
- _context.next = 5;
58
+ _context.next = 6;
51
59
  break;
52
60
  }
53
61
 
54
62
  return _context.abrupt("return", {
55
63
  version: option.version,
56
- entryUrl: normalizeEntryUrl(option.name, option.version, env.resourceUrl || WIDGET_ENTRY_URL)
64
+ entryUrl: normalizeEntryUrl(option.name, option.version, Release.resourceUrl || WIDGET_ENTRY_URL)
57
65
  });
58
66
 
59
- case 5:
67
+ case 6:
68
+ if (!central) {
69
+ _context.next = 12;
70
+ break;
71
+ }
72
+
60
73
  if (cachedRelease) {
61
- _context.next = 10;
74
+ _context.next = 12;
62
75
  break;
63
76
  }
64
77
 
65
- _context.next = 8;
66
- return _axios.default.get(env.releaseUrl);
78
+ _context.next = 10;
79
+ return _alfaCore.request.get(Release.releaseUrl);
80
+
81
+ case 10:
82
+ _resp = _context.sent;
83
+
84
+ if (_resp && _resp.data) {
85
+ exports.cachedRelease = cachedRelease = _resp.data;
86
+ }
87
+
88
+ case 12:
89
+ if (!cachedRelease) {
90
+ _context.next = 19;
91
+ break;
92
+ }
67
93
 
68
- case 8:
94
+ latestVersion = cachedRelease[option.name][option.version].latest;
95
+ _nextVersion = (_cachedRelease$option = cachedRelease[option.name][option.version].next) === null || _cachedRelease$option === void 0 ? void 0 : _cachedRelease$option.version;
96
+ gray = (_cachedRelease$option2 = cachedRelease[option.name][option.version].next) === null || _cachedRelease$option2 === void 0 ? void 0 : _cachedRelease$option2.gray;
97
+ version = uid && Number(uid.substring(uid.length - 2)) < gray ? _nextVersion : latestVersion;
98
+ entryUrl = normalizeEntryUrl(option.name, version, Release.resourceUrl || WIDGET_ENTRY_URL);
99
+ return _context.abrupt("return", {
100
+ version: version,
101
+ entryUrl: entryUrl
102
+ });
103
+
104
+ case 19:
105
+ _context.next = 21;
106
+ return _alfaCore.request.get((0, _template.default)(Release.releaseUrl)({
107
+ id: name
108
+ }));
109
+
110
+ case 21:
69
111
  resp = _context.sent;
70
- exports.cachedRelease = cachedRelease = resp.data;
71
112
 
72
- case 10:
73
- version = cachedRelease[option.name][option.version].latest;
113
+ if (!(!resp || !resp.data)) {
114
+ _context.next = 24;
115
+ break;
116
+ }
117
+
118
+ throw new Error('Cannot get Release');
119
+
120
+ case 24:
121
+ release = resp.data;
122
+ nextVersion = (_release$distTags = release['dist-tags']) === null || _release$distTags === void 0 ? void 0 : _release$distTags["".concat(option.version, "-next")];
123
+ version = (_release$distTags2 = release['dist-tags']) === null || _release$distTags2 === void 0 ? void 0 : _release$distTags2[option.version]; // has gray version
124
+
125
+ if (nextVersion && release !== null && release !== void 0 && (_release$nextVersion = release['next-versions']) !== null && _release$nextVersion !== void 0 && _release$nextVersion[nextVersion] && uid) {
126
+ sampling = release['next-versions'][nextVersion].featureStatus.sampling || 0;
127
+
128
+ if (sampling * 100 > Number(uid.substring(uid.length - 2))) {
129
+ version = nextVersion;
130
+ }
131
+ }
132
+
133
+ entryUrl = normalizeEntryUrl(option.name, version, Release.resourceUrl || WIDGET_ENTRY_URL);
74
134
  return _context.abrupt("return", {
75
135
  version: version,
76
- entryUrl: normalizeEntryUrl(option.name, version, env.resourceUrl || WIDGET_ENTRY_URL)
136
+ entryUrl: entryUrl
77
137
  });
78
138
 
79
- case 12:
139
+ case 30:
80
140
  case "end":
81
141
  return _context.stop();
82
142
  }
package/lib/widget.js CHANGED
@@ -82,7 +82,7 @@ function createCWSWidget(option) {
82
82
  deps = _context.sent;
83
83
  return _context.abrupt("return", (0, _consoleOsLoader.loadBundle)({
84
84
  id: (0, _utils.normalizeName)(option.name),
85
- url: (option.url || url).replace('index.js', option !== null && option !== void 0 && option.alfaLoader ? 'index.alfa.js' : 'index.js'),
85
+ url: (option.url || url || '').replace('index.js', option !== null && option !== void 0 && option.alfaLoader ? 'index.alfa.js' : 'index.js'),
86
86
  deps: _objectSpread(_objectSpread({}, deps), option.dependencies),
87
87
  xmlrequest: !option.alfaLoader,
88
88
  context: {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alicloud/alfa-react",
3
- "version": "1.4.0-alpha.5",
3
+ "version": "1.4.0",
4
4
  "description": "Alfa Framework (React Version)",
5
5
  "main": "lib/index.js",
6
6
  "module": "es/index.js",
@@ -39,7 +39,7 @@
39
39
  "typescript": "^3.0.3"
40
40
  },
41
41
  "dependencies": {
42
- "@alicloud/alfa-core": "^1.4.0-alpha.5",
42
+ "@alicloud/alfa-core": "^1.4.0",
43
43
  "@alicloud/console-os-loader": "^1.2.3",
44
44
  "@alicloud/widget-utils-console": "^0.1.6",
45
45
  "classnames": "^2.2.6",
@@ -48,5 +48,5 @@
48
48
  "peerDependencies": {
49
49
  "react": "^16 | ^17"
50
50
  },
51
- "gitHead": "159eecca7062c5210cf9f976cf13db9991a735b1"
51
+ "gitHead": "1c7eb1a7355af5d72966152a3f52f71fe97bde8b"
52
52
  }