-
Notifications
You must be signed in to change notification settings - Fork 4
/
index.js
81 lines (70 loc) · 3.46 KB
/
index.js
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
/*!
* ios-pwa-splash <https://github.com/avadhesh18/iosPWASplash>
*
* Copyright (c) 2023, Avadhesh B.
* Released under the MIT License.
*/
//index.js
function iosPWASplash(icon, color = 'white') {
// Check if the provided 'icon' is a valid URL
if (typeof icon !== 'string' || icon.length === 0) {
throw new Error('Invalid icon URL provided');
}
// Calculate the device's width and height
const deviceWidth = screen.width;
const deviceHeight = screen.height;
// Calculate the pixel ratio
const pixelRatio = window.devicePixelRatio || 1;
// Create two canvases and get their contexts to draw landscape and portrait splash screens.
const canvas = document.createElement('canvas');
const canvas2 = document.createElement('canvas');
const ctx = canvas.getContext('2d');
const ctx2 = canvas2.getContext('2d');
// Create an image element for the icon
const iconImage = new Image();
iconImage.onerror = function () {
throw new Error('Failed to load icon image');
};
iconImage.src = icon;
// Load the icon image, make sure it is served from the same domain (ideal size 512pxX512px). If not then set the proper CORS headers on the image and uncomment the next line.
//iconImage.crossOrigin="anonymous"
iconImage.onload = function () {
// Calculate the icon size based on the device's pixel ratio
const iconSizew = iconImage.width / (3 / pixelRatio);
const iconSizeh = iconImage.height / (3 / pixelRatio);
canvas.width = deviceWidth * pixelRatio;
canvas2.height = canvas.width;
canvas.height = deviceHeight * pixelRatio;
canvas2.width = canvas.height;
ctx.fillStyle = color;
ctx2.fillStyle = color;
ctx.fillRect(0, 0, canvas.width, canvas.height);
ctx2.fillRect(0, 0, canvas2.width, canvas2.height);
// Calculate the position to center the icon
const x = (canvas.width - iconSizew) / 2;
const y = (canvas.height - iconSizeh) / 2;
const x2 = (canvas2.width - iconSizew) / 2;
const y2 = (canvas2.height - iconSizeh) / 2;
// Draw the icon with the calculated size
ctx.drawImage(iconImage, x, y, iconSizew, iconSizeh);
ctx2.drawImage(iconImage, x2, y2, iconSizew, iconSizeh);
const imageDataURL = canvas.toDataURL('image/png');
const imageDataURL2 = canvas2.toDataURL('image/png');
// Create the first startup image <link> tag (splash screen)
const appleTouchStartupImageLink = document.createElement('link');
appleTouchStartupImageLink.setAttribute('rel', 'apple-touch-startup-image');
appleTouchStartupImageLink.setAttribute('media', "screen and (orientation: portrait)");
appleTouchStartupImageLink.setAttribute('href', imageDataURL);
document.head.appendChild(appleTouchStartupImageLink);
// Create the second startup image <link> tag (splash screen)
const appleTouchStartupImageLink2 = document.createElement('link');
appleTouchStartupImageLink2.setAttribute('rel', 'apple-touch-startup-image');
appleTouchStartupImageLink2.setAttribute('media', "screen and (orientation: landscape)");
appleTouchStartupImageLink2.setAttribute('href', imageDataURL2);
document.head.appendChild(appleTouchStartupImageLink2);
};
}
// Export the function for use in Node.js or browser environments
if (typeof module !== 'undefined' && module.exports) {
module.exports = iosPWASplash;
}