UNPKG

@huantv/vue

Version:
57 lines (48 loc) 1.64 kB
/* eslint-disable import/prefer-default-export */ import Native from './native'; import ElementNode from '../renderer/element-node'; function drawStatusBar(appOptions = {}) { const { iPhone } = appOptions; let statusBarOpts = {}; if (iPhone && iPhone.statusBar) { statusBarOpts = iPhone.statusBar; } if (statusBarOpts.disabled) { return null; } const statusBar = new ElementNode('div'); const { statusBarHeight } = Native.Dimensions.screen; // Initial status bar if (Native.screenIsVertical) { statusBar.setStyle('height', statusBarHeight); } else { statusBar.setStyle('height', 0); } // Set safe area background color let backgroundColor = 4282431619; // Vue green // FIXME: Use Number.isInteger to check backgroundColor type. if (typeof statusBarOpts.backgroundColor === 'number') { ({ backgroundColor } = statusBarOpts); } statusBar.setStyle('backgroundColor', backgroundColor); // Set safe area background image if defined if (typeof statusBarOpts.backgroundImage === 'string') { const statusBarImage = new ElementNode('img'); statusBarImage.setStyle('width', Native.Dimensions.screen.width); statusBarImage.setStyle('height', statusBarHeight); statusBarImage.setAttribute('src', appOptions.statusBarOpts.backgroundImage); statusBar.appendChild(statusBarImage); } // Listen the screen rotate event statusBar.addEventListener('layout', () => { if (Native.screenIsVertical) { statusBar.setStyle('height', statusBarHeight); } else { statusBar.setStyle('height', 0); } }); return statusBar; } export { drawStatusBar, };