avo 0.5.0.beta9 → 0.5.0.beta10
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of avo might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/Gemfile +47 -48
- data/Gemfile.lock +1 -1
- data/Rakefile +14 -14
- data/app/components/avo/common/multiple_file_viewer_component.rb +1 -1
- data/app/components/avo/common/single_file_viewer_component.rb +1 -1
- data/app/components/avo/edit/field_wrapper_component.rb +3 -3
- data/app/components/avo/index/field_wrapper_component.rb +1 -1
- data/app/components/avo/index/grid_item_component.rb +10 -9
- data/app/components/avo/index/resource_controls_component.rb +2 -2
- data/app/components/avo/panel_component.rb +7 -6
- data/app/components/avo/resource_component.rb +4 -3
- data/app/components/avo/show/field_wrapper_component.rb +3 -3
- data/app/components/avo/views/resource_edit_component.rb +4 -3
- data/app/components/avo/views/resource_index_component.rb +8 -7
- data/app/components/avo/views/resource_new_component.rb +4 -3
- data/app/components/avo/views/resource_show_component.rb +21 -21
- data/app/controllers/avo/actions_controller.rb +30 -29
- data/app/controllers/avo/application_controller.rb +113 -126
- data/app/controllers/avo/attachments_controller.rb +3 -3
- data/app/controllers/avo/base_controller.rb +81 -80
- data/app/controllers/avo/home_controller.rb +2 -2
- data/app/controllers/avo/relations_controller.rb +29 -28
- data/app/controllers/avo/resources_controller.rb +1 -1
- data/app/controllers/avo/search_controller.rb +20 -19
- data/app/helpers/avo/application_helper.rb +48 -42
- data/app/helpers/avo/resources_helper.rb +11 -11
- data/app/mailers/avo/application_mailer.rb +2 -2
- data/app/packs/entrypoints/application.js +9 -7
- data/app/packs/js/controllers/fields/code_field_controller.js +14 -14
- data/app/packs/js/controllers/filter_controller.js +9 -8
- data/app/packs/js/toastr.js +1 -0
- data/avo.gemspec +31 -31
- data/config/initializers/inline_svg.rb +1 -1
- data/config/initializers/pagy.rb +1 -1
- data/config/routes.rb +12 -12
- data/config/spring.rb +5 -5
- data/db/factories.rb +3 -5
- data/lib/avo.rb +6 -6
- data/lib/avo/app.rb +18 -18
- data/lib/avo/base_action.rb +20 -20
- data/lib/avo/base_resource.rb +41 -45
- data/lib/avo/configuration.rb +16 -18
- data/lib/avo/engine.rb +18 -18
- data/lib/avo/fields/badge_field.rb +2 -2
- data/lib/avo/fields/base_field.rb +24 -25
- data/lib/avo/fields/belongs_to_field.rb +13 -12
- data/lib/avo/fields/boolean_field.rb +4 -4
- data/lib/avo/fields/boolean_group_field.rb +3 -3
- data/lib/avo/fields/code_field.rb +4 -4
- data/lib/avo/fields/country_field.rb +2 -2
- data/lib/avo/fields/currency_field.rb +3 -3
- data/lib/avo/fields/date_field.rb +3 -3
- data/lib/avo/fields/date_time_field.rb +2 -2
- data/lib/avo/fields/external_image_field.rb +2 -2
- data/lib/avo/fields/field_extensions/has_field_name.rb +2 -2
- data/lib/avo/fields/field_extensions/visible_in_different_views.rb +34 -33
- data/lib/avo/fields/file_field.rb +1 -1
- data/lib/avo/fields/files_field.rb +2 -2
- data/lib/avo/fields/gravatar_field.rb +9 -9
- data/lib/avo/fields/has_and_belongs_to_many_field.rb +1 -1
- data/lib/avo/fields/has_many_field.rb +1 -1
- data/lib/avo/fields/has_one_field.rb +2 -2
- data/lib/avo/fields/heading_field.rb +2 -2
- data/lib/avo/fields/hidden_field.rb +1 -1
- data/lib/avo/fields/id_field.rb +3 -3
- data/lib/avo/fields/key_value_field.rb +12 -12
- data/lib/avo/fields/markdown_field.rb +2 -2
- data/lib/avo/fields/number_field.rb +3 -3
- data/lib/avo/fields/password_field.rb +1 -1
- data/lib/avo/fields/select_field.rb +8 -12
- data/lib/avo/fields/status_field.rb +4 -4
- data/lib/avo/fields/text_field.rb +2 -2
- data/lib/avo/fields/textarea_field.rb +2 -2
- data/lib/avo/fields/trix_field.rb +1 -1
- data/lib/avo/fields_collector.rb +4 -5
- data/lib/avo/filters/base_filter.rb +6 -6
- data/lib/avo/filters/boolean_filter.rb +1 -1
- data/lib/avo/filters/select_filter.rb +1 -1
- data/lib/avo/licensing/h_q.rb +56 -55
- data/lib/avo/licensing/license.rb +5 -5
- data/lib/avo/licensing/license_manager.rb +4 -4
- data/lib/avo/licensing/null_license.rb +2 -2
- data/lib/avo/licensing/pro_license.rb +1 -1
- data/lib/avo/loaders/fields_loader.rb +4 -4
- data/lib/avo/services/authorization_service.rb +2 -2
- data/lib/avo/services/panel_service.rb +4 -4
- data/lib/avo/version.rb +1 -1
- data/lib/generators/avo/action_generator.rb +4 -4
- data/lib/generators/avo/controller_generator.rb +4 -4
- data/lib/generators/avo/filter_generator.rb +5 -5
- data/lib/generators/avo/install_generator.rb +8 -8
- data/lib/generators/avo/locales_generator.rb +5 -5
- data/lib/generators/avo/partials_generator.rb +4 -4
- data/lib/generators/avo/resource_generator.rb +5 -5
- data/lib/tasks/avo_tasks.rake +52 -53
- data/public/avo-packs/css/{application-38e7e91b.css → application-4e16d6a6.css} +4 -4
- data/public/avo-packs/css/application-4e16d6a6.css.br +0 -0
- data/public/avo-packs/css/{application-38e7e91b.css.gz → application-4e16d6a6.css.gz} +0 -0
- data/public/avo-packs/css/{application-38e7e91b.css.map → application-4e16d6a6.css.map} +1 -1
- data/public/avo-packs/css/application-4e16d6a6.css.map.br +0 -0
- data/public/avo-packs/css/application-4e16d6a6.css.map.gz +0 -0
- data/public/avo-packs/js/{application-2b90fe889f7d6df1ad92.js → application-8eb130a4688f2c667703.js} +4 -4
- data/public/avo-packs/js/{application-2b90fe889f7d6df1ad92.js.LICENSE.txt → application-8eb130a4688f2c667703.js.LICENSE.txt} +0 -0
- data/public/avo-packs/js/application-8eb130a4688f2c667703.js.br +0 -0
- data/public/avo-packs/js/application-8eb130a4688f2c667703.js.gz +0 -0
- data/public/avo-packs/js/application-8eb130a4688f2c667703.js.map +1 -0
- data/public/avo-packs/js/application-8eb130a4688f2c667703.js.map.br +0 -0
- data/public/avo-packs/js/application-8eb130a4688f2c667703.js.map.gz +0 -0
- data/public/avo-packs/manifest.json +15 -15
- metadata +15 -15
- data/public/avo-packs/css/application-38e7e91b.css.br +0 -0
- data/public/avo-packs/css/application-38e7e91b.css.map.br +0 -0
- data/public/avo-packs/css/application-38e7e91b.css.map.gz +0 -0
- data/public/avo-packs/js/application-2b90fe889f7d6df1ad92.js.br +0 -0
- data/public/avo-packs/js/application-2b90fe889f7d6df1ad92.js.gz +0 -0
- data/public/avo-packs/js/application-2b90fe889f7d6df1ad92.js.map +0 -1
- data/public/avo-packs/js/application-2b90fe889f7d6df1ad92.js.map.br +0 -0
- data/public/avo-packs/js/application-2b90fe889f7d6df1ad92.js.map.gz +0 -0
@@ -1,36 +1,36 @@
|
|
1
|
-
require
|
1
|
+
require "json"
|
2
2
|
|
3
3
|
module Avo
|
4
4
|
module Fields
|
5
5
|
class KeyValueField < BaseField
|
6
6
|
def initialize(name, **args, &block)
|
7
7
|
@defaults = {
|
8
|
-
partial_name:
|
8
|
+
partial_name: "key-value-field"
|
9
9
|
}
|
10
10
|
|
11
11
|
super(name, **args, &block)
|
12
12
|
|
13
13
|
hide_on :index
|
14
14
|
|
15
|
-
@key_label = args[:key_label].present? ? args[:key_label].to_s :
|
16
|
-
@value_label = args[:value_label].present? ? args[:value_label].to_s :
|
17
|
-
@action_text = args[:action_text].present? ? args[:action_text].to_s :
|
18
|
-
@delete_text = args[:delete_text].present? ? args[:delete_text].to_s :
|
15
|
+
@key_label = args[:key_label].present? ? args[:key_label].to_s : "Key"
|
16
|
+
@value_label = args[:value_label].present? ? args[:value_label].to_s : "Value"
|
17
|
+
@action_text = args[:action_text].present? ? args[:action_text].to_s : "Add row"
|
18
|
+
@delete_text = args[:delete_text].present? ? args[:delete_text].to_s : "Delete row"
|
19
19
|
|
20
20
|
@disable_editing_keys = args[:disable_editing_keys].present? ? args[:disable_editing_keys] : false
|
21
21
|
# disabling editing keys also disables adding rows (doesn't take into account the value of disable_adding_rows)
|
22
|
-
if args[:disable_editing_keys].present? && args[:disable_editing_keys] == true
|
23
|
-
|
22
|
+
@disable_adding_rows = if args[:disable_editing_keys].present? && args[:disable_editing_keys] == true
|
23
|
+
true
|
24
24
|
elsif args[:disable_adding_rows].present?
|
25
|
-
|
25
|
+
args[:disable_adding_rows]
|
26
26
|
else
|
27
|
-
|
27
|
+
false
|
28
28
|
end
|
29
29
|
@disable_deleting_rows = args[:disable_deleting_rows].present? ? args[:disable_deleting_rows] : false
|
30
30
|
end
|
31
31
|
|
32
32
|
def to_permitted_param
|
33
|
-
[:"#{id}", "#{id}": {}
|
33
|
+
[:"#{id}", "#{id}": {}]
|
34
34
|
end
|
35
35
|
|
36
36
|
def hydrate_field(fields, model, resource, view)
|
@@ -41,7 +41,7 @@ module Avo
|
|
41
41
|
delete_text: @delete_text,
|
42
42
|
disable_editing_keys: @disable_editing_keys,
|
43
43
|
disable_adding_rows: @disable_adding_rows,
|
44
|
-
disable_deleting_rows: @disable_deleting_rows
|
44
|
+
disable_deleting_rows: @disable_deleting_rows
|
45
45
|
}
|
46
46
|
end
|
47
47
|
end
|
@@ -3,7 +3,7 @@ module Avo
|
|
3
3
|
class MarkdownField < BaseField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
6
|
+
partial_name: "markdown-field"
|
7
7
|
}
|
8
8
|
|
9
9
|
super(name, **args, &block)
|
@@ -11,7 +11,7 @@ module Avo
|
|
11
11
|
hide_on :index
|
12
12
|
|
13
13
|
@always_show = args[:always_show].present? ? args[:always_show] : false
|
14
|
-
@height = args[:height].present? ? args[:height].to_s :
|
14
|
+
@height = args[:height].present? ? args[:height].to_s : "auto"
|
15
15
|
end
|
16
16
|
|
17
17
|
def hydrate_field(fields, model, resource, view)
|
@@ -3,8 +3,8 @@ module Avo
|
|
3
3
|
class NumberField < TextField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
7
|
-
computable: true
|
6
|
+
partial_name: "number-field",
|
7
|
+
computable: true
|
8
8
|
}
|
9
9
|
|
10
10
|
super(name, **args, &block)
|
@@ -12,7 +12,7 @@ module Avo
|
|
12
12
|
@meta = {
|
13
13
|
min: args[:min].present? ? args[:min].to_f : nil,
|
14
14
|
max: args[:max].present? ? args[:max].to_f : nil,
|
15
|
-
step: args[:step].present? ? args[:step].to_f : nil
|
15
|
+
step: args[:step].present? ? args[:step].to_f : nil
|
16
16
|
}
|
17
17
|
end
|
18
18
|
end
|
@@ -7,7 +7,7 @@ module Avo
|
|
7
7
|
|
8
8
|
def initialize(name, **args, &block)
|
9
9
|
@defaults = {
|
10
|
-
partial_name:
|
10
|
+
partial_name: "select-field"
|
11
11
|
}
|
12
12
|
|
13
13
|
super(name, **args, &block)
|
@@ -16,7 +16,7 @@ module Avo
|
|
16
16
|
@options = ActiveSupport::HashWithIndifferentAccess.new @options
|
17
17
|
@enum = args[:enum].present? ? args[:enum] : nil
|
18
18
|
@display_value = args[:display_value].present? ? args[:display_value] : false
|
19
|
-
@placeholder = args[:placeholder].present? ? args[:placeholder].to_s : I18n.t(
|
19
|
+
@placeholder = args[:placeholder].present? ? args[:placeholder].to_s : I18n.t("avo.choose_an_option")
|
20
20
|
end
|
21
21
|
|
22
22
|
def options_for_select
|
@@ -26,24 +26,20 @@ module Avo
|
|
26
26
|
else
|
27
27
|
options.map { |label, value| [label, label] }.to_h
|
28
28
|
end
|
29
|
+
elsif display_value
|
30
|
+
options.map { |label, value| [value, value] }.to_h
|
29
31
|
else
|
30
|
-
|
31
|
-
options.map { |label, value| [value, value] }.to_h
|
32
|
-
else
|
33
|
-
options
|
34
|
-
end
|
32
|
+
options
|
35
33
|
end
|
36
34
|
end
|
37
35
|
|
38
36
|
def label
|
39
37
|
if display_value
|
40
38
|
value
|
39
|
+
elsif enum.present?
|
40
|
+
options[value]
|
41
41
|
else
|
42
|
-
|
43
|
-
options[value]
|
44
|
-
else
|
45
|
-
options.invert[value]
|
46
|
-
end
|
42
|
+
options.invert[value]
|
47
43
|
end
|
48
44
|
end
|
49
45
|
end
|
@@ -3,7 +3,7 @@ module Avo
|
|
3
3
|
class StatusField < BaseField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
6
|
+
partial_name: "status-field"
|
7
7
|
}
|
8
8
|
|
9
9
|
super(name, **args, &block)
|
@@ -13,10 +13,10 @@ module Avo
|
|
13
13
|
end
|
14
14
|
|
15
15
|
def status
|
16
|
-
status =
|
16
|
+
status = "success"
|
17
17
|
if value.present?
|
18
|
-
status =
|
19
|
-
status =
|
18
|
+
status = "failed" if @failed_when.include? value.to_sym
|
19
|
+
status = "loading" if @loading_when.include? value.to_sym
|
20
20
|
end
|
21
21
|
|
22
22
|
status
|
data/lib/avo/fields_collector.rb
CHANGED
@@ -11,16 +11,15 @@ module Avo
|
|
11
11
|
field[:name].to_s == as.to_s
|
12
12
|
end
|
13
13
|
|
14
|
-
if matched_field.present?
|
14
|
+
if matched_field.present? && matched_field[:class].present?
|
15
15
|
klass = matched_field[:class]
|
16
16
|
|
17
|
-
if
|
18
|
-
|
17
|
+
if block
|
18
|
+
klass.new(field_name, **args || {}, &block)
|
19
19
|
else
|
20
|
-
|
20
|
+
klass.new(field_name, **args || {})
|
21
21
|
end
|
22
22
|
|
23
|
-
field
|
24
23
|
end
|
25
24
|
end
|
26
25
|
|
@@ -1,19 +1,19 @@
|
|
1
1
|
module Avo
|
2
2
|
module Filters
|
3
3
|
class BaseFilter
|
4
|
-
class_attribute :name, default:
|
5
|
-
class_attribute :component, default:
|
6
|
-
class_attribute :default, default:
|
7
|
-
class_attribute :template, default:
|
4
|
+
class_attribute :name, default: "Filter"
|
5
|
+
class_attribute :component, default: "boolean-filter"
|
6
|
+
class_attribute :default, default: ""
|
7
|
+
class_attribute :template, default: "avo/base/select_filter"
|
8
8
|
|
9
9
|
def apply_query(request, query, value)
|
10
10
|
value.symbolize_keys! if value.is_a? Hash
|
11
11
|
|
12
|
-
|
12
|
+
apply(request, query, value)
|
13
13
|
end
|
14
14
|
|
15
15
|
def id
|
16
|
-
self.class.name.underscore.
|
16
|
+
self.class.name.underscore.tr("/", "_")
|
17
17
|
end
|
18
18
|
end
|
19
19
|
end
|
data/lib/avo/licensing/h_q.rb
CHANGED
@@ -3,8 +3,8 @@ module Avo
|
|
3
3
|
class HQ
|
4
4
|
attr_accessor :current_request
|
5
5
|
|
6
|
-
ENDPOINT =
|
7
|
-
CACHE_KEY =
|
6
|
+
ENDPOINT = "https://avohq.io/api/v1/licenses/check" unless const_defined?(:ENDPOINT)
|
7
|
+
CACHE_KEY = "avo.hq.response" unless const_defined?(:CACHE_KEY)
|
8
8
|
REQUEST_TIMEOUT = 5 unless const_defined?(:REQUEST_TIMEOUT) # seconds
|
9
9
|
|
10
10
|
def initialize(current_request)
|
@@ -13,76 +13,77 @@ module Avo
|
|
13
13
|
end
|
14
14
|
|
15
15
|
def response
|
16
|
-
@hq_response
|
16
|
+
@hq_response || request
|
17
17
|
end
|
18
18
|
|
19
19
|
private
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
20
|
+
|
21
|
+
def request
|
22
|
+
return cached_response if has_cached_response
|
23
|
+
|
24
|
+
begin
|
25
|
+
perform_and_cache_request
|
26
|
+
rescue HTTParty::Error => exception
|
27
|
+
cache_and_return_error "HTTP client error.", exception.message
|
28
|
+
rescue Net::OpenTimeout => exception
|
29
|
+
cache_and_return_error "Request timeout.", exception.message
|
30
|
+
rescue SocketError => exception
|
31
|
+
cache_and_return_error "Connection error.", exception.message
|
32
32
|
end
|
33
|
+
end
|
33
34
|
|
34
|
-
|
35
|
-
|
35
|
+
def perform_and_cache_request
|
36
|
+
hq_response = perform_request
|
36
37
|
|
37
|
-
|
38
|
+
return cache_and_return_error "Avo HQ Internal server error.", hq_response.body if hq_response.code == 500
|
38
39
|
|
39
|
-
|
40
|
-
|
40
|
+
cache_response 1.hour.to_i, hq_response.parsed_response if hq_response.code == 200
|
41
|
+
end
|
41
42
|
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
43
|
+
def cache_response(time, response)
|
44
|
+
response.merge!(
|
45
|
+
expiry: time,
|
46
|
+
**payload
|
47
|
+
).stringify_keys!
|
47
48
|
|
48
|
-
|
49
|
+
@cache_store.write(CACHE_KEY, response, expires_in: time)
|
49
50
|
|
50
|
-
|
51
|
+
@hq_response = response
|
51
52
|
|
52
|
-
|
53
|
-
|
53
|
+
response
|
54
|
+
end
|
54
55
|
|
55
|
-
|
56
|
-
|
56
|
+
def perform_request
|
57
|
+
puts "Performing request to avohq.io API to check license availability.".inspect if Rails.env.development?
|
57
58
|
|
58
|
-
|
59
|
-
|
59
|
+
HTTParty.post ENDPOINT, body: payload.to_json, headers: {'Content-type': "application/json"}, timeout: REQUEST_TIMEOUT
|
60
|
+
end
|
60
61
|
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
62
|
+
def payload
|
63
|
+
{
|
64
|
+
license: Avo.configuration.license,
|
65
|
+
license_key: Avo.configuration.license_key,
|
66
|
+
avo_version: Avo::VERSION,
|
67
|
+
rails_version: Rails::VERSION::STRING,
|
68
|
+
ruby_version: RUBY_VERSION,
|
69
|
+
environment: Rails.env,
|
70
|
+
ip: current_request.ip,
|
71
|
+
host: current_request.host,
|
72
|
+
port: current_request.port
|
73
|
+
}
|
74
|
+
end
|
74
75
|
|
75
|
-
|
76
|
-
|
77
|
-
|
76
|
+
def cache_and_return_error(error, exception_message = "")
|
77
|
+
cache_response 5.minutes.to_i, {error: error, exception_message: exception_message}.stringify_keys
|
78
|
+
end
|
78
79
|
|
79
|
-
|
80
|
-
|
81
|
-
|
80
|
+
def has_cached_response
|
81
|
+
@cache_store.exist? CACHE_KEY
|
82
|
+
end
|
82
83
|
|
83
|
-
|
84
|
-
|
85
|
-
|
84
|
+
def cached_response
|
85
|
+
@cache_store.read CACHE_KEY
|
86
|
+
end
|
86
87
|
end
|
87
88
|
end
|
88
89
|
end
|
@@ -7,8 +7,8 @@ module Avo
|
|
7
7
|
|
8
8
|
def initialize(response)
|
9
9
|
@response = response
|
10
|
-
@id = response[
|
11
|
-
@valid = response[
|
10
|
+
@id = response["id"]
|
11
|
+
@valid = response["valid"]
|
12
12
|
end
|
13
13
|
|
14
14
|
def valid?
|
@@ -20,15 +20,15 @@ module Avo
|
|
20
20
|
end
|
21
21
|
|
22
22
|
def pro?
|
23
|
-
id ==
|
23
|
+
id == "pro"
|
24
24
|
end
|
25
25
|
|
26
26
|
def error
|
27
|
-
@response[
|
27
|
+
@response["error"]
|
28
28
|
end
|
29
29
|
|
30
30
|
def properties
|
31
|
-
@response.slice(
|
31
|
+
@response.slice("valid", "id", "error").symbolize_keys
|
32
32
|
end
|
33
33
|
|
34
34
|
def abilities
|