forked from DevExpress/device-specs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
utils.js
49 lines (42 loc) · 1.64 KB
/
utils.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
const fs = require('fs');
const { join } = require('path');
const VIEWPORT_SIZES_PATH = join(__dirname, 'viewport-sizes.json');
const VIEWPORT_DATA = JSON.parse(fs.readFileSync(VIEWPORT_SIZES_PATH));
/** Gets the name and the viewport size of mobile devices
* @function
* @name getDevicesViewportData
* @returns {ViewportData} A JSON Object that contains device names and viewport sizes.
*/
function getDevicesViewportData () {
return VIEWPORT_DATA;
}
/** @typedef {Object} DeviceViewportSize
* @description Defines the size of a device viewport.
* @property {number} portraitWidth - The viewport width in portrait orientation.
* @property {number} landscapeWidth - The viewport width in landscape orientation.
*/
/** Gets the viewport size for the specified device.
* @function
* @name getViewportSize
* @param {string} deviceName - Specifies the name of the target device. Use values from the Device Name column of [this table]{@link http://viewportsizes.com/}.
* @returns {DeviceViewportSize} The size of the device viewport.
*/
function getViewportSize (deviceName) {
deviceName = deviceName.toLowerCase().replace(/\s+/g, '');
return getDevicesViewportData()[deviceName];
}
/**
* Checks if the provided string is a valid device name contained in the screen size database.
* @function
* @name isValidDeviceName
* @param {string} inputString - The string to be validated.
* @returns {boolean} `true` if the specified string is a valid device name.
*/
function isValidDeviceName (inputString) {
return !!getViewportSize(inputString);
}
module.exports = {
getDevicesViewportData,
getViewportSize,
isValidDeviceName
};