effective_bootstrap 0.9.15 → 0.9.20
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/assets/javascripts/effective_has_many/initialize.js.coffee +2 -2
- data/app/assets/javascripts/effective_password/initialize.js.coffee +2 -2
- data/app/helpers/effective_bootstrap_helper.rb +30 -0
- data/app/models/effective/form_inputs/file_field.rb +4 -0
- data/app/models/effective/form_inputs/has_many.rb +1 -1
- data/app/models/effective/form_inputs/password_field.rb +2 -2
- data/app/models/effective/form_inputs/text_field.rb +0 -4
- data/lib/effective_bootstrap/version.rb +1 -1
- metadata +2 -3
- data/app/models/effective/access_denied.rb +0 -17
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: fc9ac29fcd023cd275a7a7297fa003465ae57dd4083bc918726ddd320a64aba7
|
4
|
+
data.tar.gz: cdc85057126193e16d6ffe680d2176f4338fa18eb2e8ffbd9988ea80f3c7ec84
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 43b8330b6295ba275311ea1dc07fa4eb96d33e740f24c35f48c793f4c2941e0e26ddd0b6940ef7d4046cd5e336d765fc47bd62357ce67124bed143d12a81625b
|
7
|
+
data.tar.gz: cfcf9995db34b32add68cb9a3e7bc79c441d20758ee12846c177ac37985f0538495ea032b0bc34738cdd0d710cef499af164f2ca9f41fbf01076417044e5bf24
|
@@ -3,7 +3,7 @@ assignPositions = (target) ->
|
|
3
3
|
return unless $hasMany.length > 0
|
4
4
|
|
5
5
|
$fields = $hasMany.children('.has-many-fields:not(.marked-for-destruction)')
|
6
|
-
positions = $fields.find("input[name$='[position]']").map(-> this.value).get()
|
6
|
+
positions = $fields.find("input[name$='[position]'][type=hidden]").map(-> this.value).get()
|
7
7
|
|
8
8
|
if positions.length > 0
|
9
9
|
index = Math.min.apply(Math, positions) || 0
|
@@ -35,7 +35,7 @@ $(document).on 'click', '[data-effective-form-has-many-add]', (event) ->
|
|
35
35
|
return unless $hasMany.length > 0
|
36
36
|
|
37
37
|
uid = (new Date).valueOf()
|
38
|
-
template = $obj.data('effective-form-has-many-template').replace(/HASMANYINDEX/g, uid)
|
38
|
+
template = atob($obj.data('effective-form-has-many-template')).replace(/HASMANYINDEX/g, uid)
|
39
39
|
|
40
40
|
$fields = $(template).hide().fadeIn('fast')
|
41
41
|
EffectiveBootstrap.initialize($fields)
|
@@ -1,9 +1,9 @@
|
|
1
1
|
# Prevent non-currency buttons from being pressed
|
2
|
-
$(document).on 'click', '
|
2
|
+
$(document).on 'click', 'span[data-effective-password]', (event) ->
|
3
3
|
$obj = $(event.currentTarget)
|
4
4
|
$input = $obj.closest('.input-group')
|
5
5
|
|
6
6
|
$input.find('input').attr('type', $obj.data('effective-password'))
|
7
|
-
$input.find('
|
7
|
+
$input.find('span[data-effective-password]').toggle()
|
8
8
|
|
9
9
|
false
|
@@ -18,6 +18,36 @@ module EffectiveBootstrapHelper
|
|
18
18
|
content
|
19
19
|
end
|
20
20
|
|
21
|
+
# https://getbootstrap.com/docs/4.0/components/card/
|
22
|
+
# = card('title do')
|
23
|
+
# %p Stuff
|
24
|
+
# = card('Stuff', header: 'header title')
|
25
|
+
def card(value = nil, opts = {}, &block)
|
26
|
+
raise('expected a block') unless block_given?
|
27
|
+
|
28
|
+
if value.kind_of?(Hash)
|
29
|
+
opts = value; value = nil
|
30
|
+
end
|
31
|
+
|
32
|
+
header = opts.delete(:header)
|
33
|
+
title = opts.delete(:title) || value
|
34
|
+
|
35
|
+
content_tag(:div, merge_class_key(opts, 'card mb-4')) do
|
36
|
+
header = content_tag(:div, header, class: 'card-header') if header.present?
|
37
|
+
|
38
|
+
body = content_tag(:div, class: 'card-body') do
|
39
|
+
if title.present?
|
40
|
+
content_tag(:h5, title, class: 'card-title') + capture(&block)
|
41
|
+
else
|
42
|
+
capture(&block)
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
header ? (header + body) : body
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
|
21
51
|
# https://getbootstrap.com/docs/4.0/components/collapse/
|
22
52
|
|
23
53
|
# = collapse('toggle visibility') do
|
@@ -75,6 +75,8 @@ module Effective
|
|
75
75
|
|
76
76
|
def build_table_attachment(attachment)
|
77
77
|
url = (@template.url_for(attachment) rescue false)
|
78
|
+
url ||= (Rails.application.routes.url_helpers.rails_blob_path(attachment, only_path: true) rescue false)
|
79
|
+
|
78
80
|
return unless url
|
79
81
|
|
80
82
|
image_tag = content_tag(:img, '', class: '', src: url, alt: attachment.filename.to_s) if attachment.image?
|
@@ -98,6 +100,8 @@ module Effective
|
|
98
100
|
|
99
101
|
def build_card_attachment(attachment)
|
100
102
|
url = (@template.url_for(attachment) rescue false)
|
103
|
+
url ||= (Rails.application.routes.url_helpers.rails_blob_path(attachment, only_path: true) rescue false)
|
104
|
+
|
101
105
|
return unless url
|
102
106
|
|
103
107
|
content_tag(:div, class: 'col') do
|
@@ -150,7 +150,7 @@ module Effective
|
|
150
150
|
html.gsub!("#{name}_attributes][#{index}]", "#{name}_attributes][HASMANYINDEX]")
|
151
151
|
html.gsub!("#{name}_attributes_#{index}_", "#{name}_attributes_HASMANYINDEX_")
|
152
152
|
|
153
|
-
html
|
153
|
+
Base64.encode64(html)
|
154
154
|
end
|
155
155
|
|
156
156
|
def link_to_add(block)
|
@@ -11,12 +11,12 @@ module Effective
|
|
11
11
|
end
|
12
12
|
|
13
13
|
def eyes
|
14
|
-
content_tag(:
|
14
|
+
content_tag(:span, icon('eye'),
|
15
15
|
class: 'btn input-group-text',
|
16
16
|
title: 'Show password',
|
17
17
|
'data-effective-password': 'text'
|
18
18
|
) +
|
19
|
-
content_tag(:
|
19
|
+
content_tag(:span, icon('eye-off'),
|
20
20
|
class: 'btn input-group-text',
|
21
21
|
title: 'Hide password',
|
22
22
|
style: 'display: none;',
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: effective_bootstrap
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.9.
|
4
|
+
version: 0.9.20
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Code and Effect
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
11
|
+
date: 2021-03-16 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -615,7 +615,6 @@ files:
|
|
615
615
|
- app/helpers/effective_editor_helper.rb
|
616
616
|
- app/helpers/effective_form_builder_helper.rb
|
617
617
|
- app/helpers/effective_icons_helper.rb
|
618
|
-
- app/models/effective/access_denied.rb
|
619
618
|
- app/models/effective/form_builder.rb
|
620
619
|
- app/models/effective/form_input.rb
|
621
620
|
- app/models/effective/form_inputs/check_box.rb
|
@@ -1,17 +0,0 @@
|
|
1
|
-
unless defined?(Effective::AccessDenied)
|
2
|
-
module Effective
|
3
|
-
class AccessDenied < StandardError
|
4
|
-
attr_reader :action, :subject
|
5
|
-
|
6
|
-
def initialize(message = nil, action = nil, subject = nil)
|
7
|
-
@message = message
|
8
|
-
@action = action
|
9
|
-
@subject = subject
|
10
|
-
end
|
11
|
-
|
12
|
-
def to_s
|
13
|
-
@message || I18n.t(:'unauthorized.default', :default => 'Access Denied')
|
14
|
-
end
|
15
|
-
end
|
16
|
-
end
|
17
|
-
end
|