spurs 0.0.6.rc1 → 0.0.6.rc2

Sign up to get free protection for your applications and to get access to all the features.
data/README.rdoc ADDED
@@ -0,0 +1,27 @@
1
+ == Spurs
2
+
3
+
4
+ Rails is a web-application framework that includes everything needed to create
5
+ database-backed web applications according to the Model-View-Control pattern.
6
+
7
+ This pattern splits the view (also called the presentation) into "dumb"
8
+ templates that are primarily responsible for inserting pre-built data in between
9
+ HTML tags. The model contains the "smart" domain objects (such as Account,
10
+ Product, Person, Post) that holds all the business logic and knows how to
11
+ persist themselves to a database. The controller handles the incoming requests
12
+ (such as Save New Account, Update Product, Show Post) by manipulating the model
13
+ and directing data to the view.
14
+
15
+ In Rails, the model is handled by what's called an object-relational mapping
16
+ layer entitled Active Record. This layer allows you to present the data from
17
+ database rows as objects and embellish these data objects with business logic
18
+ methods. You can read more about Active Record in
19
+ link:files/vendor/rails/activerecord/README.html.
20
+
21
+ The controller and view are handled by the Action Pack, which handles both
22
+ layers by its two parts: Action View and Action Controller. These two layers
23
+ are bundled in a single package due to their heavy interdependence. This is
24
+ unlike the relationship between the Active Record and Action Pack that is much
25
+ more separate. Each of these packages can be used independently outside of
26
+ Rails. You can read more about Action Pack in
27
+ link:files/vendor/rails/actionpack/README.html.
@@ -1,2 +1,2 @@
1
1
  //= require ./responsive-tables
2
- //= require ./sticky-subnav
2
+ //= require ./bootstrap-collapsible-section
@@ -0,0 +1,72 @@
1
+ /**
2
+ * jQuery Collapsible Section
3
+ * (c) 2012 Michael North
4
+ */
5
+ (function( $ ){
6
+
7
+ $.fn.collapsibleSection = function( options ) {
8
+
9
+ // Create some defaults, extending them with any options that were provided
10
+ var settings = $.extend({
11
+ collapseText :'collapse',
12
+ expandText :'click to expand',
13
+ headerClass :'section-header',
14
+ bodyClass :'section-body',
15
+ footerClass :'section-footer',
16
+ endClass :'collapsible-section-end',
17
+ sectionComponentClass:'collapsible-section-component'
18
+
19
+ }, options);
20
+
21
+ var private_methods = {
22
+ expandSection: function() {
23
+ $(this).removeClass('collapsed');
24
+ $(this).addClass('expanded');
25
+ },
26
+ collapseSection: function() {
27
+ $(this).addClass('collapsed');
28
+ $(this).removeClass('expanded');
29
+ }
30
+ };
31
+
32
+ return this.each(function(idx,item) {
33
+ //if no collapsed or expanded class is present, collapse it
34
+ if(!$(item).hasClass('collapsed') && !$(item).hasClass('expanded')) {
35
+ $(item).addClass('collapsed');
36
+ }
37
+
38
+ //create end
39
+ var end_element = document.createElement("div");
40
+ $(end_element).addClass(settings.endClass);
41
+
42
+ var end_element_message = document.createElement('div');
43
+ $(end_element_message).addClass("message").append(settings.expandText);
44
+ var fadestripe = document.createElement("div");
45
+ $(fadestripe).addClass('fadestripe');
46
+ $(fadestripe).append(" ");
47
+ end_element.appendChild(end_element_message);
48
+ end_element.appendChild(fadestripe);
49
+
50
+ $(item).append(end_element);
51
+
52
+ //add section-component class to header, body and end
53
+ $(item).find('.' + settings.bodyClass).addClass(settings.sectionComponentClass);
54
+ $(item).find('.' + settings.footerClass).addClass(settings.sectionComponentClass);
55
+ $(item).find('.' + settings.endClass).addClass(settings.sectionComponentClass);
56
+
57
+ //add collapse button
58
+ var collapse_button = document.createElement('a');
59
+ $(collapse_button).addClass('collapse-trigger');
60
+ $(collapse_button).click(function(){
61
+ private_methods.collapseSection.apply(item);
62
+ });
63
+ $(collapse_button).append(settings.collapseText);
64
+ $(item).find('.' + settings.headerClass)[0].appendChild(collapse_button);
65
+
66
+ $(item).find('.'+settings.sectionComponentClass).click(function(){
67
+ private_methods.expandSection.apply(item);
68
+ });
69
+ });
70
+
71
+ };
72
+ })( jQuery );
@@ -15,24 +15,24 @@ $(document).ready(function() {
15
15
  });
16
16
  }
17
17
  };
18
-
18
+
19
19
  $(window).load(updateTables);
20
20
  $(window).bind("resize", updateTables);
21
-
22
-
21
+
22
+
23
23
  function splitTable(original)
24
24
  {
25
25
  original.wrap("<div class='table-wrapper' />");
26
-
26
+
27
27
  var copy = original.clone();
28
28
  copy.find("td:not(.pin_for_mobile), th:not(.pin_for_mobile)").css("display", "none");
29
29
  copy.removeClass("responsive");
30
-
30
+
31
31
  original.closest(".table-wrapper").append(copy);
32
32
  copy.wrap("<div class='pinned' />");
33
33
  original.wrap("<div class='scrollable' />");
34
34
  }
35
-
35
+
36
36
  function unsplitTable(original) {
37
37
  original.closest(".table-wrapper").find(".pinned").remove();
38
38
  original.unwrap();
@@ -11,5 +11,7 @@
11
11
  // GO AFTER THE REQUIRES BELOW.
12
12
  //
13
13
  //= require ./beyond_bootstrap/all
14
- //= require wysihtml5
15
- //= require bootstrap-wysihtml5
14
+
15
+ $().ready(function(){
16
+ $('table.table').addClass('responsive');
17
+ });
@@ -2,5 +2,5 @@
2
2
  *= require ./forms
3
3
  *= require ./responsive-tables
4
4
  *= require ./mobile_modal
5
- *= require ./button_column
5
+ *= require ./bootstrap-collapsible-section
6
6
  */
@@ -0,0 +1,71 @@
1
+ .mn-section {
2
+ margin: 10px 0px;
3
+ display: block;
4
+ .section-header {
5
+ font-size: 24px;
6
+ line-height: 30px;
7
+ padding-left: 10px;
8
+ border-bottom: 1px solid #ddd;
9
+
10
+ a.collapse-trigger {
11
+ display: none;
12
+ float: right;
13
+ font-size: 12px;
14
+ font-weight: 300;
15
+ margin-right: 10px;
16
+ }
17
+ }
18
+
19
+
20
+ .section-body {
21
+ font-size: 16px;
22
+ padding-left: 10px;
23
+ font-weight: 300;
24
+ line-height: 20px;
25
+ color: #666;
26
+ overflow: hidden;
27
+ }
28
+
29
+ .collapsible-section-end {
30
+ height: 0px;
31
+ .message {
32
+ height: 0px;
33
+ padding-top: 8px;
34
+ float: right;
35
+ z-index: 1001;
36
+ color: #999;
37
+ position: relative;
38
+ }
39
+ .fadestripe {
40
+ z-index: 1000;
41
+ height: 30px;
42
+ /* IE9 SVG, needs conditional override of 'filter' to 'none' */
43
+ background: url();
44
+ background: -moz-linear-gradient(top, rgba(255,255,255,0.2) 0%, rgba(255,255,255,1) 100%); /* FF3.6+ */
45
+ background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,0.2)), color-stop(100%,rgba(255,255,255,1))); /* Chrome,Safari4+ */
46
+ background: -webkit-linear-gradient(top, rgba(255,255,255,0.2) 0%,rgba(255,255,255,1) 100%); /* Chrome10+,Safari5.1+ */
47
+ background: -o-linear-gradient(top, rgba(255,255,255,0.2) 0%,rgba(255,255,255,1) 100%); /* Opera 11.10+ */
48
+ background: -ms-linear-gradient(top, rgba(255,255,255,0.2) 0%,rgba(255,255,255,1) 100%); /* IE10+ */
49
+ background: linear-gradient(to bottom, rgba(255,255,255,0.2) 0%,rgba(255,255,255,1) 100%); /* W3C */
50
+ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#33ffffff', endColorstr='#ffffff',GradientType=0 ); /* IE6-8 */
51
+
52
+ position:relative;
53
+ top: -30px;
54
+ }
55
+ }
56
+ &.collapsed {
57
+ .section-body {
58
+ height: 60px;
59
+ }
60
+ }
61
+ &.expanded {
62
+ a.collapse-trigger {
63
+ display: inline;
64
+ }
65
+ .collapsible-section-end {
66
+ .fadestripe, .message {
67
+ display:none;
68
+ }
69
+ }
70
+ }
71
+ }
@@ -1,23 +1,9 @@
1
1
  @media (max-width: 560px)
2
2
  .modal
3
+ position: fixed
3
4
  width: 100%
4
- top: 50px
5
5
  margin-left: 0px
6
6
  margin-right: 0px
7
- box-shadow: none
8
- right: 0px
9
- border: none
10
7
  left: 0px
11
- .modal-header
12
- background: #fff
13
- width: auto
14
- padding-top: 5px
15
- padding-bottom: 5px
16
- h1
17
- font-size: 30px
18
- line-height: 30px
19
- padding-top: 0px
20
- padding-bottom: 0px
21
- .modal-body
22
-
23
- padding-top: 50px
8
+ right: 0px
9
+ top: 50px
@@ -6,32 +6,31 @@ table
6
6
  @media only screen and (max-width: 767px)
7
7
  table.responsive
8
8
  margin-bottom: 0
9
- .table-wrapper
10
- .scrollable, .pinned
11
- table
12
- td, th
13
- line-height: 21px
14
- .pinned
15
- position: absolute
16
- left: 0
17
- top: 0
18
- background: #fff
19
- width: 200px
9
+ .scrollable, .pinned
10
+ table
11
+ td, th
12
+ line-height: 21px
13
+ .pinned
14
+ position: absolute
15
+ left: 0
16
+ top: 0
17
+ background: #fff
18
+ width: 200px
20
19
 
21
- overflow: hidden
22
- overflow-x: scroll
23
- //border-right: 1px solid #ccc
24
- //border-left: 1px solid #ccc
25
- table
26
- border-right: none
27
- border-left: none
28
- width: 100%
29
- .show_for_pinned
30
- display: table-cell
31
- .hide_for_pinned
32
- display: none
33
- th, td
34
- white-space: nowrap
20
+ overflow: hidden
21
+ overflow-x: scroll
22
+ //border-right: 1px solid #ccc
23
+ //border-left: 1px solid #ccc
24
+ table
25
+ border-right: none
26
+ border-left: none
27
+ width: 100%
28
+ .show_for_pinned
29
+ display: table-cell
30
+ .hide_for_pinned
31
+ display: none
32
+ th, td
33
+ white-space: nowrap
35
34
 
36
35
  div.table-wrapper
37
36
  position: relative
@@ -1,12 +1,3 @@
1
1
  /*
2
2
  *= require ./beyond_bootsrap/all
3
- *= require bootstrap-wysihtml5
4
- */
5
-
6
- .dropdown-menu {
7
- max-height: 500px;
8
- overflow-y: auto;
9
- overflow-x: hidden;
10
- }
11
-
12
-
3
+ */
@@ -15,36 +15,3 @@
15
15
  .section_body
16
16
  display: block
17
17
 
18
-
19
- $section_bg_color: rgb(250,250,250)
20
-
21
- .spurs_section
22
- margin-bottom: 10px
23
- .section_header
24
- font-size: 20px
25
- color: #333
26
- border-bottom: 1px solid #E5E5E5
27
- margin-bottom: 2px
28
- line-height: 36px
29
- .section_body
30
- background: $section_bg_color
31
- border: 1px solid #eee
32
- padding: 10px
33
- border-bottom-right-radius: 5px
34
- border-bottom-left-radius: 5px
35
- ul.nav.nav-tabs
36
- li
37
- a
38
- background-color: #fff
39
- border: 1px solid #ddd
40
- &:hover
41
- background-color: #666
42
- color: $section_bg_color
43
- &.active
44
- a
45
- background-color: $section_bg_color
46
- border-bottom-color: transparent
47
- &:hover
48
- background-color: $section_bg_color
49
- border-bottom-color: transparent
50
- color: #333
@@ -17,47 +17,6 @@ $('body')[0].appendChild(modal_container);
17
17
  %>
18
18
  modal_container.innerHTML = "<%= modal_container_content %>";
19
19
 
20
- if ($(modal_container.children[0]).find('.javascript-hooks').size() > 0) {
21
- var js_hooks = $(modal_container.children[0]).find('.javascript-hooks');
22
- var modal = $(modal_container.children[0]);
23
-
24
- modal.on('hidden', function () {
25
- js_hooks.each(function (idx, item) {
26
- if ($(item).attr('onhidden')) {
27
- eval($(item).attr('onhidden'));
28
- }
29
- });
30
- });
31
-
32
- modal.on('hide', function () {
33
- js_hooks.each(function (idx, item) {
34
- if ($(item).attr('onhide')) {
35
- eval($(item).attr('onhide'));
36
- }
37
- });
38
- });
39
-
40
- modal.on('show', function () {
41
- js_hooks.each(function (idx, item) {
42
- if ($(item).attr('onShow')) {
43
- eval($(item).attr('onShow'));
44
- }
45
- });
46
- });
47
-
48
- modal.on('shown', function () {
49
- js_hooks.each(function (idx, item) {
50
- if ($(item).attr('onshown')) {
51
- console.log($(item));
52
- eval($(item).attr('onshown'));
53
- }
54
- });
55
- });
56
- }
57
-
58
20
  //activate the modal
59
21
  $(modal_container.children[0]).modal();
60
-
61
- if(window._asd != undefined) {
62
- window._asd();
63
- }
22
+ window._asd();
@@ -33,11 +33,7 @@ module Spurs
33
33
  extra_class = options[:type] ? "alert-#{options[:type]}" : ""
34
34
  alert_content = String.new
35
35
  if options[:title]
36
- titl = options[:title]
37
- if options[:title_icon]
38
- titl = "<i class='icon-#{options[:title_icon]}' style='margin-right: 6px'></i>".concat(titl)
39
- end
40
- alert_content.concat(content_tag(:h4, titl.html_safe, :class => 'alert-heading'))
36
+ alert_content.concat(content_tag(:h4, options[:title], :class => 'alert-heading'))
41
37
  end
42
38
  if block
43
39
  block_content = capture(nil, &block)
@@ -72,7 +68,7 @@ module Spurs
72
68
  end
73
69
  flash.clear
74
70
 
75
- #logger.debug("MESSAGE HASH >>#{message_hash.to_json}")
71
+ logger.debug("MESSAGE HASH >>#{message_hash.to_json}")
76
72
 
77
73
 
78
74
  #process the message hash now
@@ -108,9 +108,6 @@ module Spurs
108
108
  if opts[:method] then
109
109
  a_opts[:method] = opts[:method]
110
110
  end
111
- if opts[:target] then
112
- a_opts[:target] = opts[:target]
113
- end
114
111
  end
115
112
  if opts[:onclick]
116
113
  a_opts[:onclick] = opts[:onclick]
@@ -1,6 +1,10 @@
1
- require "spurs/section/builder_base"
1
+ class Spurs::Section::CollapsibleSectionBuilder
2
+ include ActionView::Helpers::TagHelper
2
3
 
3
- class Spurs::Section::CollapsibleSectionBuilder < Spurs::Section::BuilderBase
4
+ @options_from_helper
5
+ def initialize(args={})
6
+ @options_from_helper = args.clone
7
+ end
4
8
 
5
9
  def build_collapsible_section(title,content)
6
10
  r = SecureRandom::hex(5)
@@ -15,18 +15,6 @@ module Spurs
15
15
  builder.build_collapsible_section(title.html_safe,section_content.html_safe)
16
16
  end
17
17
 
18
- def spurs_section(title,options={},&block)
19
- opts = Spurs::Section::section_default_options.merge(options)
20
- if !opts[:builder]
21
- raise "Null builder"
22
- end
23
-
24
- options_to_pass_to_builder = {}
25
- builder = opts[:builder].new(options_to_pass_to_builder)
26
- section_content = capture(nil,&block)
27
- builder.build_section(title.html_safe,section_content.html_safe)
28
- end
29
-
30
18
  def spurs_vcenter(options={}, &block)
31
19
  opts = options.clone
32
20
  if !opts[:class]
data/lib/spurs/section.rb CHANGED
@@ -1,6 +1,5 @@
1
1
  require "spurs/section/helper"
2
2
  require "spurs/section/collapsible_section_builder"
3
- require "spurs/section/section_builder"
4
3
  module Spurs
5
4
  module Section
6
5
  @@collapsible_section_default_options = {
@@ -11,13 +10,6 @@ module Spurs
11
10
  def self.collapsible_section_default_options
12
11
  @@collapsible_section_default_options
13
12
  end
14
-
15
- @@section_default_options = {
16
- :builder => Spurs::Section::SectionBuilder
17
- }
18
- def self.section_default_options
19
- @@section_default_options
20
- end
21
13
  end
22
14
  end
23
15
 
data/lib/spurs/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module Spurs
2
- VERSION = "0.0.6.rc1"
2
+ VERSION = "0.0.6.rc2"
3
3
  end
data/lib/spurs.rb CHANGED
@@ -18,8 +18,6 @@ require "spurs/section"
18
18
  require "spurs/engine"
19
19
  require "spurs/badge"
20
20
 
21
- require "bootstrap-wysihtml5-rails/engine"
22
-
23
21
  ActionView::Base.send :include, Spurs::Flash::Helper
24
22
  ActionView::Base.send :include, Spurs::Nav::Helper
25
23
  ActionView::Base.send :include, Spurs::Section::Helper
data/test/spurs_test.rb CHANGED
@@ -0,0 +1,7 @@
1
+ require 'test_helper'
2
+
3
+ class SpursTest < ActiveSupport::TestCase
4
+ test "truth" do
5
+ assert_kind_of Module, Spurs
6
+ end
7
+ end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: spurs
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.6.rc1
4
+ version: 0.0.6.rc2
5
5
  prerelease: 6
6
6
  platform: ruby
7
7
  authors:
@@ -9,40 +9,24 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-07-21 00:00:00.000000000 Z
12
+ date: 2012-08-01 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: railties
16
16
  requirement: !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
- - - ! '>='
20
- - !ruby/object:Gem::Version
21
- version: '3.1'
22
- type: :runtime
23
- prerelease: false
24
- version_requirements: !ruby/object:Gem::Requirement
25
- none: false
26
- requirements:
27
- - - ! '>='
28
- - !ruby/object:Gem::Version
29
- version: '3.1'
30
- - !ruby/object:Gem::Dependency
31
- name: actionpack
32
- requirement: !ruby/object:Gem::Requirement
33
- none: false
34
- requirements:
35
- - - ! '>='
19
+ - - ~>
36
20
  - !ruby/object:Gem::Version
37
- version: '3.1'
21
+ version: 3.2.1
38
22
  type: :runtime
39
23
  prerelease: false
40
24
  version_requirements: !ruby/object:Gem::Requirement
41
25
  none: false
42
26
  requirements:
43
- - - ! '>='
27
+ - - ~>
44
28
  - !ruby/object:Gem::Version
45
- version: '3.1'
29
+ version: 3.2.1
46
30
  - !ruby/object:Gem::Dependency
47
31
  name: twitter-bootstrap-rails
48
32
  requirement: !ruby/object:Gem::Requirement
@@ -66,7 +50,7 @@ dependencies:
66
50
  requirements:
67
51
  - - ! '>='
68
52
  - !ruby/object:Gem::Version
69
- version: '3.1'
53
+ version: 3.1.4
70
54
  type: :runtime
71
55
  prerelease: false
72
56
  version_requirements: !ruby/object:Gem::Requirement
@@ -74,55 +58,7 @@ dependencies:
74
58
  requirements:
75
59
  - - ! '>='
76
60
  - !ruby/object:Gem::Version
77
- version: '3.1'
78
- - !ruby/object:Gem::Dependency
79
- name: bootstrap-wysihtml5-rails
80
- requirement: !ruby/object:Gem::Requirement
81
- none: false
82
- requirements:
83
- - - ~>
84
- - !ruby/object:Gem::Version
85
- version: 0.2.12
86
- type: :runtime
87
- prerelease: false
88
- version_requirements: !ruby/object:Gem::Requirement
89
- none: false
90
- requirements:
91
- - - ~>
92
- - !ruby/object:Gem::Version
93
- version: 0.2.12
94
- - !ruby/object:Gem::Dependency
95
- name: therubyracer
96
- requirement: !ruby/object:Gem::Requirement
97
- none: false
98
- requirements:
99
- - - ! '>='
100
- - !ruby/object:Gem::Version
101
- version: 0.10.1
102
- type: :runtime
103
- prerelease: false
104
- version_requirements: !ruby/object:Gem::Requirement
105
- none: false
106
- requirements:
107
- - - ! '>='
108
- - !ruby/object:Gem::Version
109
- version: 0.10.1
110
- - !ruby/object:Gem::Dependency
111
- name: rails
112
- requirement: !ruby/object:Gem::Requirement
113
- none: false
114
- requirements:
115
- - - ~>
116
- - !ruby/object:Gem::Version
117
- version: '3.1'
118
- type: :development
119
- prerelease: false
120
- version_requirements: !ruby/object:Gem::Requirement
121
- none: false
122
- requirements:
123
- - - ~>
124
- - !ruby/object:Gem::Version
125
- version: '3.1'
61
+ version: 3.1.4
126
62
  description: Helpers and extensions for the Twitter Bootstrap user interface
127
63
  email:
128
64
  - michael.north@truenorthapps.com
@@ -149,8 +85,8 @@ files:
149
85
  - app/assets/images/spurs/jquery_ui_theme/images/ui-icons_cd0a0a_256x240.png
150
86
  - app/assets/images/spurs/jquery_ui_theme/images/ui-icons_f6cf3b_256x240.png
151
87
  - app/assets/javascripts/spurs/beyond_bootstrap/all.js
88
+ - app/assets/javascripts/spurs/beyond_bootstrap/bootstrap-collapsible-section.js
152
89
  - app/assets/javascripts/spurs/beyond_bootstrap/responsive-tables.js
153
- - app/assets/javascripts/spurs/beyond_bootstrap/sticky-subnav.js.coffee
154
90
  - app/assets/javascripts/spurs/beyond_bootstrap.js
155
91
  - app/assets/javascripts/spurs/flashes.js.coffee
156
92
  - app/assets/javascripts/spurs/flashes.js.erb
@@ -159,7 +95,7 @@ files:
159
95
  - app/assets/javascripts/spurs/vars.js.erb
160
96
  - app/assets/javascripts/spurs.js
161
97
  - app/assets/stylesheets/spurs/beyond_bootsrap/all.css
162
- - app/assets/stylesheets/spurs/beyond_bootsrap/button_column.css.sass
98
+ - app/assets/stylesheets/spurs/beyond_bootsrap/bootstrap-collapsible-section.css.scss
163
99
  - app/assets/stylesheets/spurs/beyond_bootsrap/forms.css.sass
164
100
  - app/assets/stylesheets/spurs/beyond_bootsrap/mobile_modal.css.sass
165
101
  - app/assets/stylesheets/spurs/beyond_bootsrap/responsive-tables.css.sass
@@ -196,17 +132,15 @@ files:
196
132
  - lib/spurs/popover/builder.rb
197
133
  - lib/spurs/popover/helper.rb
198
134
  - lib/spurs/popover.rb
199
- - lib/spurs/section/builder_base.rb
200
135
  - lib/spurs/section/collapsible_section_builder.rb
201
136
  - lib/spurs/section/helper.rb
202
- - lib/spurs/section/section_builder.rb
203
137
  - lib/spurs/section.rb
204
138
  - lib/spurs/version.rb
205
139
  - lib/spurs.rb
206
140
  - lib/tasks/spurs_tasks.rake
207
141
  - MIT-LICENSE
208
142
  - Rakefile
209
- - README.markdown
143
+ - README.rdoc
210
144
  - test/dummy/app/assets/javascripts/application.js
211
145
  - test/dummy/app/assets/stylesheets/application.css
212
146
  - test/dummy/app/controllers/application_controller.rb
@@ -228,7 +162,6 @@ files:
228
162
  - test/dummy/config/locales/en.yml
229
163
  - test/dummy/config/routes.rb
230
164
  - test/dummy/config.ru
231
- - test/dummy/log/test.log
232
165
  - test/dummy/public/404.html
233
166
  - test/dummy/public/422.html
234
167
  - test/dummy/public/500.html
@@ -255,7 +188,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
255
188
  version: '0'
256
189
  segments:
257
190
  - 0
258
- hash: -286962116275508797
191
+ hash: 3755465715902946807
259
192
  required_rubygems_version: !ruby/object:Gem::Requirement
260
193
  none: false
261
194
  requirements:
@@ -290,7 +223,6 @@ test_files:
290
223
  - test/dummy/config/locales/en.yml
291
224
  - test/dummy/config/routes.rb
292
225
  - test/dummy/config.ru
293
- - test/dummy/log/test.log
294
226
  - test/dummy/public/404.html
295
227
  - test/dummy/public/422.html
296
228
  - test/dummy/public/500.html
data/README.markdown DELETED
@@ -1,87 +0,0 @@
1
- # Spurs
2
-
3
- Spurs is a library that adds some bells and whistles to the Twitter Bootstrap GUI framework.
4
-
5
- ## Installation
6
- There are many independent components of spurs, and some require more set up than others.
7
-
8
- To get started, in your gemfile, add
9
-
10
- ```ruby
11
- gem 'spurs'
12
- ```
13
-
14
- and then run
15
-
16
- ```ruby
17
- bundle install
18
- ```
19
-
20
- ## Flash Messages
21
-
22
- From the rails side, you can create four types of messages: `:notice`, `:warning`, `:info` and `:error`
23
-
24
- ```ruby
25
- flash_addItem(:notices,"A message about something successfully happening!")
26
- ```
27
- It's especially easy to add model errors as flash messages. Here's a typical use
28
- ```ruby
29
- m = Message.new(:title => "hello", :body => "world!")
30
- if !m.save
31
- flash_addModelErrors(m)
32
- end
33
- ```
34
-
35
-
36
- You can also use JavaScript to generate matching messages
37
- ```javascript
38
- spurs.flash.alert("Something has gone wrong!","error");
39
- ```
40
- [More...](https://github.com/TrueNorth/spurs/wiki/Flash-Messages)
41
-
42
- ## Navigation
43
-
44
- Spurs makes creation of bootstrap navigation easy!.
45
- ```haml
46
- = spurs_nav :type => :pills do |nav|
47
- = nav.tab :user, :icon => :user, :href => "#user"
48
- = nav.tab :settings, :icon => :cog, :onclick => "alert('hello');"
49
- ```
50
- [More...](https://github.com/TrueNorth/spurs/wiki/Navigation)
51
-
52
- ## Alerts
53
- Alerts are styled to match flash messages. Creating an in-place alert is done as follows
54
- ```haml
55
- = spurs_alert_box do
56
- This is a basic alert
57
- ```
58
- [More...](https://github.com/TrueNorth/spurs/wiki/Alerts)
59
-
60
- ## Asynchronous Modals
61
- Spurs can present a modal as a response to an asynchronous request.
62
-
63
- For example, if your request is
64
- ```javascript
65
- $.get({url: '/blogs/MY_BLOG/posts/new.js'});
66
- ```
67
- Your controller response might look like
68
- ```ruby
69
- @blog = Blog.find(params[:blog_id])
70
- respond_to do |format|
71
- format.js {
72
- spawn_modal("Create a new blog post", #Title of the modal
73
- "blogs/posts/new", # Path to a partial to render in the modal body.
74
- @blog, # Object that the partial is rendering. Can be nil if the previous argument is not a partial
75
- :title_icon => '/assets/new_blog_post_icon.png' # Path to an icon shown in the title bar of the modal
76
- :modal_options => {} # A hash passed to the partial as local variables
77
- )
78
- }
79
- end
80
- ```
81
- You can also use a method
82
- ```ruby
83
- spawn_form_modal(...) #same arguments as spawn_modal
84
- ```
85
- which will show a modal with an "OK" button in the footer. Pressing this button will submit any form in the .modal-body div.
86
-
87
-
@@ -1,24 +0,0 @@
1
- not ($) ->
2
- $ ->
3
- processScroll = ->
4
- i = undefined
5
- scrollTop = $win.scrollTop()
6
- if scrollTop >= navTop and not isFixed
7
- isFixed = 1
8
- $nav.addClass "subnav-fixed"
9
- else if scrollTop <= navTop and isFixed
10
- isFixed = 0
11
- $nav.removeClass "subnav-fixed"
12
- $win = $(window)
13
- $nav = $(".subnav")
14
- navTop = $(".subnav").length and $(".subnav").offset().top - 40
15
- isFixed = 0
16
- processScroll()
17
- $nav.on "click", ->
18
- unless isFixed
19
- setTimeout (->
20
- $win.scrollTop $win.scrollTop() - 47
21
- ), 10
22
-
23
- $win.on "scroll", processScroll
24
- (window.jQuery)
@@ -1,20 +0,0 @@
1
- .button-column
2
- width: 100%
3
- button.btn, a.btn
4
- width: 100%
5
- border-radius: 0px
6
- border-top-width: 0px
7
- &:first-child
8
- border-top-width: 0px
9
- border-top-left-radius: 4px
10
- border-top-right-radius: 4px
11
- &:last-child
12
- border-bottom-left-radius: 4px
13
- border-bottom-right-radius: 4px
14
- &.btn-large
15
- &:first-child
16
- border-top-left-radius: 6px
17
- border-top-right-radius: 6px
18
- &:last-child
19
- border-bottom-left-radius: 6px
20
- border-bottom-right-radius: 6px
@@ -1,9 +0,0 @@
1
- class Spurs::Section::BuilderBase
2
- include ActionView::Helpers::TagHelper
3
-
4
- @options_from_helper
5
- def initialize(args={})
6
- @options_from_helper = args.clone
7
- end
8
-
9
- end
@@ -1,22 +0,0 @@
1
- require "spurs/section/builder_base"
2
- class Spurs::Section::SectionBuilder < Spurs::Section::BuilderBase
3
-
4
- def build_section(title,content)
5
- r = SecureRandom::hex(5)
6
- section_id = "section_#{r}"
7
-
8
-
9
- header_output = build_header(title)
10
- body_output = build_body(content)
11
- content_tag(:div,header_output.concat(body_output), :class => "spurs_section #{section_id}")
12
- end
13
-
14
- private
15
- def build_header(title)
16
- content_tag(:div,title, :class => "section_header")
17
- end
18
-
19
- def build_body(content)
20
- content_tag(:div, content.html_safe, :class => "section_body")
21
- end
22
- end
File without changes