156 lines
4.2 KiB
JavaScript
156 lines
4.2 KiB
JavaScript
|
/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
||
|
/* Copyright 2012 Mozilla Foundation
|
||
|
*
|
||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
* you may not use this file except in compliance with the License.
|
||
|
* You may obtain a copy of the License at
|
||
|
*
|
||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||
|
*
|
||
|
* Unless required by applicable law or agreed to in writing, software
|
||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
* See the License for the specific language governing permissions and
|
||
|
* limitations under the License.
|
||
|
*/
|
||
|
|
||
|
'use strict';
|
||
|
|
||
|
// optimised CSS custom property getter/setter
|
||
|
var CustomStyle = (function CustomStyleClosure() {
|
||
|
|
||
|
// As noted on: http://www.zachstronaut.com/posts/2009/02/17/
|
||
|
// animate-css-transforms-firefox-webkit.html
|
||
|
// in some versions of IE9 it is critical that ms appear in this list
|
||
|
// before Moz
|
||
|
var prefixes = ['ms', 'Moz', 'Webkit', 'O'];
|
||
|
var _cache = { };
|
||
|
|
||
|
function CustomStyle() {
|
||
|
}
|
||
|
|
||
|
CustomStyle.getProp = function get(propName, element) {
|
||
|
// check cache only when no element is given
|
||
|
if (arguments.length == 1 && typeof _cache[propName] == 'string') {
|
||
|
return _cache[propName];
|
||
|
}
|
||
|
|
||
|
element = element || document.documentElement;
|
||
|
var style = element.style, prefixed, uPropName;
|
||
|
|
||
|
// test standard property first
|
||
|
if (typeof style[propName] == 'string') {
|
||
|
return (_cache[propName] = propName);
|
||
|
}
|
||
|
|
||
|
// capitalize
|
||
|
uPropName = propName.charAt(0).toUpperCase() + propName.slice(1);
|
||
|
|
||
|
// test vendor specific properties
|
||
|
for (var i = 0, l = prefixes.length; i < l; i++) {
|
||
|
prefixed = prefixes[i] + uPropName;
|
||
|
if (typeof style[prefixed] == 'string') {
|
||
|
return (_cache[propName] = prefixed);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
//if all fails then set to undefined
|
||
|
return (_cache[propName] = 'undefined');
|
||
|
};
|
||
|
|
||
|
CustomStyle.setProp = function set(propName, element, str) {
|
||
|
var prop = this.getProp(propName);
|
||
|
if (prop != 'undefined')
|
||
|
element.style[prop] = str;
|
||
|
};
|
||
|
|
||
|
return CustomStyle;
|
||
|
})();
|
||
|
|
||
|
function getFileName(url) {
|
||
|
var anchor = url.indexOf('#');
|
||
|
var query = url.indexOf('?');
|
||
|
var end = Math.min(
|
||
|
anchor > 0 ? anchor : url.length,
|
||
|
query > 0 ? query : url.length);
|
||
|
return url.substring(url.lastIndexOf('/', end) + 1, end);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns scale factor for the canvas. It makes sense for the HiDPI displays.
|
||
|
* @return {Object} The object with horizontal (sx) and vertical (sy)
|
||
|
scales. The scaled property is set to false if scaling is
|
||
|
not required, true otherwise.
|
||
|
*/
|
||
|
function getOutputScale() {
|
||
|
var pixelRatio = 'devicePixelRatio' in window ? window.devicePixelRatio : 1;
|
||
|
return {
|
||
|
sx: pixelRatio,
|
||
|
sy: pixelRatio,
|
||
|
scaled: pixelRatio != 1
|
||
|
};
|
||
|
}
|
||
|
|
||
|
|
||
|
var ProgressBar = (function ProgressBarClosure() {
|
||
|
|
||
|
function clamp(v, min, max) {
|
||
|
return Math.min(Math.max(v, min), max);
|
||
|
}
|
||
|
|
||
|
function ProgressBar(id, opts) {
|
||
|
|
||
|
// Fetch the sub-elements for later
|
||
|
this.div = document.querySelector(id + ' .progress');
|
||
|
|
||
|
// Get options, with sensible defaults
|
||
|
this.height = opts.height || 100;
|
||
|
this.width = opts.width || 100;
|
||
|
this.units = opts.units || '%';
|
||
|
|
||
|
// Initialize heights
|
||
|
this.div.style.height = this.height + this.units;
|
||
|
this.percent = 0;
|
||
|
}
|
||
|
|
||
|
ProgressBar.prototype = {
|
||
|
|
||
|
updateBar: function ProgressBar_updateBar() {
|
||
|
if (this._indeterminate) {
|
||
|
this.div.classList.add('indeterminate');
|
||
|
this.div.style.width = this.width + this.units;
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
this.div.classList.remove('indeterminate');
|
||
|
var progressSize = this.width * this._percent / 100;
|
||
|
this.div.style.width = progressSize + this.units;
|
||
|
},
|
||
|
|
||
|
get percent() {
|
||
|
return this._percent;
|
||
|
},
|
||
|
|
||
|
set percent(val) {
|
||
|
this._indeterminate = isNaN(val);
|
||
|
this._percent = clamp(val, 0, 100);
|
||
|
this.updateBar();
|
||
|
}
|
||
|
};
|
||
|
|
||
|
return ProgressBar;
|
||
|
})();
|
||
|
|
||
|
var Cache = function cacheCache(size) {
|
||
|
var data = [];
|
||
|
this.push = function cachePush(view) {
|
||
|
var i = data.indexOf(view);
|
||
|
if (i >= 0)
|
||
|
data.splice(i);
|
||
|
data.push(view);
|
||
|
if (data.length > size)
|
||
|
data.shift().destroy();
|
||
|
};
|
||
|
};
|
||
|
|