studiokit-scaffolding-js 4.7.0 → 4.7.1-alpha.2
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.
|
@@ -26,6 +26,7 @@ var CircularProgress_1 = __importDefault(require("@material-ui/core/CircularProg
|
|
|
26
26
|
var Sentry = __importStar(require("@sentry/react"));
|
|
27
27
|
var detect_browser_1 = require("detect-browser");
|
|
28
28
|
var react_1 = __importStar(require("react"));
|
|
29
|
+
var lockDownBrowser_1 = require("../../utils/lockDownBrowser");
|
|
29
30
|
var logger_1 = require("../../utils/logger");
|
|
30
31
|
var Shortcut = function (_a) {
|
|
31
32
|
var content = _a.content;
|
|
@@ -86,6 +87,7 @@ var RefreshIndicator = function (_a) {
|
|
|
86
87
|
}, [hasLogged, localLogAndWarnAfterSeconds, seconds, shouldLog, shouldWarn]);
|
|
87
88
|
var refreshShortcut = getRefreshShortcut();
|
|
88
89
|
var hardRefreshShortcut = getHardRefreshShortcut();
|
|
90
|
+
var lockDownBrowserInfo = lockDownBrowser_1.getLockDownBrowserInfo();
|
|
89
91
|
return (react_1.default.createElement("div", null,
|
|
90
92
|
react_1.default.createElement(CircularProgress_1.default, { size: loaderSize !== null && loaderSize !== void 0 ? loaderSize : 40, style: loaderStyle !== null && loaderStyle !== void 0 ? loaderStyle : {
|
|
91
93
|
display: 'inherit',
|
|
@@ -102,11 +104,14 @@ var RefreshIndicator = function (_a) {
|
|
|
102
104
|
refreshShortcut ? react_1.default.createElement(react_1.default.Fragment, null,
|
|
103
105
|
", ",
|
|
104
106
|
refreshShortcut) : ''),
|
|
105
|
-
|
|
106
|
-
"
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
107
|
+
!lockDownBrowserInfo.isClientLockDownBrowser ? (react_1.default.createElement(react_1.default.Fragment, null,
|
|
108
|
+
hardRefreshShortcut && react_1.default.createElement("li", null,
|
|
109
|
+
"\"Hard Refresh\" the page, ",
|
|
110
|
+
hardRefreshShortcut),
|
|
111
|
+
react_1.default.createElement("li", { className: !!refreshShortcut || !!hardRefreshShortcut ? 'mb2' : '' }, "Try a different browser"),
|
|
112
|
+
react_1.default.createElement("li", null, "Clear your browser cache and then refresh"))) : (react_1.default.createElement(react_1.default.Fragment, null,
|
|
113
|
+
react_1.default.createElement("li", null, "Close and re-open LockDown Browser"),
|
|
114
|
+
react_1.default.createElement("li", null, "Restart your computer and then re-open LockDown Browser")))),
|
|
110
115
|
react_1.default.createElement("p", { className: "mb3" },
|
|
111
116
|
"If you are still experiencing loading issues, please contact us at",
|
|
112
117
|
' ',
|
package/lib/utils/url.js
CHANGED
|
@@ -44,6 +44,7 @@ var lodash_1 = __importDefault(require("lodash"));
|
|
|
44
44
|
var shard_1 = __importDefault(require("../constants/shard"));
|
|
45
45
|
var tier_1 = __importDefault(require("../constants/tier"));
|
|
46
46
|
var windowService_1 = __importDefault(require("../services/windowService"));
|
|
47
|
+
var logger_1 = require("./logger");
|
|
47
48
|
var shard_2 = require("./shard");
|
|
48
49
|
function getApiBaseUrl(tier, apiUrlString) {
|
|
49
50
|
// skip shard logic on LOCAL or if not using a custom domain (e.g. staging)
|
|
@@ -74,15 +75,46 @@ function isUrlValid(url) {
|
|
|
74
75
|
return /^(?:http(s)?:\/\/)?[\w.-]+(?:\.[\w.-]+)+[\w\-._~:/?#[\]@!$&'()*+,;=]+$/.test(url);
|
|
75
76
|
}
|
|
76
77
|
exports.isUrlValid = isUrlValid;
|
|
78
|
+
var RETRY_LIMIT = 5;
|
|
79
|
+
function wait(time) {
|
|
80
|
+
return new Promise(function (resolve) {
|
|
81
|
+
setTimeout(resolve, time);
|
|
82
|
+
});
|
|
83
|
+
}
|
|
77
84
|
function fetchText(url, options) {
|
|
78
85
|
return __awaiter(this, void 0, void 0, function () {
|
|
79
|
-
var resp;
|
|
86
|
+
var tryCount, didFail, resp, text, error_1;
|
|
80
87
|
return __generator(this, function (_a) {
|
|
81
88
|
switch (_a.label) {
|
|
82
|
-
case 0:
|
|
89
|
+
case 0:
|
|
90
|
+
tryCount = 0;
|
|
91
|
+
didFail = false;
|
|
92
|
+
_a.label = 1;
|
|
83
93
|
case 1:
|
|
94
|
+
didFail = false;
|
|
95
|
+
tryCount++;
|
|
96
|
+
_a.label = 2;
|
|
97
|
+
case 2:
|
|
98
|
+
_a.trys.push([2, 5, , 7]);
|
|
99
|
+
return [4 /*yield*/, fetch(url, options)];
|
|
100
|
+
case 3:
|
|
84
101
|
resp = _a.sent();
|
|
85
|
-
return [
|
|
102
|
+
return [4 /*yield*/, resp.text()];
|
|
103
|
+
case 4:
|
|
104
|
+
text = _a.sent();
|
|
105
|
+
return [2 /*return*/, text];
|
|
106
|
+
case 5:
|
|
107
|
+
error_1 = _a.sent();
|
|
108
|
+
didFail = true;
|
|
109
|
+
logger_1.getLogger().error("Failed to fetch " + url + ". attempt: " + tryCount + ", error: " + error_1);
|
|
110
|
+
return [4 /*yield*/, wait(2 ^ (tryCount * 100))]; // 100, 200, 400...
|
|
111
|
+
case 6:
|
|
112
|
+
_a.sent(); // 100, 200, 400...
|
|
113
|
+
return [3 /*break*/, 7];
|
|
114
|
+
case 7:
|
|
115
|
+
if (tryCount < RETRY_LIMIT && didFail) return [3 /*break*/, 1];
|
|
116
|
+
_a.label = 8;
|
|
117
|
+
case 8: throw new Error("Failed to fetch " + url + " after " + RETRY_LIMIT + " attempts.");
|
|
86
118
|
}
|
|
87
119
|
});
|
|
88
120
|
});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "studiokit-scaffolding-js",
|
|
3
|
-
"version": "4.7.
|
|
3
|
+
"version": "4.7.1-alpha.2",
|
|
4
4
|
"description": "Common scaffolding for Studio apps at Purdue",
|
|
5
5
|
"repository": "https://gitlab.com/purdue-informatics/studiokit/studiokit-scaffolding-js",
|
|
6
6
|
"license": "MIT",
|