reveal-ck 0.1.2 → 0.1.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (80) hide show
  1. checksums.yaml +8 -8
  2. data/README.md +13 -0
  3. data/bin/reveal-ck +23 -8
  4. data/lib/reveal-ck.rb +6 -0
  5. data/lib/reveal-ck/build_task.rb +14 -0
  6. data/lib/reveal-ck/builder.rb +21 -0
  7. data/lib/reveal-ck/config.rb +43 -0
  8. data/lib/reveal-ck/file_slicer.rb +19 -17
  9. data/lib/reveal-ck/file_splicer.rb +30 -28
  10. data/lib/reveal-ck/file_string_replacer.rb +17 -0
  11. data/lib/reveal-ck/haml_processor.rb +17 -15
  12. data/lib/reveal-ck/presentation_builder.rb +69 -0
  13. data/lib/reveal-ck/slide_builder.rb +66 -0
  14. data/lib/reveal-ck/version.rb +1 -1
  15. data/rakelib/cucumber.rake +14 -1
  16. data/reveal.js/Gruntfile.js +132 -0
  17. data/reveal.js/LICENSE +1 -1
  18. data/reveal.js/README.md +362 -50
  19. data/reveal.js/css/print/paper.css +14 -14
  20. data/reveal.js/css/print/pdf.css +60 -30
  21. data/reveal.js/css/reveal.css +444 -149
  22. data/reveal.js/css/reveal.min.css +2 -2
  23. data/reveal.js/css/theme/README.md +8 -10
  24. data/reveal.js/css/theme/beige.css +24 -45
  25. data/reveal.js/css/theme/default.css +24 -45
  26. data/reveal.js/css/theme/moon.css +142 -0
  27. data/reveal.js/css/theme/night.css +24 -44
  28. data/reveal.js/css/theme/serif.css +27 -45
  29. data/reveal.js/css/theme/simple.css +25 -45
  30. data/reveal.js/css/theme/sky.css +26 -43
  31. data/reveal.js/css/theme/solarized.css +142 -0
  32. data/reveal.js/css/theme/source/beige.scss +2 -2
  33. data/reveal.js/css/theme/source/default.scss +2 -2
  34. data/reveal.js/css/theme/source/moon.scss +68 -0
  35. data/reveal.js/css/theme/source/night.scss +4 -4
  36. data/reveal.js/css/theme/source/serif.scss +8 -6
  37. data/reveal.js/css/theme/source/simple.scss +5 -5
  38. data/reveal.js/css/theme/source/sky.scss +9 -4
  39. data/reveal.js/css/theme/source/solarized.scss +74 -0
  40. data/reveal.js/css/theme/template/settings.scss +2 -2
  41. data/reveal.js/examples/assets/image1.png +0 -0
  42. data/reveal.js/examples/assets/image2.png +0 -0
  43. data/reveal.js/examples/barebones.html +42 -0
  44. data/reveal.js/examples/embedded-media.html +49 -0
  45. data/reveal.js/examples/slide-backgrounds.html +101 -0
  46. data/reveal.js/index.html +63 -56
  47. data/reveal.js/js/reveal.js +997 -216
  48. data/reveal.js/js/reveal.min.js +3 -3
  49. data/reveal.js/package.json +43 -29
  50. data/reveal.js/plugin/highlight/highlight.js +28 -6
  51. data/reveal.js/plugin/markdown/example.html +97 -0
  52. data/reveal.js/plugin/markdown/example.md +29 -0
  53. data/reveal.js/plugin/markdown/markdown.js +164 -11
  54. data/reveal.js/plugin/markdown/marked.js +37 -0
  55. data/reveal.js/plugin/multiplex/client.js +13 -0
  56. data/reveal.js/plugin/multiplex/index.js +56 -0
  57. data/reveal.js/plugin/multiplex/master.js +50 -0
  58. data/reveal.js/plugin/notes-server/index.js +1 -0
  59. data/reveal.js/plugin/notes-server/notes.html +8 -5
  60. data/reveal.js/plugin/notes/notes.html +133 -44
  61. data/reveal.js/plugin/notes/notes.js +3 -1
  62. data/reveal.js/plugin/print-pdf/print-pdf.js +8 -3
  63. data/reveal.js/plugin/remotes/remotes.js +13 -4
  64. data/reveal.js/plugin/search/search.js +196 -0
  65. data/reveal.js/plugin/zoom-js/zoom.js +26 -21
  66. data/spec/data/config/config.toml +6 -0
  67. data/spec/data/string_replacer/after_replace +4 -0
  68. data/spec/data/string_replacer/before_replace +4 -0
  69. data/spec/lib/reveal-ck/config_spec.rb +50 -0
  70. data/spec/lib/reveal-ck/file_slicer_spec.rb +29 -27
  71. data/spec/lib/reveal-ck/file_splicer_spec.rb +28 -26
  72. data/spec/lib/reveal-ck/file_string_replacer_spec.rb +32 -0
  73. data/spec/lib/reveal-ck/haml_processor_spec.rb +28 -26
  74. metadata +82 -27
  75. data/rakelib/presentation.rake +0 -41
  76. data/rakelib/reveal.rake +0 -15
  77. data/reveal.js/css/shaders/tile-flip.fs +0 -64
  78. data/reveal.js/css/shaders/tile-flip.vs +0 -141
  79. data/reveal.js/grunt.js +0 -84
  80. data/reveal.js/plugin/markdown/showdown.js +0 -62
@@ -5,7 +5,9 @@
5
5
  var RevealNotes = (function() {
6
6
 
7
7
  function openNotes() {
8
- var notesPopup = window.open( 'plugin/notes/notes.html', 'reveal.js - Notes', 'width=1120,height=850' );
8
+ var jsFileLocation = document.querySelector('script[src$="notes.js"]').src; // this js file path
9
+ jsFileLocation = jsFileLocation.replace(/notes\.js(\?.*)?$/, ''); // the js folder path
10
+ var notesPopup = window.open( jsFileLocation + 'notes.html', 'reveal.js - Notes', 'width=1120,height=850' );
9
11
 
10
12
  // Fires when slide is changed
11
13
  Reveal.addEventListener( 'slidechanged', function( event ) {
@@ -11,8 +11,13 @@
11
11
  var page = new WebPage();
12
12
  var system = require( 'system' );
13
13
 
14
+ page.viewportSize = {
15
+ width: 1024,
16
+ height: 768
17
+ };
18
+
14
19
  page.paperSize = {
15
- format: 'A4',
20
+ format: 'letter',
16
21
  orientation: 'landscape',
17
22
  margin: {
18
23
  left: '0',
@@ -21,7 +26,6 @@ page.paperSize = {
21
26
  bottom: '0'
22
27
  }
23
28
  };
24
- page.zoomFactor = 1.5;
25
29
 
26
30
  var revealFile = system.args[1] || 'index.html?print-pdf';
27
31
  var slideFile = system.args[2] || 'slides.pdf';
@@ -36,4 +40,5 @@ page.open( revealFile, function( status ) {
36
40
  console.log( 'Printed succesfully' );
37
41
  page.render( slideFile );
38
42
  phantom.exit();
39
- } );
43
+ } );
44
+
@@ -13,16 +13,25 @@
13
13
  return ('ontouchstart' in window) || window.DocumentTouch && document instanceof DocumentTouch;
14
14
  })();
15
15
 
16
- if(!hasTouch){
16
+ /**
17
+ * Detects if notes are enable and the current page is opened inside an /iframe
18
+ * this prevents loading Remotes.io several times
19
+ */
20
+ var remotesAndIsNotes = (function(){
21
+ return !(window.RevealNotes && self == top);
22
+ })();
23
+
24
+ if(!hasTouch && !remotesAndIsNotes){
17
25
  head.ready( 'remotes.ne.min.js', function() {
18
26
  new Remotes("preview")
19
27
  .on("swipe-left", function(e){ Reveal.right(); })
20
28
  .on("swipe-right", function(e){ Reveal.left(); })
21
29
  .on("swipe-up", function(e){ Reveal.down(); })
22
30
  .on("swipe-down", function(e){ Reveal.up(); })
23
- .on("tap", function(e){
24
- Reveal.toggleOverview();
25
- });
31
+ .on("tap", function(e){ Reveal.next(); })
32
+ .on("zoom-out", function(e){ Reveal.toggleOverview(true); })
33
+ .on("zoom-in", function(e){ Reveal.toggleOverview(false); })
34
+ ;
26
35
  } );
27
36
 
28
37
  head.js('https://raw.github.com/Remotes/Remotes/master/dist/remotes.ne.min.js');
@@ -0,0 +1,196 @@
1
+ /*
2
+ * Handles finding a text string anywhere in the slides and showing the next occurrence to the user
3
+ * by navigatating to that slide and highlighting it.
4
+ *
5
+ * By Jon Snyder <snyder.jon@gmail.com>, February 2013
6
+ */
7
+
8
+ var RevealSearch = (function() {
9
+
10
+ var matchedSlides;
11
+ var currentMatchedIndex;
12
+ var searchboxDirty;
13
+ var myHilitor;
14
+
15
+ // Original JavaScript code by Chirp Internet: www.chirp.com.au
16
+ // Please acknowledge use of this code by including this header.
17
+ // 2/2013 jon: modified regex to display any match, not restricted to word boundaries.
18
+
19
+ function Hilitor(id, tag)
20
+ {
21
+
22
+ var targetNode = document.getElementById(id) || document.body;
23
+ var hiliteTag = tag || "EM";
24
+ var skipTags = new RegExp("^(?:" + hiliteTag + "|SCRIPT|FORM|SPAN)$");
25
+ var colors = ["#ff6", "#a0ffff", "#9f9", "#f99", "#f6f"];
26
+ var wordColor = [];
27
+ var colorIdx = 0;
28
+ var matchRegex = "";
29
+ var matchingSlides = [];
30
+
31
+ this.setRegex = function(input)
32
+ {
33
+ input = input.replace(/^[^\w]+|[^\w]+$/g, "").replace(/[^\w'-]+/g, "|");
34
+ matchRegex = new RegExp("(" + input + ")","i");
35
+ }
36
+
37
+ this.getRegex = function()
38
+ {
39
+ return matchRegex.toString().replace(/^\/\\b\(|\)\\b\/i$/g, "").replace(/\|/g, " ");
40
+ }
41
+
42
+ // recursively apply word highlighting
43
+ this.hiliteWords = function(node)
44
+ {
45
+ if(node == undefined || !node) return;
46
+ if(!matchRegex) return;
47
+ if(skipTags.test(node.nodeName)) return;
48
+
49
+ if(node.hasChildNodes()) {
50
+ for(var i=0; i < node.childNodes.length; i++)
51
+ this.hiliteWords(node.childNodes[i]);
52
+ }
53
+ if(node.nodeType == 3) { // NODE_TEXT
54
+ if((nv = node.nodeValue) && (regs = matchRegex.exec(nv))) {
55
+ //find the slide's section element and save it in our list of matching slides
56
+ var secnode = node.parentNode;
57
+ while (secnode.nodeName != 'SECTION') {
58
+ secnode = secnode.parentNode;
59
+ }
60
+
61
+ var slideIndex = Reveal.getIndices(secnode);
62
+ var slidelen = matchingSlides.length;
63
+ var alreadyAdded = false;
64
+ for (var i=0; i < slidelen; i++) {
65
+ if ( (matchingSlides[i].h === slideIndex.h) && (matchingSlides[i].v === slideIndex.v) ) {
66
+ alreadyAdded = true;
67
+ }
68
+ }
69
+ if (! alreadyAdded) {
70
+ matchingSlides.push(slideIndex);
71
+ }
72
+
73
+ if(!wordColor[regs[0].toLowerCase()]) {
74
+ wordColor[regs[0].toLowerCase()] = colors[colorIdx++ % colors.length];
75
+ }
76
+
77
+ var match = document.createElement(hiliteTag);
78
+ match.appendChild(document.createTextNode(regs[0]));
79
+ match.style.backgroundColor = wordColor[regs[0].toLowerCase()];
80
+ match.style.fontStyle = "inherit";
81
+ match.style.color = "#000";
82
+
83
+ var after = node.splitText(regs.index);
84
+ after.nodeValue = after.nodeValue.substring(regs[0].length);
85
+ node.parentNode.insertBefore(match, after);
86
+ }
87
+ }
88
+ };
89
+
90
+ // remove highlighting
91
+ this.remove = function()
92
+ {
93
+ var arr = document.getElementsByTagName(hiliteTag);
94
+ while(arr.length && (el = arr[0])) {
95
+ el.parentNode.replaceChild(el.firstChild, el);
96
+ }
97
+ };
98
+
99
+ // start highlighting at target node
100
+ this.apply = function(input)
101
+ {
102
+ if(input == undefined || !input) return;
103
+ this.remove();
104
+ this.setRegex(input);
105
+ this.hiliteWords(targetNode);
106
+ return matchingSlides;
107
+ };
108
+
109
+ }
110
+
111
+ function openSearch() {
112
+ //ensure the search term input dialog is visible and has focus:
113
+ var inputbox = document.getElementById("searchinput");
114
+ inputbox.style.display = "inline";
115
+ inputbox.focus();
116
+ inputbox.select();
117
+ }
118
+
119
+ function toggleSearch() {
120
+ var inputbox = document.getElementById("searchinput");
121
+ if (inputbox.style.display !== "inline") {
122
+ openSearch();
123
+ }
124
+ else {
125
+ inputbox.style.display = "none";
126
+ myHilitor.remove();
127
+ }
128
+ }
129
+
130
+ function doSearch() {
131
+ //if there's been a change in the search term, perform a new search:
132
+ if (searchboxDirty) {
133
+ var searchstring = document.getElementById("searchinput").value;
134
+
135
+ //find the keyword amongst the slides
136
+ myHilitor = new Hilitor("slidecontent");
137
+ matchedSlides = myHilitor.apply(searchstring);
138
+ currentMatchedIndex = 0;
139
+ }
140
+
141
+ //navigate to the next slide that has the keyword, wrapping to the first if necessary
142
+ if (matchedSlides.length && (matchedSlides.length <= currentMatchedIndex)) {
143
+ currentMatchedIndex = 0;
144
+ }
145
+ if (matchedSlides.length > currentMatchedIndex) {
146
+ Reveal.slide(matchedSlides[currentMatchedIndex].h, matchedSlides[currentMatchedIndex].v);
147
+ currentMatchedIndex++;
148
+ }
149
+ }
150
+
151
+ var dom = {};
152
+ dom.wrapper = document.querySelector( '.reveal' );
153
+
154
+ if( !dom.wrapper.querySelector( '.searchbox' ) ) {
155
+ var searchElement = document.createElement( 'div' );
156
+ searchElement.id = "searchinputdiv";
157
+ searchElement.classList.add( 'searchdiv' );
158
+ searchElement.style.position = 'absolute';
159
+ searchElement.style.top = '10px';
160
+ searchElement.style.left = '10px';
161
+ //embedded base64 search icon Designed by Sketchdock - http://www.sketchdock.com/:
162
+ searchElement.innerHTML = '<span><input type="search" id="searchinput" class="searchinput" style="vertical-align: top;"/><img src="" id="searchbutton" class="searchicon" style="vertical-align: top; margin-top: -1px;"/></span>';
163
+ dom.wrapper.appendChild( searchElement );
164
+ }
165
+
166
+ document.getElementById("searchbutton").addEventListener( 'click', function(event) {
167
+ doSearch();
168
+ }, false );
169
+
170
+ document.getElementById("searchinput").addEventListener( 'keyup', function( event ) {
171
+ switch (event.keyCode) {
172
+ case 13:
173
+ event.preventDefault();
174
+ doSearch();
175
+ searchboxDirty = false;
176
+ break;
177
+ default:
178
+ searchboxDirty = true;
179
+ }
180
+ }, false );
181
+
182
+ // Open the search when the 's' key is hit (yes, this conflicts with the notes plugin, disabling for now)
183
+ /*
184
+ document.addEventListener( 'keydown', function( event ) {
185
+ // Disregard the event if the target is editable or a
186
+ // modifier is present
187
+ if ( document.querySelector( ':focus' ) !== null || event.shiftKey || event.altKey || event.ctrlKey || event.metaKey ) return;
188
+
189
+ if( event.keyCode === 83 ) {
190
+ event.preventDefault();
191
+ openSearch();
192
+ }
193
+ }, false );
194
+ */
195
+ return { open: openSearch };
196
+ })();
@@ -1,29 +1,34 @@
1
1
  // Custom reveal.js integration
2
2
  (function(){
3
- document.querySelector( '.reveal' ).addEventListener( 'click', function( event ) {
4
- if( event.altKey ) {
3
+ var isEnabled = true;
4
+
5
+ document.querySelector( '.reveal' ).addEventListener( 'mousedown', function( event ) {
6
+ if( event.altKey && isEnabled ) {
5
7
  event.preventDefault();
6
8
  zoom.to({ element: event.target, pan: false });
7
9
  }
8
10
  } );
11
+
12
+ Reveal.addEventListener( 'overviewshown', function() { isEnabled = false; } );
13
+ Reveal.addEventListener( 'overviewhidden', function() { isEnabled = true; } );
9
14
  })();
10
15
 
11
16
  /*!
12
17
  * zoom.js 0.2 (modified version for use with reveal.js)
13
18
  * http://lab.hakim.se/zoom-js
14
19
  * MIT licensed
15
- *
20
+ *
16
21
  * Copyright (C) 2011-2012 Hakim El Hattab, http://hakim.se
17
22
  */
18
23
  var zoom = (function(){
19
24
 
20
25
  // The current zoom level (scale)
21
26
  var level = 1;
22
-
27
+
23
28
  // The current mouse position, used for panning
24
29
  var mouseX = 0,
25
30
  mouseY = 0;
26
-
31
+
27
32
  // Timeout before pan is activated
28
33
  var panEngageTimeout = -1,
29
34
  panUpdateInterval = -1;
@@ -36,7 +41,7 @@ var zoom = (function(){
36
41
  'msTransform' in document.body.style ||
37
42
  'OTransform' in document.body.style ||
38
43
  'transform' in document.body.style;
39
-
44
+
40
45
  if( supportsTransforms ) {
41
46
  // The easing that will be applied when we zoom in/out
42
47
  document.body.style.transition = 'transform 0.8s ease';
@@ -45,7 +50,7 @@ var zoom = (function(){
45
50
  document.body.style.MozTransition = '-moz-transform 0.8s ease';
46
51
  document.body.style.WebkitTransition = '-webkit-transform 0.8s ease';
47
52
  }
48
-
53
+
49
54
  // Zoom out if the user hits escape
50
55
  document.addEventListener( 'keyup', function( event ) {
51
56
  if( level !== 1 && event.keyCode === 27 ) {
@@ -62,21 +67,21 @@ var zoom = (function(){
62
67
  }, false );
63
68
 
64
69
  /**
65
- * Applies the CSS required to zoom in, prioritizes use of CSS3
70
+ * Applies the CSS required to zoom in, prioritizes use of CSS3
66
71
  * transforms but falls back on zoom for IE.
67
- *
68
- * @param {Number} pageOffsetX
69
- * @param {Number} pageOffsetY
70
- * @param {Number} elementOffsetX
71
- * @param {Number} elementOffsetY
72
- * @param {Number} scale
72
+ *
73
+ * @param {Number} pageOffsetX
74
+ * @param {Number} pageOffsetY
75
+ * @param {Number} elementOffsetX
76
+ * @param {Number} elementOffsetY
77
+ * @param {Number} scale
73
78
  */
74
79
  function magnify( pageOffsetX, pageOffsetY, elementOffsetX, elementOffsetY, scale ) {
75
80
 
76
81
  if( supportsTransforms ) {
77
82
  var origin = pageOffsetX +'px '+ pageOffsetY +'px',
78
83
  transform = 'translate('+ -elementOffsetX +'px,'+ -elementOffsetY +'px) scale('+ scale +')';
79
-
84
+
80
85
  document.body.style.transformOrigin = origin;
81
86
  document.body.style.OTransformOrigin = origin;
82
87
  document.body.style.msTransformOrigin = origin;
@@ -121,7 +126,7 @@ var zoom = (function(){
121
126
  }
122
127
 
123
128
  /**
124
- * Pan the document when the mosue cursor approaches the edges
129
+ * Pan the document when the mosue cursor approaches the edges
125
130
  * of the window.
126
131
  */
127
132
  function pan() {
@@ -129,7 +134,7 @@ var zoom = (function(){
129
134
  rangeX = window.innerWidth * range,
130
135
  rangeY = window.innerHeight * range,
131
136
  scrollOffset = getScrollOffset();
132
-
137
+
133
138
  // Up
134
139
  if( mouseY < rangeY ) {
135
140
  window.scroll( scrollOffset.x, scrollOffset.y - ( 1 - ( mouseY / rangeY ) ) * ( 14 / level ) );
@@ -159,7 +164,7 @@ var zoom = (function(){
159
164
  return {
160
165
  /**
161
166
  * Zooms in on either a rectangle or HTML element.
162
- *
167
+ *
163
168
  * @param {Object} options
164
169
  * - element: HTML element to zoom in on
165
170
  * OR
@@ -232,7 +237,7 @@ var zoom = (function(){
232
237
  if( currentOptions && currentOptions.element ) {
233
238
  scrollOffset.x -= ( window.innerWidth - ( currentOptions.width * currentOptions.scale ) ) / 2;
234
239
  }
235
-
240
+
236
241
  magnify( scrollOffset.x, scrollOffset.y, 0, 0, 1 );
237
242
 
238
243
  level = 1;
@@ -241,11 +246,11 @@ var zoom = (function(){
241
246
  // Alias
242
247
  magnify: function( options ) { this.to( options ) },
243
248
  reset: function() { this.out() },
244
-
249
+
245
250
  zoomLevel: function() {
246
251
  return level;
247
252
  }
248
253
  }
249
-
254
+
250
255
  })();
251
256
 
@@ -0,0 +1,6 @@
1
+ title = "The Never Sea Slides"
2
+ author = "Captain Hook"
3
+
4
+ [presentation]
5
+
6
+ theme = "night"
@@ -0,0 +1,4 @@
1
+ Just off the shores of Never Land
2
+ Ahh coconuts!
3
+ Yo Ho! Yo Ho!
4
+ Let's Go! Let's Go!
@@ -0,0 +1,4 @@
1
+ Just off the shores of Never Land
2
+ A hideaway at sea
3
+ Yo Ho! Yo Ho!
4
+ Let's Go! Let's Go!
@@ -0,0 +1,50 @@
1
+ require 'spec_helper'
2
+
3
+ module RevealCK
4
+ describe Config do
5
+
6
+ context 'when no config is supplied' do
7
+
8
+ let :config do
9
+ Config.new
10
+ end
11
+
12
+ it '#title defaults to "Slides"' do
13
+ config.title.should == "Slides"
14
+ end
15
+
16
+ it '#author defaults to "Hakim El Hattab"' do
17
+ config.author.should == "Hakim El Hattab"
18
+ end
19
+
20
+ it '#theme defaults to "default"' do
21
+ config.theme.should == "default"
22
+ end
23
+
24
+ end
25
+
26
+ context 'when a config is supplied' do
27
+
28
+ let :config_file do
29
+ File.join 'spec', 'data', 'config', 'config.toml'
30
+ end
31
+
32
+ let :config do
33
+ Config.new config_file: config_file
34
+ end
35
+
36
+ it '#title comes from the config file' do
37
+ expect(config.title).to eq "The Never Sea Slides"
38
+ end
39
+
40
+ it '#author comes from the config file' do
41
+ expect(config.author).to eq "Captain Hook"
42
+ end
43
+
44
+ it '#theme comes from the config file' do
45
+ config.theme.should == "night"
46
+ end
47
+
48
+ end
49
+ end
50
+ end