summaryrefslogtreecommitdiffstats
path: root/debian/missing-sources/epoch/src/adapters
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--debian/missing-sources/epoch/src/adapters.coffee13
-rw-r--r--debian/missing-sources/epoch/src/adapters/MooTools.coffee19
-rw-r--r--debian/missing-sources/epoch/src/adapters/jQuery.coffee18
-rw-r--r--debian/missing-sources/epoch/src/adapters/zepto.coffee27
4 files changed, 77 insertions, 0 deletions
diff --git a/debian/missing-sources/epoch/src/adapters.coffee b/debian/missing-sources/epoch/src/adapters.coffee
new file mode 100644
index 0000000..e378af5
--- /dev/null
+++ b/debian/missing-sources/epoch/src/adapters.coffee
@@ -0,0 +1,13 @@
+# Maps short string names to classes for library adapters.
+Epoch._typeMap =
+ 'area': Epoch.Chart.Area
+ 'bar': Epoch.Chart.Bar
+ 'line': Epoch.Chart.Line
+ 'pie': Epoch.Chart.Pie
+ 'scatter': Epoch.Chart.Scatter
+ 'histogram': Epoch.Chart.Histogram
+ 'time.area': Epoch.Time.Area
+ 'time.bar': Epoch.Time.Bar
+ 'time.line': Epoch.Time.Line
+ 'time.gauge': Epoch.Time.Gauge
+ 'time.heatmap': Epoch.Time.Heatmap
diff --git a/debian/missing-sources/epoch/src/adapters/MooTools.coffee b/debian/missing-sources/epoch/src/adapters/MooTools.coffee
new file mode 100644
index 0000000..8b3d544
--- /dev/null
+++ b/debian/missing-sources/epoch/src/adapters/MooTools.coffee
@@ -0,0 +1,19 @@
+MooToolsModule = ->
+ # Data key to use for storing a reference to the chart instance on an element.
+ DATA_NAME = 'epoch-chart'
+
+ # Adds an Epoch chart of the given type to the referenced element.
+ # @param [Object] options Options for the chart.
+ # @option options [String] type The type of chart to append to the referenced element.
+ # @return [Object] The chart instance that was associated with the containing element.
+ Element.implement 'epoch', (options) ->
+ self = $$(this)
+ unless (chart = self.retrieve(DATA_NAME)[0])?
+ options.el = this
+ klass = Epoch._typeMap[options.type]
+ unless klass?
+ Epoch.exception "Unknown chart type '#{options.type}'"
+ self.store DATA_NAME, (chart = new klass options)
+ return chart
+
+MooToolsModule() if window.MooTools?
diff --git a/debian/missing-sources/epoch/src/adapters/jQuery.coffee b/debian/missing-sources/epoch/src/adapters/jQuery.coffee
new file mode 100644
index 0000000..e115bad
--- /dev/null
+++ b/debian/missing-sources/epoch/src/adapters/jQuery.coffee
@@ -0,0 +1,18 @@
+jQueryModule = ($) ->
+ # Data key to use for storing a reference to the chart instance on an element.
+ DATA_NAME = 'epoch-chart'
+
+ # Adds an Epoch chart of the given type to the referenced element.
+ # @param [Object] options Options for the chart.
+ # @option options [String] type The type of chart to append to the referenced element.
+ # @return [Object] The chart instance that was associated with the containing element.
+ $.fn.epoch = (options) ->
+ options.el = @get(0)
+ unless (chart = @data(DATA_NAME))?
+ klass = Epoch._typeMap[options.type]
+ unless klass?
+ Epoch.exception "Unknown chart type '#{options.type}'"
+ @data DATA_NAME, (chart = new klass options)
+ return chart
+
+jQueryModule(jQuery) if window.jQuery?
diff --git a/debian/missing-sources/epoch/src/adapters/zepto.coffee b/debian/missing-sources/epoch/src/adapters/zepto.coffee
new file mode 100644
index 0000000..81153dc
--- /dev/null
+++ b/debian/missing-sources/epoch/src/adapters/zepto.coffee
@@ -0,0 +1,27 @@
+zeptoModule = ($) ->
+ # For mapping charts to selected elements
+ DATA_NAME = 'epoch-chart'
+ chartMap = {}
+ chartId = 0
+ next_cid = -> "#{DATA_NAME}-#{++chartId}"
+
+ # Adds an Epoch chart of the given type to the referenced element.
+ # @param [Object] options Options for the chart.
+ # @option options [String] type The type of chart to append to the referenced element.
+ # @return [Object] The chart instance that was associated with the containing element.
+ $.extend $.fn,
+ epoch: (options) ->
+ return chartMap[cid] if (cid = @data(DATA_NAME))?
+ options.el = @get(0)
+
+ klass = Epoch._typeMap[options.type]
+ unless klass?
+ Epoch.exception "Unknown chart type '#{options.type}'"
+
+ @data DATA_NAME, (cid = next_cid())
+ chart = new klass options
+ chartMap[cid] = chart
+
+ return chart
+
+zeptoModule(Zepto) if window.Zepto?