@next-core/brick-kit 2.147.1 → 2.148.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.
package/dist/index.esm.js CHANGED
@@ -6139,12 +6139,12 @@ var flowApiDefinitionPromiseMap = new Map(); // Legacy Custom API: `${namespace}
6139
6139
  function isCustomApiProvider(provider) {
6140
6140
  return provider.includes("@");
6141
6141
  }
6142
- function getArgsOfCustomApi(_x, _x2) {
6142
+ function getArgsOfCustomApi(_x, _x2, _x3) {
6143
6143
  return _getArgsOfCustomApi.apply(this, arguments);
6144
6144
  }
6145
6145
 
6146
6146
  function _getArgsOfCustomApi() {
6147
- _getArgsOfCustomApi = _asyncToGenerator$3(function* (provider, originalArgs) {
6147
+ _getArgsOfCustomApi = _asyncToGenerator$3(function* (provider, originalArgs, method) {
6148
6148
  if (!isCustomApiProvider(provider)) {
6149
6149
  return originalArgs;
6150
6150
  }
@@ -6157,15 +6157,15 @@ function _getArgsOfCustomApi() {
6157
6157
  }
6158
6158
 
6159
6159
  var apiProfile = getApiProfileFromApiDefinition(provider, apiDefinition);
6160
- return getApiArgsFromApiProfile(apiProfile, originalArgs);
6160
+ return getApiArgsFromApiProfile(apiProfile, originalArgs, method);
6161
6161
  });
6162
6162
  return _getArgsOfCustomApi.apply(this, arguments);
6163
6163
  }
6164
6164
 
6165
- function getApiArgsFromApiProfile(_ref, originalArgs) {
6165
+ function getApiArgsFromApiProfile(_ref, originalArgs, method) {
6166
6166
  var {
6167
6167
  uri,
6168
- method,
6168
+ method: apiMethod,
6169
6169
  ext_fields,
6170
6170
  name,
6171
6171
  namespace,
@@ -6175,9 +6175,10 @@ function getApiArgsFromApiProfile(_ref, originalArgs) {
6175
6175
  isFileType,
6176
6176
  request
6177
6177
  } = _ref;
6178
+ var isDownload = isFileType && method === "saveAs";
6178
6179
  var fileName;
6179
6180
 
6180
- if (isFileType) {
6181
+ if (isDownload) {
6181
6182
  fileName = originalArgs.shift();
6182
6183
  }
6183
6184
 
@@ -6185,20 +6186,14 @@ function getApiArgsFromApiProfile(_ref, originalArgs) {
6185
6186
  url,
6186
6187
  args
6187
6188
  } = getTransformedUriAndRestArgs(uri, originalArgs, name, namespace, serviceName, version);
6188
- return isFileType ? [fileName, {
6189
+ return [...(isDownload ? [fileName] : []), {
6189
6190
  url,
6190
- method,
6191
- ext_fields,
6192
- responseWrapper: false,
6193
- request
6194
- }, ...args, {
6195
- responseType: "blob"
6196
- }] : [{
6197
- url,
6198
- method,
6191
+ originalUri: uri,
6192
+ method: apiMethod,
6199
6193
  ext_fields,
6200
6194
  responseWrapper,
6201
- request
6195
+ request,
6196
+ isFileType
6202
6197
  }, ...args];
6203
6198
  }
6204
6199
 
@@ -6255,7 +6250,7 @@ function fetchFlowApiDefinition(provider) {
6255
6250
  return promise;
6256
6251
  }
6257
6252
 
6258
- function _fetchFlowApiDefinition(_x3) {
6253
+ function _fetchFlowApiDefinition(_x4) {
6259
6254
  return _fetchFlowApiDefinition2.apply(this, arguments);
6260
6255
  }
6261
6256
 
@@ -6869,7 +6864,7 @@ function _brickCallback() {
6869
6864
  var computedArgs = argsFactory(handler.args, context, event, options);
6870
6865
 
6871
6866
  if (isUseProviderHandler(handler)) {
6872
- computedArgs = yield getArgsOfCustomApi(handler.useProvider, computedArgs);
6867
+ computedArgs = yield getArgsOfCustomApi(handler.useProvider, computedArgs, method);
6873
6868
  }
6874
6869
 
6875
6870
  return target[method](...computedArgs);
@@ -7298,35 +7293,36 @@ function processBootstrapResponse(bootstrapResponse) {
7298
7293
  }
7299
7294
 
7300
7295
  var CUSTOM_API_PROVIDER = "brick-kit.provider-custom-api";
7301
- function processExtFields(ext_fields) {
7302
- var hasFields = type => {
7303
- return ext_fields.some(item => item.source === type);
7304
- };
7305
7296
 
7306
- var hasQueryParams = hasFields("query");
7307
- var HasBodyParams = hasFields("body");
7297
+ function hasFields(ext_fields, type) {
7298
+ return ext_fields.some(item => item.source === type);
7299
+ }
7300
+
7301
+ function processExtFields(ext_fields) {
7302
+ var hasQueryParams = hasFields(ext_fields, "query");
7303
+ var hasBodyParams = hasFields(ext_fields, "body");
7308
7304
 
7309
7305
  for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
7310
7306
  args[_key - 1] = arguments[_key];
7311
7307
  }
7312
7308
 
7313
- if (hasQueryParams && HasBodyParams) {
7314
- var [_data, params, _options] = args;
7315
- return {
7316
- data: _data,
7317
- options: _objectSpread({
7318
- params: params
7319
- }, _options)
7320
- };
7321
- }
7322
-
7323
7309
  if (hasQueryParams) {
7324
- var [_params, _options2] = args;
7310
+ if (hasBodyParams) {
7311
+ var [_data, _params, _options2] = args;
7312
+ return {
7313
+ data: _data,
7314
+ options: _objectSpread({
7315
+ params: _params
7316
+ }, _options2)
7317
+ };
7318
+ }
7319
+
7320
+ var [params, _options] = args;
7325
7321
  return {
7326
7322
  data: {},
7327
7323
  options: _objectSpread({
7328
- params: _params
7329
- }, _options2)
7324
+ params: params
7325
+ }, _options)
7330
7326
  };
7331
7327
  } // only hasBodyParams or default
7332
7328
 
@@ -7395,12 +7391,17 @@ function _CustomApi() {
7395
7391
  _CustomApi = _asyncToGenerator$3(function* (_ref2) {
7396
7392
  var {
7397
7393
  url,
7394
+ originalUri,
7398
7395
  method = "GET",
7399
7396
  responseWrapper = true,
7400
7397
  ext_fields = [],
7401
- request
7398
+ request,
7399
+ isFileType
7402
7400
  } = _ref2;
7403
7401
  var isSimpleRequest = ["get", "delete", "head"].includes(method.toLowerCase());
7402
+ var defaultOptions = isFileType ? {
7403
+ responseType: "blob"
7404
+ } : {};
7404
7405
  var response;
7405
7406
 
7406
7407
  for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
@@ -7408,17 +7409,28 @@ function _CustomApi() {
7408
7409
  }
7409
7410
 
7410
7411
  if (isSimpleRequest) {
7411
- var [data, options] = args;
7412
- response = yield http.simpleRequest(method, url, _objectSpread({
7413
- params: data
7414
- }, options));
7412
+ var _originalUri$match$le, _originalUri$match, _request$fields$lengt, _request$fields;
7413
+
7414
+ var noParams = originalUri && request ? ((_originalUri$match$le = (_originalUri$match = originalUri.match(/:([^/]+)/g)) === null || _originalUri$match === void 0 ? void 0 : _originalUri$match.length) !== null && _originalUri$match$le !== void 0 ? _originalUri$match$le : 0) === ((_request$fields$lengt = (_request$fields = request.fields) === null || _request$fields === void 0 ? void 0 : _request$fields.length) !== null && _request$fields$lengt !== void 0 ? _request$fields$lengt : 0) : false;
7415
+ var params;
7416
+ var options;
7417
+
7418
+ if (noParams) {
7419
+ [options] = args;
7420
+ } else {
7421
+ [params, options] = args;
7422
+ }
7423
+
7424
+ response = yield http.simpleRequest(method, url, _objectSpread(_objectSpread({
7425
+ params
7426
+ }, defaultOptions), options));
7415
7427
  } else {
7416
7428
  var isUploadType = hasFileType(request);
7417
7429
  var result = processExtFields(ext_fields, ...args);
7418
- response = yield http.requestWithBody(method, url, isUploadType ? transformFormData(result.data) : result.data, result.options);
7430
+ response = yield http.requestWithBody(method, url, isUploadType ? transformFormData(result.data) : result.data, _objectSpread(_objectSpread({}, defaultOptions), result.options));
7419
7431
  }
7420
7432
 
7421
- return responseWrapper ? response.data : response;
7433
+ return (isFileType ? false : responseWrapper) ? response.data : response;
7422
7434
  });
7423
7435
  return _CustomApi.apply(this, arguments);
7424
7436
  }
@@ -11644,7 +11656,7 @@ class Resolver {
11644
11656
  } else {
11645
11657
  promise = _asyncToGenerator$3(function* () {
11646
11658
  if (useProvider) {
11647
- actualArgs = yield getArgsOfCustomApi(useProvider, actualArgs);
11659
+ actualArgs = yield getArgsOfCustomApi(useProvider, actualArgs, method);
11648
11660
  }
11649
11661
 
11650
11662
  return providerBrick[method](...actualArgs);
@@ -12144,7 +12156,8 @@ class Router {
12144
12156
  }
12145
12157
 
12146
12158
  var history = getHistory();
12147
- history.unblock(); // Create the page tracker before page load.
12159
+ history.unblock();
12160
+ var renderStartTime = performance.now(); // Create the page tracker before page load.
12148
12161
  // And the API Analyzer maybe disabled.
12149
12162
 
12150
12163
  var pageTracker = (_apiAnalyzer$getInsta = apiAnalyzer.getInstance()) === null || _apiAnalyzer$getInsta === void 0 ? void 0 : _apiAnalyzer$getInsta.pageTracker();
@@ -12382,6 +12395,8 @@ class Router {
12382
12395
  // we say *page found*, otherwise, *page not found*.
12383
12396
 
12384
12397
  if (route && route.type !== "routes" || failed) {
12398
+ var _this3$kernel$bootstr, _this3$kernel$bootstr2;
12399
+
12385
12400
  main.length > 0 && mountTree(main, mountPoints.main);
12386
12401
  portal.length > 0 && mountTree(portal, mountPoints.portal);
12387
12402
  afterMountTree(mountPoints.main);
@@ -12410,7 +12425,29 @@ class Router {
12410
12425
  path: locationContext.getCurrentMatch().path,
12411
12426
  username: getAuth().username,
12412
12427
  pageTitle: document.title
12413
- }); // analytics page_view event
12428
+ });
12429
+ var renderTime = performance.now() - renderStartTime;
12430
+ var {
12431
+ loadTime = 0,
12432
+ loadInfoPage
12433
+ } = (_this3$kernel$bootstr = (_this3$kernel$bootstr2 = _this3.kernel.bootstrapData.settings) === null || _this3$kernel$bootstr2 === void 0 ? void 0 : _this3$kernel$bootstr2.misc) !== null && _this3$kernel$bootstr !== void 0 ? _this3$kernel$bootstr : {};
12434
+
12435
+ if (currentApp.isBuildPush && loadTime > 0 && renderTime > loadTime) {
12436
+ var getSecond = time => Math.floor(time * 100) / 100;
12437
+
12438
+ window.dispatchEvent(new CustomEvent("app.bar.tips", {
12439
+ detail: [_objectSpread({
12440
+ text: "\u60A8\u7684\u9875\u9762\u5B58\u5728\u6027\u80FD\u95EE\u9898, \u5F53\u524D\u9875\u9762\u6E32\u67D3\u65F6\u95F4\u4E3A: ".concat(getSecond(renderTime / 1000), " \u79D2, \u89C4\u5B9A\u9608\u503C\u4E3A: ").concat(getSecond(loadTime / 1000), " \u79D2; \u60A8\u5DF2\u8D85\u8FC7, \u8BF7\u60A8\u9488\u5BF9\u8BE5\u9875\u9762\u8FDB\u884C\u6027\u80FD\u4F18\u5316!"),
12441
+ closeable: false
12442
+ }, loadInfoPage ? {
12443
+ info: {
12444
+ label: "查看详情",
12445
+ url: loadInfoPage
12446
+ }
12447
+ } : {})]
12448
+ }));
12449
+ } // analytics page_view event
12450
+
12414
12451
 
12415
12452
  userAnalytics.event("page_view", _objectSpread({
12416
12453
  micro_app_id: _this3.kernel.currentApp.id,