avo 0.5.0.beta8 → 0.5.0.beta13
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 +46 -50
- data/Gemfile.lock +3 -8
- 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/edit/fields/trix_field_component.html.erb +1 -1
- 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 -4
- data/app/packs/images/logo.png +0 -0
- 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/app/packs/stylesheets/components/code.css +0 -16
- data/avo.gemspec +30 -31
- data/bin/webpack +1 -0
- data/config/initializers/pagy.rb +1 -1
- data/config/routes.rb +12 -12
- data/config/spring.rb +5 -5
- data/config/webpack/base.js +3 -3
- data/config/webpacker.yml +32 -0
- 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 +25 -26
- 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/generators/avo/templates/action.tt +0 -4
- data/lib/generators/avo/templates/resource/resource.tt +3 -13
- data/lib/tasks/avo_tasks.rake +0 -60
- data/public/avo-packs/css/{application-5bb09ba4.css → application-9d115b7e.css} +124 -276
- data/public/avo-packs/css/application-9d115b7e.css.br +0 -0
- data/public/avo-packs/css/application-9d115b7e.css.gz +0 -0
- data/public/avo-packs/css/application-9d115b7e.css.map +1 -0
- data/public/avo-packs/css/application-9d115b7e.css.map.br +0 -0
- data/public/avo-packs/css/application-9d115b7e.css.map.gz +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js +26 -0
- data/public/avo-packs/js/{application-86a3ea5a835b0c758203.js.LICENSE.txt → application-4751feac1bb0404b9c47.js.LICENSE.txt} +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.br +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.gz +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.map +1 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.map.br +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.map.gz +0 -0
- data/public/avo-packs/manifest.json +16 -16
- data/public/avo-packs/media/images/dadf2db36589607d107d.png +0 -0
- metadata +16 -31
- data/config/initializers/inline_svg.rb +0 -33
- data/public/avo-packs/css/application-5bb09ba4.css.br +0 -0
- data/public/avo-packs/css/application-5bb09ba4.css.gz +0 -0
- data/public/avo-packs/css/application-5bb09ba4.css.map +0 -1
- data/public/avo-packs/css/application-5bb09ba4.css.map.br +0 -0
- data/public/avo-packs/css/application-5bb09ba4.css.map.gz +0 -0
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js +0 -26
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.br +0 -0
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.gz +0 -0
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.map +0 -1
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.map.br +0 -0
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.map.gz +0 -0
- data/public/avo-packs/media/images/f1b4befac91a3336db9a.png +0 -0
data/lib/avo/engine.rb
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
# requires all dependencies
|
2
|
-
Gem.loaded_specs[
|
2
|
+
Gem.loaded_specs["avo"].dependencies.each do |d|
|
3
3
|
require d.name
|
4
4
|
end
|
5
|
-
require
|
5
|
+
require "view_component/engine"
|
6
6
|
|
7
7
|
module Avo
|
8
8
|
class Engine < ::Rails::Engine
|
@@ -13,42 +13,42 @@ module Avo
|
|
13
13
|
::Avo::App.boot
|
14
14
|
end
|
15
15
|
|
16
|
-
initializer
|
17
|
-
Rails.autoloaders.main.push_dir(Rails.root.join(
|
18
|
-
Rails.autoloaders.main.push_dir(Rails.root.join(
|
19
|
-
Rails.autoloaders.main.push_dir(Rails.root.join(
|
16
|
+
initializer "avo.autoload", before: :set_autoload_paths do |app|
|
17
|
+
Rails.autoloaders.main.push_dir(Rails.root.join("app", "avo", "filters"))
|
18
|
+
Rails.autoloaders.main.push_dir(Rails.root.join("app", "avo", "actions"))
|
19
|
+
Rails.autoloaders.main.push_dir(Rails.root.join("app", "avo", "resources"))
|
20
20
|
end
|
21
21
|
|
22
|
-
initializer
|
22
|
+
initializer "avo.init_fields" do |app|
|
23
23
|
# Init the fields
|
24
24
|
::Avo::App.init_fields
|
25
25
|
end
|
26
26
|
|
27
|
-
initializer
|
28
|
-
if Avo::IN_DEVELOPMENT && ENV[
|
27
|
+
initializer "avo.reload_avo_files" do |app|
|
28
|
+
if Avo::IN_DEVELOPMENT && ENV["RELOAD_AVO_FILES"]
|
29
29
|
avo_root_path = Avo::Engine.root.to_s
|
30
30
|
# Register reloader
|
31
31
|
app.reloaders << app.config.file_watcher.new([], {
|
32
|
-
Avo::Engine.root.join(
|
32
|
+
Avo::Engine.root.join("lib", "avo").to_s => ["rb"]
|
33
33
|
}) {}
|
34
34
|
|
35
35
|
# What to do on file change
|
36
36
|
config.to_prepare do
|
37
|
-
Dir.glob(avo_root_path +
|
37
|
+
Dir.glob(avo_root_path + "/lib/avo/**/*.rb".to_s).each { |c| load c }
|
38
38
|
Avo::App.boot
|
39
39
|
end
|
40
40
|
end
|
41
41
|
end
|
42
42
|
|
43
|
-
initializer
|
43
|
+
initializer "webpacker.proxy" do |app|
|
44
44
|
app.config.debug_exception_response_format = :api
|
45
45
|
# app.config.logger = ::Logger.new(STDOUT)
|
46
46
|
|
47
47
|
insert_middleware = begin
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
48
|
+
Avo.webpacker.config.dev_server.present?
|
49
|
+
rescue
|
50
|
+
nil
|
51
|
+
end
|
52
52
|
|
53
53
|
if insert_middleware
|
54
54
|
app.middleware.insert_before(
|
@@ -61,8 +61,8 @@ module Avo
|
|
61
61
|
|
62
62
|
config.app_middleware.use(
|
63
63
|
Rack::Static,
|
64
|
-
urls: [
|
65
|
-
root: Avo::Engine.root.join(
|
64
|
+
urls: ["/avo-packs"],
|
65
|
+
root: Avo::Engine.root.join("public")
|
66
66
|
)
|
67
67
|
|
68
68
|
config.generators do |g|
|
@@ -3,14 +3,14 @@ module Avo
|
|
3
3
|
class BadgeField < BaseField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
6
|
+
partial_name: "badge-field"
|
7
7
|
}
|
8
8
|
|
9
9
|
super(name, **args, &block)
|
10
10
|
|
11
11
|
hide_on [:edit, :new]
|
12
12
|
|
13
|
-
default_options = {
|
13
|
+
default_options = {info: :info, success: :success, danger: :danger, warning: :warning}
|
14
14
|
@meta[:options] = args[:options].present? ? default_options.merge(args[:options]) : default_options
|
15
15
|
end
|
16
16
|
end
|
@@ -44,14 +44,14 @@ module Avo
|
|
44
44
|
|
45
45
|
args = @defaults.merge(args).symbolize_keys
|
46
46
|
|
47
|
-
null_values = [nil,
|
47
|
+
null_values = [nil, "", *args[:null_values]]
|
48
48
|
# The field properties as a hash {property: default_value}
|
49
49
|
@field_properties = {
|
50
50
|
id: id,
|
51
51
|
name: id.to_s.humanize(keep_id_suffix: true),
|
52
52
|
translation_key: nil,
|
53
53
|
block: block,
|
54
|
-
partial_name:
|
54
|
+
partial_name: "field",
|
55
55
|
required: false,
|
56
56
|
readonly: false,
|
57
57
|
updatable: true,
|
@@ -67,7 +67,7 @@ module Avo
|
|
67
67
|
default: nil,
|
68
68
|
visible: true,
|
69
69
|
meta: {},
|
70
|
-
panel_name: nil
|
70
|
+
panel_name: nil
|
71
71
|
}
|
72
72
|
|
73
73
|
# Set the values in the following order
|
@@ -76,7 +76,7 @@ module Avo
|
|
76
76
|
# - field option
|
77
77
|
@field_properties.each do |name, default_value|
|
78
78
|
final_value = args[name.to_sym]
|
79
|
-
|
79
|
+
send("#{name}=", name != "null_values" && (final_value.nil? || !defined?(final_value)) ? default_value : final_value)
|
80
80
|
end
|
81
81
|
|
82
82
|
# Set the visibility
|
@@ -102,8 +102,8 @@ module Avo
|
|
102
102
|
end
|
103
103
|
|
104
104
|
def visible?
|
105
|
-
if visible.present?
|
106
|
-
visible.call
|
105
|
+
if visible.present? && visible.respond_to?(:call)
|
106
|
+
visible.call resource: resource
|
107
107
|
else
|
108
108
|
visible
|
109
109
|
end
|
@@ -111,18 +111,18 @@ module Avo
|
|
111
111
|
|
112
112
|
def value
|
113
113
|
# Get model value
|
114
|
-
final_value = @model.send(id) if model_or_class(@model) ==
|
114
|
+
final_value = @model.send(id) if (model_or_class(@model) == "model") && @model.respond_to?(id)
|
115
115
|
|
116
|
-
if @view === :new
|
117
|
-
if default.present?
|
118
|
-
|
116
|
+
if (@view === :new) || @action.present?
|
117
|
+
final_value = if default.present? && default.respond_to?(:call)
|
118
|
+
default.call
|
119
119
|
else
|
120
|
-
|
120
|
+
default
|
121
121
|
end
|
122
122
|
end
|
123
123
|
|
124
124
|
# Run callback block if present
|
125
|
-
if computable
|
125
|
+
if computable && block.present?
|
126
126
|
final_value = block.call @model, @resource, @view, self
|
127
127
|
end
|
128
128
|
|
@@ -141,18 +141,16 @@ module Avo
|
|
141
141
|
end
|
142
142
|
|
143
143
|
def partial_path_for(view)
|
144
|
-
return @custom_partials[view] if @custom_partials.present?
|
144
|
+
return @custom_partials[view] if @custom_partials.present? && @custom_partials[view].present?
|
145
145
|
|
146
146
|
"avo/fields/#{view}/#{partial_name}"
|
147
147
|
end
|
148
148
|
|
149
149
|
# Try to see if the field has a different database ID than it's name
|
150
150
|
def database_id(model)
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
id
|
155
|
-
end
|
151
|
+
foreign_key
|
152
|
+
rescue
|
153
|
+
id
|
156
154
|
end
|
157
155
|
|
158
156
|
def has_own_panel?
|
@@ -168,7 +166,7 @@ module Avo
|
|
168
166
|
end
|
169
167
|
|
170
168
|
def component_name(view = :index)
|
171
|
-
"Avo::#{view.to_s.classify}::Fields::#{partial_name.gsub(
|
169
|
+
"Avo::#{view.to_s.classify}::Fields::#{partial_name.gsub("-field", "").underscore.camelize}FieldComponent"
|
172
170
|
end
|
173
171
|
|
174
172
|
def model_errors
|
@@ -178,17 +176,18 @@ module Avo
|
|
178
176
|
end
|
179
177
|
|
180
178
|
def type
|
181
|
-
self.class.name.demodulize.to_s.underscore.gsub(
|
179
|
+
self.class.name.demodulize.to_s.underscore.gsub("_field", "")
|
182
180
|
end
|
183
181
|
|
184
182
|
private
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
183
|
+
|
184
|
+
def model_or_class(model)
|
185
|
+
if model.instance_of?(String)
|
186
|
+
"class"
|
187
|
+
else
|
188
|
+
"model"
|
191
189
|
end
|
190
|
+
end
|
192
191
|
end
|
193
192
|
end
|
194
193
|
end
|
@@ -3,13 +3,13 @@ module Avo
|
|
3
3
|
class BelongsToField < BaseField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
7
|
-
placeholder: I18n.t(
|
6
|
+
partial_name: "belongs-to-field",
|
7
|
+
placeholder: I18n.t("avo.choose_an_option")
|
8
8
|
}
|
9
9
|
|
10
10
|
super(name, **args, &block)
|
11
11
|
|
12
|
-
@meta[:searchable] = args[:searchable] == true
|
12
|
+
@meta[:searchable] = args[:searchable] == true
|
13
13
|
@meta[:relation_method] = name.to_s.parameterize.underscore
|
14
14
|
end
|
15
15
|
|
@@ -28,7 +28,7 @@ module Avo
|
|
28
28
|
|
29
29
|
def foreign_key
|
30
30
|
if @model.present?
|
31
|
-
if @model.
|
31
|
+
if @model.instance_of?(Class)
|
32
32
|
@model.reflections[@meta[:relation_method]].foreign_key
|
33
33
|
else
|
34
34
|
@model.class.reflections[@meta[:relation_method]].foreign_key
|
@@ -51,15 +51,16 @@ module Avo
|
|
51
51
|
end
|
52
52
|
|
53
53
|
private
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
54
|
+
|
55
|
+
def target_resource
|
56
|
+
if @model._reflections[id.to_s].klass.present?
|
57
|
+
App.get_resource_by_model_name @model._reflections[id.to_s].klass.to_s
|
58
|
+
elsif @model._reflections[id.to_s].options[:class_name].present?
|
59
|
+
App.get_resource_by_model_name @model._reflections[id.to_s].options[:class_name]
|
60
|
+
else
|
61
|
+
App.get_resource_by_name id.to_s
|
62
62
|
end
|
63
|
+
end
|
63
64
|
end
|
64
65
|
end
|
65
66
|
end
|
@@ -6,8 +6,8 @@ module Avo
|
|
6
6
|
|
7
7
|
def initialize(name, **args, &block)
|
8
8
|
@defaults = {
|
9
|
-
partial_name:
|
10
|
-
computable: true
|
9
|
+
partial_name: "boolean-field",
|
10
|
+
computable: true
|
11
11
|
}
|
12
12
|
|
13
13
|
super(name, **args, &block)
|
@@ -25,11 +25,11 @@ module Avo
|
|
25
25
|
end
|
26
26
|
|
27
27
|
def truthy_values
|
28
|
-
[
|
28
|
+
["true", "1", @true_value]
|
29
29
|
end
|
30
30
|
|
31
31
|
def falsy_values
|
32
|
-
[
|
32
|
+
["false", "0", @false_value]
|
33
33
|
end
|
34
34
|
end
|
35
35
|
end
|
@@ -5,8 +5,8 @@ module Avo
|
|
5
5
|
|
6
6
|
def initialize(name, **args, &block)
|
7
7
|
@defaults = {
|
8
|
-
partial_name:
|
9
|
-
computable: true
|
8
|
+
partial_name: "boolean-group-field",
|
9
|
+
computable: true
|
10
10
|
}
|
11
11
|
|
12
12
|
super(name, **args, &block)
|
@@ -15,7 +15,7 @@ module Avo
|
|
15
15
|
end
|
16
16
|
|
17
17
|
def to_permitted_param
|
18
|
-
["#{id}": []
|
18
|
+
["#{id}": []]
|
19
19
|
end
|
20
20
|
|
21
21
|
def fill_field(model, key, value)
|
@@ -10,16 +10,16 @@ module Avo
|
|
10
10
|
|
11
11
|
def initialize(name, **args, &block)
|
12
12
|
@defaults = {
|
13
|
-
partial_name:
|
13
|
+
partial_name: "code-field"
|
14
14
|
}
|
15
15
|
|
16
16
|
hide_on :index
|
17
17
|
|
18
18
|
super(name, **args, &block)
|
19
19
|
|
20
|
-
@language = args[:language].present? ? args[:language].to_s :
|
21
|
-
@theme = args[:theme].present? ? args[:theme].to_s :
|
22
|
-
@height = args[:height].present? ? args[:height].to_s :
|
20
|
+
@language = args[:language].present? ? args[:language].to_s : "javascript"
|
21
|
+
@theme = args[:theme].present? ? args[:theme].to_s : "material-darker"
|
22
|
+
@height = args[:height].present? ? args[:height].to_s : "auto"
|
23
23
|
@tab_size = args[:tab_size].present? ? args[:tab_size] : 2
|
24
24
|
@indent_with_tabs = args[:indent_with_tabs].present? ? args[:indent_with_tabs] : false
|
25
25
|
@line_wrapping = args[:line_wrapping].present? ? args[:line_wrapping] : true
|
@@ -6,8 +6,8 @@ module Avo
|
|
6
6
|
|
7
7
|
def initialize(name, **args, &block)
|
8
8
|
@defaults = {
|
9
|
-
partial_name:
|
10
|
-
placeholder: I18n.t(
|
9
|
+
partial_name: "country-field",
|
10
|
+
placeholder: I18n.t("avo.choose_a_country")
|
11
11
|
}
|
12
12
|
|
13
13
|
super(name, **args, &block)
|
@@ -3,8 +3,8 @@ module Avo
|
|
3
3
|
class CurrencyField < BaseField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
7
|
-
computable: true
|
6
|
+
partial_name: "currency-field",
|
7
|
+
computable: true
|
8
8
|
}
|
9
9
|
|
10
10
|
super(name, **args, &block)
|
@@ -16,7 +16,7 @@ module Avo
|
|
16
16
|
def hydrate_field(fields, model, resource, view)
|
17
17
|
{
|
18
18
|
currency: @currency,
|
19
|
-
locale: @locale
|
19
|
+
locale: @locale
|
20
20
|
}
|
21
21
|
end
|
22
22
|
end
|
@@ -9,15 +9,15 @@ module Avo
|
|
9
9
|
|
10
10
|
def initialize(name, **args, &block)
|
11
11
|
@defaults = {
|
12
|
-
partial_name:
|
12
|
+
partial_name: "date-field"
|
13
13
|
}
|
14
14
|
|
15
15
|
super(name, **args, &block)
|
16
16
|
|
17
17
|
@first_day_of_week = args[:first_day_of_week].present? ? args[:first_day_of_week].to_i : 0
|
18
|
-
@picker_format = args[:picker_format].present? ? args[:picker_format] :
|
18
|
+
@picker_format = args[:picker_format].present? ? args[:picker_format] : "Y-m-d"
|
19
19
|
@format = args[:format].present? ? args[:format] : :long
|
20
|
-
@placeholder = args[:placeholder].present? ? args[:placeholder] :
|
20
|
+
@placeholder = args[:placeholder].present? ? args[:placeholder] : ""
|
21
21
|
@relative = args[:relative].present? ? args[:relative] : false
|
22
22
|
end
|
23
23
|
|
@@ -8,8 +8,8 @@ module Avo
|
|
8
8
|
def initialize(name, **args, &block)
|
9
9
|
super(name, **args, &block)
|
10
10
|
|
11
|
-
@partial_name =
|
12
|
-
@picker_format = args[:picker_format].present? ? args[:picker_format] :
|
11
|
+
@partial_name = "date-time-field"
|
12
|
+
@picker_format = args[:picker_format].present? ? args[:picker_format] : "Y-m-d H:i:S"
|
13
13
|
@time_24hr = args[:time_24hr].present? ? args[:time_24hr] : false
|
14
14
|
@timezone = args[:timezone].present? ? args[:timezone] : Rails.application.config.time_zone
|
15
15
|
end
|
@@ -9,9 +9,9 @@ module Avo
|
|
9
9
|
|
10
10
|
# Get the field name
|
11
11
|
def get_field_name
|
12
|
-
return
|
12
|
+
return field_name_attribute if field_name_attribute.present?
|
13
13
|
|
14
|
-
|
14
|
+
to_s.demodulize.underscore.gsub "_field", ""
|
15
15
|
end
|
16
16
|
end
|
17
17
|
end
|
@@ -45,48 +45,49 @@ module Avo
|
|
45
45
|
end
|
46
46
|
|
47
47
|
private
|
48
|
-
def show_on_view(view)
|
49
|
-
self.send("show_on_#{view.to_s}=", true)
|
50
|
-
end
|
51
48
|
|
52
|
-
|
53
|
-
|
54
|
-
|
49
|
+
def show_on_view(view)
|
50
|
+
send("show_on_#{view}=", true)
|
51
|
+
end
|
55
52
|
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
end
|
53
|
+
def hide_on_view(view)
|
54
|
+
send("show_on_#{view}=", false)
|
55
|
+
end
|
60
56
|
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
57
|
+
def only_on_view(view)
|
58
|
+
hide_on_all
|
59
|
+
show_on_view view
|
60
|
+
end
|
65
61
|
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
@show_on_new = true
|
71
|
-
end
|
62
|
+
def except_on_view(view)
|
63
|
+
show_on_all
|
64
|
+
hide_on_view view
|
65
|
+
end
|
72
66
|
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
67
|
+
def show_on_all
|
68
|
+
@show_on_index = true
|
69
|
+
@show_on_show = true
|
70
|
+
@show_on_edit = true
|
71
|
+
@show_on_new = true
|
72
|
+
end
|
79
73
|
|
80
|
-
|
81
|
-
|
74
|
+
def hide_on_all
|
75
|
+
@show_on_index = false
|
76
|
+
@show_on_show = false
|
77
|
+
@show_on_edit = false
|
78
|
+
@show_on_new = false
|
79
|
+
end
|
82
80
|
|
83
|
-
|
84
|
-
|
85
|
-
views_and_groups = views_and_groups + [:new, :edit]
|
86
|
-
end
|
81
|
+
def normalize_views(*views_and_groups)
|
82
|
+
forms = views_and_groups.flatten! & [:forms]
|
87
83
|
|
88
|
-
|
84
|
+
if forms.present?
|
85
|
+
views_and_groups -= forms
|
86
|
+
views_and_groups += [:new, :edit]
|
89
87
|
end
|
88
|
+
|
89
|
+
views_and_groups.flatten.uniq
|
90
|
+
end
|
90
91
|
end
|
91
92
|
end
|
92
93
|
end
|