Path: blob/main/projects/missiles/src/banner.js
1835 views
MG.banner = (function () {1var SHOW_TIME = 1.1;2var HIDE_TIME = 0.8;34var BannerState = {5HIDDEN: 'hidden',6VISIBLE: 'visible',7MESSAGE_QUEUED: 'message-queued'8};910var mTitle = '';11var mText = '';1213var mRootNode;14var mTitleNode;15var mTextNode;16var mVisibility;17var mState;1819return {20init: function () {21mVisibility = 0.0;22mState = BannerState.HIDDEN;2324mRootNode = document.getElementById('banner');2526var titleBoxNode = document.getElementById('banner-title');27mTitleNode = document.createTextNode('');28titleBoxNode.appendChild(mTitleNode);2930var textBoxNode = document.getElementById('banner-text');31mTextNode = document.createTextNode('');32textBoxNode.appendChild(mTextNode);3334mRootNode.setAttribute('visibility', 'visible');3536},3738update: function (dt) {39switch (mState) {40case BannerState.VISIBLE:41mVisibility += dt/SHOW_TIME;42break;43case BannerState.MESSAGE_QUEUED:44if (mVisibility === 0) {45mState = BannerState.VISIBLE;4647mTitleNode.data = mTitle;48mTextNode.data = mText;49}50// FALLTHROUGH51case BannerState.HIDDEN:52mVisibility -= dt/HIDE_TIME;53break;54}55mVisibility = Math.max(0,Math.min(1, mVisibility));56},5758updateDOM: function () {59if (mVisibility === 0) {60mRootNode.setAttribute('visibility', 'hidden');61} else {62mRootNode.setAttribute('width', (30 + 80*(0.5 + 0.5*Math.cos(Math.PI*mVisibility))) + '%');63mRootNode.setAttribute('visibility', 'visible');64}65},6667hide: function () {68mState = BannerState.HIDDEN;69},7071show: function (newTitle, newText) {7273mTitle = String(newTitle);74mText = String(newText);7576mState = BannerState.MESSAGE_QUEUED;77},7879isFullyVisible: function () {80return mVisibility === 1;81}8283};84}());858687