This repository was archived by the owner on Mar 19, 2026. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathflutter_bootstrap.js
More file actions
88 lines (74 loc) · 2.43 KB
/
flutter_bootstrap.js
File metadata and controls
88 lines (74 loc) · 2.43 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
86
87
88
"use strict";
{{=<% %>=}}{{flutter_js}}<%={{ }}=%>
{{=<% %>=}}{{flutter_build_config}}<%={{ }}=%>
const progressBar = document.querySelector('#progress-bar');
const progressText = document.querySelector('#progress-text');
const progressIndicator = document.querySelector('#progress-indicator');
async function readAssets() {
// NOTE: AssetManifest.json will be deprecated in favour of AssetManifest.bin:
// https://github.com/VeryGoodOpenSource/flutter_web_preloader/issues/28
const response = await fetch('assets/AssetManifest.json');
const manifest = await response.json();
const assets = Object.values(manifest)
.map((list) => list.map((url) => 'assets/' + url))
.reduce((arr, curr) => [...arr, ...curr], []);
return assets;
}
let loadedAssets = 0;
let totalAssets;
async function beginPreloading() {
const assets = await readAssets();
totalAssets = assets.length;
if (totalAssets === 0) {
// No assets to load, so we can skip the loading process entirely.
return;
}
const batchSize = {{batch_size}};
progressIndicator.style.width = '0%';
progressText.textContent = `Loaded ${loadedAssets} of ${totalAssets} assets`;
for (let i = 0; i < assets.length; i += batchSize) {
const batch = assets.slice(i, i + batchSize);
await loadBatch(batch);
}
}
function reportProgress() {
loadedAssets++;
const value = Math.floor((loadedAssets / totalAssets) * 100) + '%';
progressIndicator.style.width = value;
progressText.textContent = `Loaded ${loadedAssets} of ${totalAssets} assets`;
}
async function load(url) {
try {
const response = await fetch(url);
if (!response.ok) {
throw new Error(
`Failed to load: ${response.status} ${response.statusText}`,
);
}
return await response.text();
} catch (error) {
throw new Error("Network error");
}
}
async function loadBatch(urls) {
const loadPromises = urls.map(async (url) => {
await load(url);
reportProgress();
});
try {
return await Promise.all(loadPromises);
} catch (error) {
console.error('Error loading one or more asset:', error);
}
}
_flutter.loader.load({
serviceWorkerSettings: {
serviceWorkerVersion: {{=<% %>=}}{{flutter_service_worker_version}}<%={{ }}=%>,
},
onEntrypointLoaded: async function(engineInitializer) {
await Promise.all([
beginPreloading(),
engineInitializer.initializeEngine(),
]).then(([_, appRunner]) => appRunner.runApp());
}
});