Updated. Removed not needed excanvas.
This commit is contained in:
parent
711cbd9819
commit
187e8f10d9
5 changed files with 277 additions and 1453 deletions
|
@ -4,6 +4,21 @@ Source: http://benalman.com/code/test/js-linkify/
|
|||
Copyright: 2009 "Cowboy" Ben Alman
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
bootstrap
|
||||
Source: https://github.com/twbs/bootstrap
|
||||
Copyright: 2011-2015 Twitter, Inc.
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
bootstrap-datepicker.js
|
||||
Source: https://github.com/eternicode/bootstrap-datepicker
|
||||
Copyright: Stefan Petre, Andrew Rowls
|
||||
License: Apache License, Version 2.0
|
||||
-----------------------------------------------------------------------------
|
||||
bootstrap-timepicker.js
|
||||
Source: https://github.com/jdewit/bootstrap-timepicker
|
||||
Copyright: 2013 Joris de Wit
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
bootstrap-tokenfield.js
|
||||
Source: https://github.com/sliptree/bootstrap-tokenfield
|
||||
Copyright 2013-2014 Sliptree and other contributors
|
||||
|
@ -16,7 +31,7 @@ License: MIT license
|
|||
-----------------------------------------------------------------------------
|
||||
desktop-notify.js
|
||||
Source: https://github.com/ttsvetko/HTML5-Desktop-Notifications
|
||||
Copyright: Tsvetan Tsvetkov (tsekach@gmail.com)
|
||||
Copyright: Tsvetan Tsvetkov <tsekach@gmail.com>
|
||||
License: Apache License, Version 2.0
|
||||
-----------------------------------------------------------------------------
|
||||
email-addresses.js
|
||||
|
@ -29,20 +44,31 @@ Source: https://github.com/bgrins/ExpandingTextareas
|
|||
Copyright: Brian Grinstead (https://github.com/bgrins)
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
Exif.js
|
||||
Source: https://github.com/exif-js/exif-js
|
||||
Copyright: Jacob Seidelin, Roald de Vries
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
jquery.flot.js
|
||||
Source: https://github.com/dnschnur/flot
|
||||
Copyright: Ole Laursen, IOLA
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
highlight.pack.js
|
||||
Source: https://highlightjs.org
|
||||
Copyright: 2006 Ivan Sagalaev (https://github.com/isagalaev)
|
||||
License: BSD License
|
||||
-----------------------------------------------------------------------------
|
||||
jquery-scrollto.js
|
||||
Source:
|
||||
Copyright:
|
||||
License:
|
||||
Source: https://github.com/balupton/jquery-scrollto
|
||||
Copyright: Bevry Pty Ltd <us@bevry.me>
|
||||
Benjamin Lupton <b@lupton.cc>
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
jquery.fineuploader-3.0.js
|
||||
Source: http://github.com/Valums-File-Uploader/file-uploader
|
||||
Copyright: 2010 Andrew Valums ( andrew(at)valums.com )
|
||||
2012 Ray Nicholus ( fineuploader(at)garstasio.com )
|
||||
Copyright: 2010 Andrew Valums <andrew(at)valums.com>
|
||||
2012 Ray Nicholus <fineuploader(at)garstasio.com>
|
||||
License: MIT license, GNU GPL 2 or later, GNU LGPL 2 or later
|
||||
-----------------------------------------------------------------------------
|
||||
jquery.noty.js
|
||||
|
@ -52,8 +78,8 @@ License: MIT license
|
|||
-----------------------------------------------------------------------------
|
||||
jquery.sew.js
|
||||
Source: https://github.com/tactivos/jquery-sew
|
||||
Copyright: @leChanteaux (santiago at mural.ly)
|
||||
Mural.ly Dev Team (dev at mural.ly)
|
||||
Copyright: @leChanteaux <santiago at mural.ly>
|
||||
Mural.ly Dev Team <dev at mural.ly>
|
||||
License: dfyw
|
||||
-----------------------------------------------------------------------------
|
||||
marked.js
|
||||
|
@ -92,21 +118,6 @@ Source: https://github.com/julianshapiro/velocity
|
|||
Copyright: 2014 The jQuery Foundation
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
bootstrap
|
||||
Source: https://github.com/twbs/bootstrap
|
||||
Copyright: 2011-2015 Twitter, Inc.
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
bootstrap-datepicker.js
|
||||
Source: https://github.com/eternicode/bootstrap-datepicker
|
||||
Copyright: Stefan Petre, Andrew Rowls
|
||||
License: Apache License, Version 2.0
|
||||
-----------------------------------------------------------------------------
|
||||
bootstrap-timepicker.js
|
||||
Source: https://github.com/jdewit/bootstrap-timepicker
|
||||
Copyright: 2013 Joris de Wit
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
jquery.js
|
||||
Source: http://jquery.com/
|
||||
Copyright 2005, 2014 jQuery Foundation, Inc.
|
||||
|
@ -124,7 +135,7 @@ License: MIT license
|
|||
-----------------------------------------------------------------------------
|
||||
spine.js
|
||||
Source: http://spinejs.com
|
||||
Copyright: 2011 Alex MacCaw (info@eribium.org)
|
||||
Copyright: 2011 Alex MacCaw <info@eribium.org>
|
||||
License: MIT license
|
||||
-----------------------------------------------------------------------------
|
||||
rangy.js
|
||||
|
|
242
app/assets/javascripts/app/lib/base/seedrandom.js
Normal file
242
app/assets/javascripts/app/lib/base/seedrandom.js
Normal file
|
@ -0,0 +1,242 @@
|
|||
/*
|
||||
Copyright 2014 David Bau.
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining
|
||||
a copy of this software and associated documentation files (the
|
||||
"Software"), to deal in the Software without restriction, including
|
||||
without limitation the rights to use, copy, modify, merge, publish,
|
||||
distribute, sublicense, and/or sell copies of the Software, and to
|
||||
permit persons to whom the Software is furnished to do so, subject to
|
||||
the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be
|
||||
included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
*/
|
||||
|
||||
(function (pool, math) {
|
||||
//
|
||||
// The following constants are related to IEEE 754 limits.
|
||||
//
|
||||
var global = this,
|
||||
width = 256, // each RC4 output is 0 <= x < 256
|
||||
chunks = 6, // at least six RC4 outputs for each double
|
||||
digits = 52, // there are 52 significant digits in a double
|
||||
rngname = 'random', // rngname: name for Math.random and Math.seedrandom
|
||||
startdenom = math.pow(width, chunks),
|
||||
significance = math.pow(2, digits),
|
||||
overflow = significance * 2,
|
||||
mask = width - 1,
|
||||
nodecrypto; // node.js crypto module, initialized at the bottom.
|
||||
|
||||
//
|
||||
// seedrandom()
|
||||
// This is the seedrandom function described above.
|
||||
//
|
||||
function seedrandom(seed, options, callback) {
|
||||
var key = [];
|
||||
options = (options == true) ? { entropy: true } : (options || {});
|
||||
|
||||
// Flatten the seed string or build one from local entropy if needed.
|
||||
var shortseed = mixkey(flatten(
|
||||
options.entropy ? [seed, tostring(pool)] :
|
||||
(seed == null) ? autoseed() : seed, 3), key);
|
||||
|
||||
// Use the seed to initialize an ARC4 generator.
|
||||
var arc4 = new ARC4(key);
|
||||
|
||||
// This function returns a random double in [0, 1) that contains
|
||||
// randomness in every bit of the mantissa of the IEEE 754 value.
|
||||
var prng = function() {
|
||||
var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48
|
||||
d = startdenom, // and denominator d = 2 ^ 48.
|
||||
x = 0; // and no 'extra last byte'.
|
||||
while (n < significance) { // Fill up all significant digits by
|
||||
n = (n + x) * width; // shifting numerator and
|
||||
d *= width; // denominator and generating a
|
||||
x = arc4.g(1); // new least-significant-byte.
|
||||
}
|
||||
while (n >= overflow) { // To avoid rounding up, before adding
|
||||
n /= 2; // last byte, shift everything
|
||||
d /= 2; // right using integer math until
|
||||
x >>>= 1; // we have exactly the desired bits.
|
||||
}
|
||||
return (n + x) / d; // Form the number within [0, 1).
|
||||
};
|
||||
|
||||
prng.int32 = function() { return arc4.g(4) | 0; }
|
||||
prng.quick = function() { return arc4.g(4) / 0x100000000; }
|
||||
prng.double = prng;
|
||||
|
||||
// Mix the randomness into accumulated entropy.
|
||||
mixkey(tostring(arc4.S), pool);
|
||||
|
||||
// Calling convention: what to return as a function of prng, seed, is_math.
|
||||
return (options.pass || callback ||
|
||||
function(prng, seed, is_math_call, state) {
|
||||
if (state) {
|
||||
// Load the arc4 state from the given state if it has an S array.
|
||||
if (state.S) { copy(state, arc4); }
|
||||
// Only provide the .state method if requested via options.state.
|
||||
prng.state = function() { return copy(arc4, {}); }
|
||||
}
|
||||
|
||||
// If called as a method of Math (Math.seedrandom()), mutate
|
||||
// Math.random because that is how seedrandom.js has worked since v1.0.
|
||||
if (is_math_call) { math[rngname] = prng; return seed; }
|
||||
|
||||
// Otherwise, it is a newer calling convention, so return the
|
||||
// prng directly.
|
||||
else return prng;
|
||||
})(
|
||||
prng,
|
||||
shortseed,
|
||||
'global' in options ? options.global : (this == math),
|
||||
options.state);
|
||||
}
|
||||
math['seed' + rngname] = seedrandom;
|
||||
|
||||
//
|
||||
// ARC4
|
||||
//
|
||||
// An ARC4 implementation. The constructor takes a key in the form of
|
||||
// an array of at most (width) integers that should be 0 <= x < (width).
|
||||
//
|
||||
// The g(count) method returns a pseudorandom integer that concatenates
|
||||
// the next (count) outputs from ARC4. Its return value is a number x
|
||||
// that is in the range 0 <= x < (width ^ count).
|
||||
//
|
||||
function ARC4(key) {
|
||||
var t, keylen = key.length,
|
||||
me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];
|
||||
|
||||
// The empty key [] is treated as [0].
|
||||
if (!keylen) { key = [keylen++]; }
|
||||
|
||||
// Set up S using the standard key scheduling algorithm.
|
||||
while (i < width) {
|
||||
s[i] = i++;
|
||||
}
|
||||
for (i = 0; i < width; i++) {
|
||||
s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];
|
||||
s[j] = t;
|
||||
}
|
||||
|
||||
// The "g" method returns the next (count) outputs as one number.
|
||||
(me.g = function(count) {
|
||||
// Using instance members instead of closure state nearly doubles speed.
|
||||
var t, r = 0,
|
||||
i = me.i, j = me.j, s = me.S;
|
||||
while (count--) {
|
||||
t = s[i = mask & (i + 1)];
|
||||
r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];
|
||||
}
|
||||
me.i = i; me.j = j;
|
||||
return r;
|
||||
// For robust unpredictability, the function call below automatically
|
||||
// discards an initial batch of values. This is called RC4-drop[256].
|
||||
// See http://google.com/search?q=rsa+fluhrer+response&btnI
|
||||
})(width);
|
||||
}
|
||||
|
||||
//
|
||||
// copy()
|
||||
// Copies internal state of ARC4 to or from a plain object.
|
||||
//
|
||||
function copy(f, t) {
|
||||
t.i = f.i;
|
||||
t.j = f.j;
|
||||
t.S = f.S.slice();
|
||||
return t;
|
||||
};
|
||||
|
||||
//
|
||||
// flatten()
|
||||
// Converts an object tree to nested arrays of strings.
|
||||
//
|
||||
function flatten(obj, depth) {
|
||||
var result = [], typ = (typeof obj), prop;
|
||||
if (depth && typ == 'object') {
|
||||
for (prop in obj) {
|
||||
try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}
|
||||
}
|
||||
}
|
||||
return (result.length ? result : typ == 'string' ? obj : obj + '\0');
|
||||
}
|
||||
|
||||
//
|
||||
// mixkey()
|
||||
// Mixes a string seed into a key that is an array of integers, and
|
||||
// returns a shortened string seed that is equivalent to the result key.
|
||||
//
|
||||
function mixkey(seed, key) {
|
||||
var stringseed = seed + '', smear, j = 0;
|
||||
while (j < stringseed.length) {
|
||||
key[mask & j] =
|
||||
mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));
|
||||
}
|
||||
return tostring(key);
|
||||
}
|
||||
|
||||
//
|
||||
// autoseed()
|
||||
// Returns an object for autoseeding, using window.crypto and Node crypto
|
||||
// module if available.
|
||||
//
|
||||
function autoseed() {
|
||||
try {
|
||||
if (nodecrypto) { return tostring(nodecrypto.randomBytes(width)); }
|
||||
var out = new Uint8Array(width);
|
||||
(global.crypto || global.msCrypto).getRandomValues(out);
|
||||
return tostring(out);
|
||||
} catch (e) {
|
||||
var browser = global.navigator,
|
||||
plugins = browser && browser.plugins;
|
||||
return [+new Date, global, plugins, global.screen, tostring(pool)];
|
||||
}
|
||||
}
|
||||
|
||||
//
|
||||
// tostring()
|
||||
// Converts an array of charcodes to a string
|
||||
//
|
||||
function tostring(a) {
|
||||
return String.fromCharCode.apply(0, a);
|
||||
}
|
||||
|
||||
//
|
||||
// When seedrandom.js is loaded, we immediately mix a few bits
|
||||
// from the built-in RNG into the entropy pool. Because we do
|
||||
// not want to interfere with deterministic PRNG state later,
|
||||
// seedrandom will not call math.random on its own again after
|
||||
// initialization.
|
||||
//
|
||||
mixkey(math.random(), pool);
|
||||
|
||||
//
|
||||
// Nodejs and AMD support: export the implementation as a module using
|
||||
// either convention.
|
||||
//
|
||||
if ((typeof module) == 'object' && module.exports) {
|
||||
module.exports = seedrandom;
|
||||
// When in node.js, try using crypto package for autoseeding.
|
||||
try {
|
||||
nodecrypto = require('crypto');
|
||||
} catch (ex) {}
|
||||
} else if ((typeof define) == 'function' && define.amd) {
|
||||
define(function() { return seedrandom; });
|
||||
}
|
||||
|
||||
// End anonymous scope, and pass initial values.
|
||||
})(
|
||||
[], // pool: entropy pool starts empty
|
||||
Math // math: package containing random, pow, and seedrandom
|
||||
);
|
|
@ -1 +0,0 @@
|
|||
!function(a,b,c,d,e,f,g,h,i){function j(a){var b,c=a.length,e=this,f=0,g=e.i=e.j=0,h=e.S=[];for(c||(a=[c++]);d>f;)h[f]=f++;for(f=0;d>f;f++)h[f]=h[g=r&g+a[f%c]+(b=h[f])],h[g]=b;(e.g=function(a){for(var b,c=0,f=e.i,g=e.j,h=e.S;a--;)b=h[f=r&f+1],c=c*d+h[r&(h[f]=h[g=r&g+b])+(h[g]=b)];return e.i=f,e.j=g,c})(d)}function k(a,b){var c,d=[],e=typeof a;if(b&&"object"==e)for(c in a)try{d.push(k(a[c],b-1))}catch(f){}return d.length?d:"string"==e?a:a+"\0"}function l(a,b){for(var c,d=a+"",e=0;e<d.length;)b[r&e]=r&(c^=19*b[r&e])+d.charCodeAt(e++);return n(b)}function m(c){try{return a.crypto.getRandomValues(c=new Uint8Array(d)),n(c)}catch(e){return[+new Date,a,(c=a.navigator)&&c.plugins,a.screen,n(b)]}}function n(a){return String.fromCharCode.apply(0,a)}var o=c.pow(d,e),p=c.pow(2,f),q=2*p,r=d-1,s=c["seed"+i]=function(a,f,g){var h=[];f=1==f?{entropy:!0}:f||{};var r=l(k(f.entropy?[a,n(b)]:null==a?m():a,3),h),s=new j(h);return l(n(s.S),b),(f.pass||g||function(a,b,d){return d?(c[i]=a,b):a})(function(){for(var a=s.g(e),b=o,c=0;p>a;)a=(a+c)*d,b*=d,c=s.g(1);for(;a>=q;)a/=2,b/=2,c>>>=1;return(a+c)/b},r,"global"in f?f.global:this==c)};l(c[i](),b),g&&g.exports?g.exports=s:h&&h.amd&&h(function(){return s})}(this,[],Math,256,6,52,"object"==typeof module&&module,"function"==typeof define&&define,"random");
|
File diff suppressed because it is too large
Load diff
File diff suppressed because one or more lines are too long
Loading…
Reference in a new issue