-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathjquery-plot-generator.js
More file actions
107 lines (103 loc) · 3.15 KB
/
jquery-plot-generator.js
File metadata and controls
107 lines (103 loc) · 3.15 KB
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/**
* Plot Generator (jQuery plugin)
* Version: 0.1
* Released: 2011-11-30
*
* Copyright (c) 2013 Creative Area
* Dual licensed under the MIT or GPL Version 2 licenses.
*
* Require jQuery
* http://jquery.com/
* Copyright 2011, John Resig
* Dual licensed under the MIT or GPL Version 2 licenses.
* http://jquery.org/license
*/
(function($){
$.fn.extend({
generatePlot: function(data, init) {
var container = this;
var plotData = data;
// generator
var plotGenerator = {
getRandomInt: function(min, max) {
return Math.floor(Math.random() * (max - min + 1) + min);
},
roll: function(data, delta) {
delta = delta || 0;
var max = data.length - 1 - delta;
return data[plotGenerator.getRandomInt(0, max)];
},
generateItem: function(item, level) {
var data = plotData[ item ];
var $div = $('<div class="plot-item">');
$div.append('<button class="generate-plot-item" data-item="'+item+'" data-level="'+level+'">Change</button> ');
if ( data.label ) {
$div.append('<strong>'+data.label+': </strong>');
}
var what = plotGenerator.roll(data.roll);
if ( $.isArray(what) ) {
switch (what[1]) {
case 'appear':
// roll twice: first is real, second is appearance
var display = plotGenerator.roll(data.roll, 1)+' ('+what[0]+' '+plotGenerator.roll(data.roll, 1)+')';
$div.append(display);
break;
case 'twice':
// (roll on this table twice, ignoring any further 20s)
var display = what[0]+': '+plotGenerator.roll(data.roll, 1)+' + '+plotGenerator.roll(data.roll, 1)+'';
$div.append(display);
break;
case 'subroll':
$div.append(what[0]);
$div.append(
$('<blockquote>').append( plotGenerator.generate(what[2], level+1) )
);
break;
default:
$div.append(what[0]);
break;
}
} else {
$div.append(what);
}
return $div;
},
generate: function(item, level) {
level = level || 2;
var data = plotData[ item ];
var $div = $('<div class="plot-item">');
if ( data.group != undefined ) {
if ( data.label ) {
$div.append('<h'+level+'><button class="generate-plot-group" data-item="'+item+'" data-level="'+level+'">Change</button> '+data.label+'</h'+level+'>');
}
$.each(data.group, function(index, val) {
$div.append(plotGenerator.generateItem(this, level));
});
} else {
$div.append(plotGenerator.generateItem(item, level));
}
return $div;
}
};
// events
this.on('click', '.generate-plot-group', function(e){
e.preventDefault();
var $this = $(this);
var data = $this.data();
$this.closest('.plot-item').html(plotGenerator.generate(data.item, data.level));
});
this.on('click', '.generate-plot-item', function(e){
e.preventDefault();
var $this = $(this);
var data = $this.data();
$this.closest('.plot-item').html(plotGenerator.generateItem(data.item, data.level));
});
// generate content
container.html('');
$.each(init, function(index, val) {
container.append(plotGenerator.generate(this));
});
return this;
}
})
})(jQuery);