five-two-nw-olivander 0.1.2.1 → 0.1.2.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/controllers/concerns/olivander/resources/auto_form_attributes.rb +13 -0
- data/app/controllers/concerns/olivander/resources/route_builder.rb +129 -0
- data/app/helpers/olivander/application_helper.rb +17 -0
- data/app/views/application/_form.html.haml +17 -0
- data/app/views/application/edit.html.haml +2 -6
- data/app/views/application/index.html.haml +4 -3
- data/app/views/application/new.html.haml +0 -6
- data/app/views/application/show.html.haml +2 -8
- data/app/views/effective/resource/_actions_dropleft.html.haml +3 -0
- data/app/views/layouts/olivander/adminlte/_head.html.haml +1 -1
- data/app/views/layouts/olivander/adminlte/_sidebar.html.haml +35 -0
- data/config/initializers/simple_form.rb +176 -0
- data/config/locales/simple_form.en.yml +31 -0
- data/lib/five-two-nw-olivander.rb +1 -0
- data/lib/olivander/application_context.rb +1 -1
- data/lib/olivander/version.rb +1 -1
- data/lib/templates/erb/scaffold/_form.html.haml +8 -0
- metadata +9 -6
- data/app/controllers/olivander/resources/crud_chain.rb +0 -119
- data/app/controllers/olivander/resources/crud_controller.rb +0 -55
- data/app/controllers/olivander/resources/default_crud_chain.rb +0 -48
- data/app/controllers/olivander/test_controller.rb +0 -35
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 597764e454652e4a42b1d81c7d63db17f9495a662886fd9184c7fc3790d16c75
|
4
|
+
data.tar.gz: faa979538cb5fa01390a65e0378054b3f916b3f3630ac45e586ff64fb43e9ffa
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: b1d0847e4694082bcbf22f3717f4ea551f1144697b51e809539118402f347e46158767a8fdca8eab49b1262dde97e09ad964f8722b0d3701cfbfe3789478da34
|
7
|
+
data.tar.gz: 92df52efda623339deb45a35ad86c5a52e0205ba5eb49e71aa70d5683eb2df079825531407f58634c0970c0a6802b8c62081e6c910fdedd494dec4a88fbd90a6
|
@@ -0,0 +1,129 @@
|
|
1
|
+
module Olivander
|
2
|
+
module Resources
|
3
|
+
class ResourceAction
|
4
|
+
attr_accessor :sym, :action, :verb, :confirm, :turbo_frame, :collection, :controller, :crud_action, :show_in_form, :show_in_datatable, :no_route
|
5
|
+
|
6
|
+
def initialize(sym, action: nil, controller: nil, verb: :get, confirm: false, turbo_frame: nil, collection: false, crud_action: false,
|
7
|
+
show_in_form: true, show_in_datatable: true, no_route: false)
|
8
|
+
self.sym = sym
|
9
|
+
self.action = action || sym
|
10
|
+
self.controller = controller
|
11
|
+
self.verb = verb
|
12
|
+
self.confirm = confirm
|
13
|
+
self.turbo_frame = turbo_frame
|
14
|
+
self.collection = collection
|
15
|
+
self.crud_action = crud_action
|
16
|
+
self.show_in_form = show_in_form
|
17
|
+
self.show_in_datatable = show_in_datatable
|
18
|
+
self.no_route = no_route
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
class RoutedResource
|
23
|
+
attr_accessor :model, :actions
|
24
|
+
|
25
|
+
def initialize(model, crud_actions)
|
26
|
+
self.model = model
|
27
|
+
self.actions = []
|
28
|
+
crud_actions.each do |ca|
|
29
|
+
actions << ResourceAction.new(ca, controller: model, crud_action: true)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
def crud_actions
|
34
|
+
actions.select{ |x| x.crud_action }
|
35
|
+
end
|
36
|
+
|
37
|
+
def additional_actions
|
38
|
+
actions.select{ |x| !x.crud_action }
|
39
|
+
end
|
40
|
+
|
41
|
+
def member_actions
|
42
|
+
additional_actions.select{ |x| !x.collection }
|
43
|
+
end
|
44
|
+
|
45
|
+
def collection_actions
|
46
|
+
additional_actions.select{ |x| x.collection }
|
47
|
+
end
|
48
|
+
|
49
|
+
def datatable_bulk_actions
|
50
|
+
collection_actions.select{ |x| x.show_in_datatable }
|
51
|
+
end
|
52
|
+
|
53
|
+
def unpersisted_crud_actions
|
54
|
+
allowed = %i[index new]
|
55
|
+
crud_actions.select{ |x| allowed.include?(x.sym) }
|
56
|
+
end
|
57
|
+
|
58
|
+
def persisted_crud_actions
|
59
|
+
allowed = %i[show edit destroy]
|
60
|
+
crud_actions.select{ |x| allowed.include?(x.sym) }
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
module RouteBuilder
|
65
|
+
extend ActiveSupport::Concern
|
66
|
+
|
67
|
+
DEFAULT_CRUD_ACTIONS = %i[index new create show edit update destroy]
|
68
|
+
|
69
|
+
included do
|
70
|
+
class_attribute :resources, default: {}
|
71
|
+
class_attribute :current_resource
|
72
|
+
end
|
73
|
+
|
74
|
+
class_methods do
|
75
|
+
def resource(model, only: DEFAULT_CRUD_ACTIONS, except: [], &block)
|
76
|
+
self.current_resource = RoutedResource.new(model, DEFAULT_CRUD_ACTIONS & (only - except))
|
77
|
+
yield if block_given?
|
78
|
+
resources[model] = current_resource
|
79
|
+
self.current_resource = nil
|
80
|
+
end
|
81
|
+
|
82
|
+
def action(sym, verb: :get, confirm: false, turbo_frame: nil, collection: false, show_in_datatable: true, show_in_form: true, no_route: false, controller: nil, action: nil)
|
83
|
+
raise 'Must be invoked in a resource block' unless current_resource.present?
|
84
|
+
|
85
|
+
controller ||= current_resource.model
|
86
|
+
current_resource.actions << ResourceAction.new(
|
87
|
+
sym, action: action, controller: controller, verb: verb, confirm: confirm, turbo_frame: turbo_frame, collection: collection,
|
88
|
+
show_in_datatable: show_in_datatable, show_in_form: show_in_form, no_route: no_route
|
89
|
+
)
|
90
|
+
end
|
91
|
+
|
92
|
+
def build_routes(mapper)
|
93
|
+
build_resource_routes(mapper)
|
94
|
+
end
|
95
|
+
|
96
|
+
def build_resource_routes(mapper)
|
97
|
+
resources.keys.each do |k|
|
98
|
+
r = resources[k]
|
99
|
+
mapper.resources r.model, only: r.crud_actions.map{ |ca| ca.action } do
|
100
|
+
mapper.member do
|
101
|
+
r.member_actions.each do |ma|
|
102
|
+
next if ma.no_route
|
103
|
+
if ma.confirm
|
104
|
+
mapper.get ma.action, action: "confirm_#{ma.action}"
|
105
|
+
mapper.post ma.action
|
106
|
+
else
|
107
|
+
mapper.send(ma.verb, ma.action)
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
111
|
+
|
112
|
+
mapper.collection do
|
113
|
+
r.collection_actions.each do |ba|
|
114
|
+
next if ba.no_route
|
115
|
+
if ba.confirm
|
116
|
+
mapper.get ba.action, action: "confirm_#{ba.action}"
|
117
|
+
mapper.post ba.action
|
118
|
+
else
|
119
|
+
mapper.send(ma.verb, ba.action)
|
120
|
+
end
|
121
|
+
end
|
122
|
+
end
|
123
|
+
end
|
124
|
+
end
|
125
|
+
end
|
126
|
+
end
|
127
|
+
end
|
128
|
+
end
|
129
|
+
end
|
@@ -16,5 +16,22 @@ module Olivander
|
|
16
16
|
def user_image_path(user)
|
17
17
|
"avatar#{SecureRandom.random_number(4)}.png"
|
18
18
|
end
|
19
|
+
|
20
|
+
def authorized_resource_actions(resource, for_action: :show)
|
21
|
+
plural_name = resource.is_a?(Class) ? resource.table_name : resource.class.table_name
|
22
|
+
routed_resource = @context.route_builder.resources[plural_name.to_sym]
|
23
|
+
actions = resource.is_a?(Class) ?
|
24
|
+
(routed_resource.unpersisted_crud_actions | routed_resource.collection_actions) :
|
25
|
+
(resource.persisted? ? (routed_resource.persisted_crud_actions | routed_resource.member_actions): [])
|
26
|
+
actions.reject{ |a| a.sym == for_action }
|
27
|
+
end
|
28
|
+
|
29
|
+
def resource_form_actions(resource, for_action: :show)
|
30
|
+
[].tap do |output|
|
31
|
+
authorized_resource_actions(resource, for_action: for_action).select{ |x| x.show_in_form }.each do |a|
|
32
|
+
output << link_to(a.sym, {controller: a.controller, action: a.action}, method: a.verb, class: 'btn btn-primary', data: { turbo: true })
|
33
|
+
end
|
34
|
+
end.join(' ').html_safe
|
35
|
+
end
|
19
36
|
end
|
20
37
|
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
- read_only = action_name != 'edit'
|
2
|
+
= simple_form_for(@resource) do |f|
|
3
|
+
.card
|
4
|
+
.card-header
|
5
|
+
.card-tools
|
6
|
+
= resource_form_actions(@resource, for_action: action_name.to_sym)
|
7
|
+
.card-body
|
8
|
+
=f.error_notification
|
9
|
+
=f.error_notification message: f.object.errors[:base].to_sentence if f.object.errors[:base].present?
|
10
|
+
- @resource.auto_form_attributes.each do |a|
|
11
|
+
.row
|
12
|
+
.col-12
|
13
|
+
= f.input a, disabled: read_only
|
14
|
+
.card-footer.text-right
|
15
|
+
= link_to 'Cancel', @_effective_resource.action_path(:index), class: 'btn btn-secondary'
|
16
|
+
- unless read_only
|
17
|
+
= f.button :submit, class: 'btn btn-primary'
|
@@ -4,7 +4,9 @@
|
|
4
4
|
.col-12
|
5
5
|
.card
|
6
6
|
.card-header
|
7
|
-
%
|
7
|
+
%h3.card-title= @page_title
|
8
|
+
.card-tools
|
9
|
+
= resource_form_actions(resource.klass, for_action: :index)
|
8
10
|
.card-body
|
9
11
|
- if @datatable
|
10
12
|
= render_datatable(@datatable)
|
@@ -19,6 +21,5 @@
|
|
19
21
|
%p effective_resources index view is not sure what to render.
|
20
22
|
%p Define an @datatable, @#{resource.try(:plural_name) || 'a plural'}, or @#{resource.try(:name) || 'a singular'}.
|
21
23
|
%p or include Effective::CrudController in your controller
|
22
|
-
.card-footer
|
23
|
-
= render_resource_buttons(resource.klass, (action ||= :index) => false)
|
24
|
+
-# .card-footer
|
24
25
|
|
@@ -3,12 +3,6 @@
|
|
3
3
|
|
4
4
|
- if @resource
|
5
5
|
.row
|
6
|
-
.col-
|
7
|
-
|
8
|
-
.col-4.text-right
|
9
|
-
= render_resource_buttons(@resource, show: false)
|
6
|
+
.col-12
|
7
|
+
= render_resource_form(@resource)
|
10
8
|
|
11
|
-
= render_resource_partial(@resource)
|
12
|
-
|
13
|
-
.form-actions
|
14
|
-
= link_to 'Continue', (resource.action_path(:index) || root_path), class: 'btn btn-primary'
|
@@ -24,3 +24,38 @@
|
|
24
24
|
%ul.nav.nav-pills.nav-sidebar.nav-compact.flex-column{"data-accordion" => "false", "data-widget" => "treeview", :role => "menu"}
|
25
25
|
- @context.menu_items.each do |menu_item|
|
26
26
|
= render Olivander::Components::MenuItemComponent.new(menu_item)
|
27
|
+
|
28
|
+
|
29
|
+
:javascript
|
30
|
+
$(document).ready(function(){
|
31
|
+
function getUrl() {
|
32
|
+
const reg = /\/new|\/[0-9]+[\/edit]*/,
|
33
|
+
url = "" + window.location;
|
34
|
+
return url.replace(reg, '');
|
35
|
+
}
|
36
|
+
const url = getUrl();
|
37
|
+
|
38
|
+
$('ul.nav-sidebar a').filter(function() {
|
39
|
+
return this.href == url;
|
40
|
+
}).addClass('active');
|
41
|
+
|
42
|
+
$('ul.nav-sidebar a').filter(function() {
|
43
|
+
return this.href == url;
|
44
|
+
}).parent().addClass('active');
|
45
|
+
|
46
|
+
$('ul.nav-treeview a').filter(function() {
|
47
|
+
return this.href == url;
|
48
|
+
}).parentsUntil(".sidebar-menu > .nav-treeview").addClass('menu-open');
|
49
|
+
|
50
|
+
$('ul.nav-treeview a').filter(function() {
|
51
|
+
return this.href == url;
|
52
|
+
}).addClass('active');
|
53
|
+
|
54
|
+
$('li.has-treeview a').filter(function() {
|
55
|
+
return this.href == url;
|
56
|
+
}).addClass('active');
|
57
|
+
|
58
|
+
$('ul.nav-treeview a').filter(function() {
|
59
|
+
return this.href == url;
|
60
|
+
}).parentsUntil(".sidebar-menu > .nav-treeview").children(0).addClass('active');
|
61
|
+
});
|
@@ -0,0 +1,176 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
#
|
3
|
+
# Uncomment this and change the path if necessary to include your own
|
4
|
+
# components.
|
5
|
+
# See https://github.com/heartcombo/simple_form#custom-components to know
|
6
|
+
# more about custom components.
|
7
|
+
# Dir[Rails.root.join('lib/components/**/*.rb')].each { |f| require f }
|
8
|
+
#
|
9
|
+
# Use this setup block to configure all options available in SimpleForm.
|
10
|
+
SimpleForm.setup do |config|
|
11
|
+
# Wrappers are used by the form builder to generate a
|
12
|
+
# complete input. You can remove any component from the
|
13
|
+
# wrapper, change the order or even add your own to the
|
14
|
+
# stack. The options given below are used to wrap the
|
15
|
+
# whole input.
|
16
|
+
config.wrappers :default, class: :input,
|
17
|
+
hint_class: :field_with_hint, error_class: :field_with_errors, valid_class: :field_without_errors do |b|
|
18
|
+
## Extensions enabled by default
|
19
|
+
# Any of these extensions can be disabled for a
|
20
|
+
# given input by passing: `f.input EXTENSION_NAME => false`.
|
21
|
+
# You can make any of these extensions optional by
|
22
|
+
# renaming `b.use` to `b.optional`.
|
23
|
+
|
24
|
+
# Determines whether to use HTML5 (:email, :url, ...)
|
25
|
+
# and required attributes
|
26
|
+
b.use :html5
|
27
|
+
|
28
|
+
# Calculates placeholders automatically from I18n
|
29
|
+
# You can also pass a string as f.input placeholder: "Placeholder"
|
30
|
+
b.use :placeholder
|
31
|
+
|
32
|
+
## Optional extensions
|
33
|
+
# They are disabled unless you pass `f.input EXTENSION_NAME => true`
|
34
|
+
# to the input. If so, they will retrieve the values from the model
|
35
|
+
# if any exists. If you want to enable any of those
|
36
|
+
# extensions by default, you can change `b.optional` to `b.use`.
|
37
|
+
|
38
|
+
# Calculates maxlength from length validations for string inputs
|
39
|
+
# and/or database column lengths
|
40
|
+
b.optional :maxlength
|
41
|
+
|
42
|
+
# Calculate minlength from length validations for string inputs
|
43
|
+
b.optional :minlength
|
44
|
+
|
45
|
+
# Calculates pattern from format validations for string inputs
|
46
|
+
b.optional :pattern
|
47
|
+
|
48
|
+
# Calculates min and max from length validations for numeric inputs
|
49
|
+
b.optional :min_max
|
50
|
+
|
51
|
+
# Calculates readonly automatically from readonly attributes
|
52
|
+
b.optional :readonly
|
53
|
+
|
54
|
+
## Inputs
|
55
|
+
# b.use :input, class: 'input', error_class: 'is-invalid', valid_class: 'is-valid'
|
56
|
+
b.use :label_input
|
57
|
+
b.use :hint, wrap_with: { tag: :span, class: :hint }
|
58
|
+
b.use :error, wrap_with: { tag: :span, class: :error }
|
59
|
+
|
60
|
+
## full_messages_for
|
61
|
+
# If you want to display the full error message for the attribute, you can
|
62
|
+
# use the component :full_error, like:
|
63
|
+
#
|
64
|
+
# b.use :full_error, wrap_with: { tag: :span, class: :error }
|
65
|
+
end
|
66
|
+
|
67
|
+
# The default wrapper to be used by the FormBuilder.
|
68
|
+
config.default_wrapper = :default
|
69
|
+
|
70
|
+
# Define the way to render check boxes / radio buttons with labels.
|
71
|
+
# Defaults to :nested for bootstrap config.
|
72
|
+
# inline: input + label
|
73
|
+
# nested: label > input
|
74
|
+
config.boolean_style = :nested
|
75
|
+
|
76
|
+
# Default class for buttons
|
77
|
+
config.button_class = 'btn'
|
78
|
+
|
79
|
+
# Method used to tidy up errors. Specify any Rails Array method.
|
80
|
+
# :first lists the first message for each field.
|
81
|
+
# Use :to_sentence to list all errors for each field.
|
82
|
+
# config.error_method = :first
|
83
|
+
|
84
|
+
# Default tag used for error notification helper.
|
85
|
+
config.error_notification_tag = :div
|
86
|
+
|
87
|
+
# CSS class to add for error notification helper.
|
88
|
+
config.error_notification_class = 'error_notification'
|
89
|
+
|
90
|
+
# Series of attempts to detect a default label method for collection.
|
91
|
+
# config.collection_label_methods = [ :to_label, :name, :title, :to_s ]
|
92
|
+
|
93
|
+
# Series of attempts to detect a default value method for collection.
|
94
|
+
# config.collection_value_methods = [ :id, :to_s ]
|
95
|
+
|
96
|
+
# You can wrap a collection of radio/check boxes in a pre-defined tag, defaulting to none.
|
97
|
+
# config.collection_wrapper_tag = nil
|
98
|
+
|
99
|
+
# You can define the class to use on all collection wrappers. Defaulting to none.
|
100
|
+
# config.collection_wrapper_class = nil
|
101
|
+
|
102
|
+
# You can wrap each item in a collection of radio/check boxes with a tag,
|
103
|
+
# defaulting to :span.
|
104
|
+
# config.item_wrapper_tag = :span
|
105
|
+
|
106
|
+
# You can define a class to use in all item wrappers. Defaulting to none.
|
107
|
+
# config.item_wrapper_class = nil
|
108
|
+
|
109
|
+
# How the label text should be generated altogether with the required text.
|
110
|
+
# config.label_text = lambda { |label, required, explicit_label| "#{required} #{label}" }
|
111
|
+
|
112
|
+
# You can define the class to use on all labels. Default is nil.
|
113
|
+
# config.label_class = nil
|
114
|
+
|
115
|
+
# You can define the default class to be used on forms. Can be overriden
|
116
|
+
# with `html: { :class }`. Defaulting to none.
|
117
|
+
# config.default_form_class = nil
|
118
|
+
|
119
|
+
# You can define which elements should obtain additional classes
|
120
|
+
# config.generate_additional_classes_for = [:wrapper, :label, :input]
|
121
|
+
|
122
|
+
# Whether attributes are required by default (or not). Default is true.
|
123
|
+
# config.required_by_default = true
|
124
|
+
|
125
|
+
# Tell browsers whether to use the native HTML5 validations (novalidate form option).
|
126
|
+
# These validations are enabled in SimpleForm's internal config but disabled by default
|
127
|
+
# in this configuration, which is recommended due to some quirks from different browsers.
|
128
|
+
# To stop SimpleForm from generating the novalidate option, enabling the HTML5 validations,
|
129
|
+
# change this configuration to true.
|
130
|
+
config.browser_validations = false
|
131
|
+
|
132
|
+
# Custom mappings for input types. This should be a hash containing a regexp
|
133
|
+
# to match as key, and the input type that will be used when the field name
|
134
|
+
# matches the regexp as value.
|
135
|
+
# config.input_mappings = { /count/ => :integer }
|
136
|
+
|
137
|
+
# Custom wrappers for input types. This should be a hash containing an input
|
138
|
+
# type as key and the wrapper that will be used for all inputs with specified type.
|
139
|
+
# config.wrapper_mappings = { string: :prepend }
|
140
|
+
|
141
|
+
# Namespaces where SimpleForm should look for custom input classes that
|
142
|
+
# override default inputs.
|
143
|
+
# config.custom_inputs_namespaces << "CustomInputs"
|
144
|
+
|
145
|
+
# Default priority for time_zone inputs.
|
146
|
+
# config.time_zone_priority = nil
|
147
|
+
|
148
|
+
# Default priority for country inputs.
|
149
|
+
# config.country_priority = nil
|
150
|
+
|
151
|
+
# When false, do not use translations for labels.
|
152
|
+
# config.translate_labels = true
|
153
|
+
|
154
|
+
# Automatically discover new inputs in Rails' autoload path.
|
155
|
+
# config.inputs_discovery = true
|
156
|
+
|
157
|
+
# Cache SimpleForm inputs discovery
|
158
|
+
# config.cache_discovery = !Rails.env.development?
|
159
|
+
|
160
|
+
# Default class for inputs
|
161
|
+
# config.input_class = nil
|
162
|
+
|
163
|
+
# Define the default class of the input wrapper of the boolean input.
|
164
|
+
config.boolean_label_class = 'checkbox'
|
165
|
+
|
166
|
+
# Defines if the default input wrapper class should be included in radio
|
167
|
+
# collection wrappers.
|
168
|
+
# config.include_default_input_wrapper_class = true
|
169
|
+
|
170
|
+
# Defines which i18n scope will be used in Simple Form.
|
171
|
+
# config.i18n_scope = 'simple_form'
|
172
|
+
|
173
|
+
# Defines validation classes to the input_field. By default it's nil.
|
174
|
+
# config.input_field_valid_class = 'is-valid'
|
175
|
+
# config.input_field_error_class = 'is-invalid'
|
176
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
en:
|
2
|
+
simple_form:
|
3
|
+
"yes": 'Yes'
|
4
|
+
"no": 'No'
|
5
|
+
required:
|
6
|
+
text: 'required'
|
7
|
+
mark: '*'
|
8
|
+
# You can uncomment the line below if you need to overwrite the whole required html.
|
9
|
+
# When using html, text and mark won't be used.
|
10
|
+
# html: '<abbr title="required">*</abbr>'
|
11
|
+
error_notification:
|
12
|
+
default_message: "Please review the problems below:"
|
13
|
+
# Examples
|
14
|
+
# labels:
|
15
|
+
# defaults:
|
16
|
+
# password: 'Password'
|
17
|
+
# user:
|
18
|
+
# new:
|
19
|
+
# email: 'E-mail to sign in.'
|
20
|
+
# edit:
|
21
|
+
# email: 'E-mail.'
|
22
|
+
# hints:
|
23
|
+
# defaults:
|
24
|
+
# username: 'User name to sign in.'
|
25
|
+
# password: 'No special characters, please.'
|
26
|
+
# include_blanks:
|
27
|
+
# defaults:
|
28
|
+
# age: 'Rather not say'
|
29
|
+
# prompts:
|
30
|
+
# defaults:
|
31
|
+
# age: 'Select your age'
|
data/lib/olivander/version.rb
CHANGED
@@ -0,0 +1,8 @@
|
|
1
|
+
= simple_form_for(@resource) do |f|
|
2
|
+
=f.error_notification}
|
3
|
+
=f.error_notification message: f.object.errors[:base].to_sentence if f.object.errors[:base].present?}
|
4
|
+
.form-inputs
|
5
|
+
- attributes.each do |attribute|
|
6
|
+
= f.send(attribute.reference? ? :association : :input, attribute.name)
|
7
|
+
.form-actions
|
8
|
+
= f.button :submit
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: five-two-nw-olivander
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.2.
|
4
|
+
version: 0.1.2.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Eric Dennis
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-07-
|
11
|
+
date: 2023-07-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: chartkick
|
@@ -171,21 +171,21 @@ files:
|
|
171
171
|
- app/assets/stylesheets/olivander/application.css
|
172
172
|
- app/components/olivander/components/menu_item_component.html.haml
|
173
173
|
- app/components/olivander/components/menu_item_component.rb
|
174
|
+
- app/controllers/concerns/olivander/resources/auto_form_attributes.rb
|
175
|
+
- app/controllers/concerns/olivander/resources/route_builder.rb
|
174
176
|
- app/controllers/olivander/application_controller.rb
|
175
|
-
- app/controllers/olivander/resources/crud_chain.rb
|
176
|
-
- app/controllers/olivander/resources/crud_controller.rb
|
177
|
-
- app/controllers/olivander/resources/default_crud_chain.rb
|
178
|
-
- app/controllers/olivander/test_controller.rb
|
179
177
|
- app/datatables/olivander/datatable.rb
|
180
178
|
- app/datatables/test_datatable.rb
|
181
179
|
- app/helpers/olivander/application_helper.rb
|
182
180
|
- app/jobs/olivander/application_job.rb
|
183
181
|
- app/mailers/olivander/application_mailer.rb
|
184
182
|
- app/models/olivander/application_record.rb
|
183
|
+
- app/views/application/_form.html.haml
|
185
184
|
- app/views/application/edit.html.haml
|
186
185
|
- app/views/application/index.html.haml
|
187
186
|
- app/views/application/new.html.haml
|
188
187
|
- app/views/application/show.html.haml
|
188
|
+
- app/views/effective/resource/_actions_dropleft.html.haml
|
189
189
|
- app/views/layouts/olivander/adminlte/_content.html.haml
|
190
190
|
- app/views/layouts/olivander/adminlte/_content_kanban.html.haml
|
191
191
|
- app/views/layouts/olivander/adminlte/_control_sidebar.html.haml
|
@@ -199,6 +199,8 @@ files:
|
|
199
199
|
- app/views/layouts/olivander/adminlte/main.html.haml
|
200
200
|
- app/views/layouts/olivander/application.html.haml
|
201
201
|
- config/initializers/effective_datatables.rb.old
|
202
|
+
- config/initializers/simple_form.rb
|
203
|
+
- config/locales/simple_form.en.yml
|
202
204
|
- config/routes.rb
|
203
205
|
- lib/five-two-nw-olivander.rb
|
204
206
|
- lib/olivander.rb
|
@@ -208,6 +210,7 @@ files:
|
|
208
210
|
- lib/olivander/menus/menu_item.rb
|
209
211
|
- lib/olivander/version.rb
|
210
212
|
- lib/tasks/olivander_tasks.rake
|
213
|
+
- lib/templates/erb/scaffold/_form.html.haml
|
211
214
|
homepage: https://rubygems.org/gems/olivander
|
212
215
|
licenses:
|
213
216
|
- MIT
|
@@ -1,119 +0,0 @@
|
|
1
|
-
module Olivander
|
2
|
-
module Resources
|
3
|
-
class CrudChain
|
4
|
-
attr_accessor :controller
|
5
|
-
|
6
|
-
def initialize(controller)
|
7
|
-
@controller = controller
|
8
|
-
end
|
9
|
-
|
10
|
-
def links
|
11
|
-
@links ||= {
|
12
|
-
authorize_action: nil,
|
13
|
-
before_load: nil, load_resource: nil, after_load: nil,
|
14
|
-
authorize_resource: nil,
|
15
|
-
before_assign: nil, assign: nil, after_assign: nil,
|
16
|
-
update_if: nil,
|
17
|
-
before_update: nil, update: nil, after_update: nil,
|
18
|
-
update_success: nil, update_failure: nil,
|
19
|
-
render_success: nil, render_failure: nil
|
20
|
-
}
|
21
|
-
end
|
22
|
-
|
23
|
-
def on(chain_link, &block)
|
24
|
-
raise "Invalid Link: #{chain_link}" unless links.keys.include?(chain_link)
|
25
|
-
|
26
|
-
links[chain_link] = block
|
27
|
-
self
|
28
|
-
end
|
29
|
-
|
30
|
-
def skip_load
|
31
|
-
clear_keys(%i[before_load load_resource after_load])
|
32
|
-
self
|
33
|
-
end
|
34
|
-
|
35
|
-
def skip_assign
|
36
|
-
clear_keys(%i[before_assign assign after_assign])
|
37
|
-
self
|
38
|
-
end
|
39
|
-
|
40
|
-
def skip_update
|
41
|
-
update_if { false }
|
42
|
-
self
|
43
|
-
end
|
44
|
-
|
45
|
-
def skip_render
|
46
|
-
clear_keys(%i[render_success render_failure])
|
47
|
-
self
|
48
|
-
end
|
49
|
-
|
50
|
-
def execute
|
51
|
-
execute_link_keys(%i[authorize_action before_load load_resource after_load authorize_resource before_assign assign after_assign])
|
52
|
-
success = perform_update
|
53
|
-
# we may not do any update - in which case we assume success
|
54
|
-
success = true if success.nil?
|
55
|
-
execute_link_key(success ? :render_success : :render_failure)
|
56
|
-
success
|
57
|
-
end
|
58
|
-
|
59
|
-
# def self.test
|
60
|
-
# CrudChain.new('string')
|
61
|
-
# .before_load { puts "we did a before load from within this action: #{self}" }
|
62
|
-
# .before_update { puts "we are doing a before_update on a controller named: #{self.class.name}" }
|
63
|
-
# .execute
|
64
|
-
# end
|
65
|
-
|
66
|
-
def clear_keys(keys)
|
67
|
-
keys.each { |k| clear_key(k) }
|
68
|
-
end
|
69
|
-
|
70
|
-
def clear_keys_except(keys)
|
71
|
-
(links.keys - keys).each { |k| clear_key(k) }
|
72
|
-
end
|
73
|
-
|
74
|
-
def clear_key(key)
|
75
|
-
links[key] = nil
|
76
|
-
end
|
77
|
-
|
78
|
-
private
|
79
|
-
|
80
|
-
def perform_update
|
81
|
-
perform_update = execute_link_key(:update_if)
|
82
|
-
perform_update = true if perform_update.nil?
|
83
|
-
return false unless perform_update
|
84
|
-
|
85
|
-
execute_link_key(:before_update)
|
86
|
-
success = execute_link_key(:update)
|
87
|
-
execute_link_key(:after_update)
|
88
|
-
execute_link_key(success ? :update_success : :update_failure)
|
89
|
-
success
|
90
|
-
end
|
91
|
-
|
92
|
-
def execute_link_keys(keys)
|
93
|
-
keys.each do |k|
|
94
|
-
execute_link_key(k)
|
95
|
-
end
|
96
|
-
end
|
97
|
-
|
98
|
-
def execute_link_key(key)
|
99
|
-
block = links[key]
|
100
|
-
return if block.nil?
|
101
|
-
|
102
|
-
@controller.instance_exec(&block)
|
103
|
-
end
|
104
|
-
|
105
|
-
def respond_to_missing?(method_name, _include_private = false)
|
106
|
-
links.keys.include?(method_name.to_sym)
|
107
|
-
end
|
108
|
-
|
109
|
-
# syntax sugar to allow direct assignment of a chain link
|
110
|
-
def method_missing(m, *args, &block)
|
111
|
-
if respond_to_missing?(m)
|
112
|
-
send(:on, m, &block)
|
113
|
-
else
|
114
|
-
super
|
115
|
-
end
|
116
|
-
end
|
117
|
-
end
|
118
|
-
end
|
119
|
-
end
|
@@ -1,55 +0,0 @@
|
|
1
|
-
module Olivander
|
2
|
-
module Resources
|
3
|
-
module CrudController
|
4
|
-
def index
|
5
|
-
execute_crud_chain(crud_action: :index)
|
6
|
-
end
|
7
|
-
|
8
|
-
def new
|
9
|
-
execute_crud_chain(crud_action: :new)
|
10
|
-
end
|
11
|
-
|
12
|
-
def create
|
13
|
-
execute_crud_chain(crud_action: :create)
|
14
|
-
end
|
15
|
-
|
16
|
-
def show
|
17
|
-
execute_crud_chain(crud_action: :show)
|
18
|
-
end
|
19
|
-
|
20
|
-
def edit
|
21
|
-
execute_crud_chain(crud_action: :edit)
|
22
|
-
end
|
23
|
-
|
24
|
-
def update
|
25
|
-
execute_crud_chain(crud_action: :update)
|
26
|
-
end
|
27
|
-
|
28
|
-
def destroy
|
29
|
-
execute_crud_chain(crud_action: :destroy)
|
30
|
-
end
|
31
|
-
|
32
|
-
def execute_crud_chain(crud_action: action_name, only: [], skip: [], &block)
|
33
|
-
chain = default_crud_chain(crud_action)
|
34
|
-
chain.clear_keys_except(only) if only.size.positive?
|
35
|
-
chain.clear_keys(skip) if skip.size.positive?
|
36
|
-
yield(chain) if block_given?
|
37
|
-
chain.execute
|
38
|
-
end
|
39
|
-
|
40
|
-
def default_crud_chain(crud_action = '')
|
41
|
-
chain = Olivander::Resources::CrudChain.new(self)
|
42
|
-
chain.links.keys.each do |k|
|
43
|
-
method_name = "crud_chain_#{crud_action}_#{k}"
|
44
|
-
method_name = "crud_chain_#{k}" unless respond_to?(method_name)
|
45
|
-
next unless respond_to?(method_name)
|
46
|
-
|
47
|
-
chain.on(k) do
|
48
|
-
send(method_name)
|
49
|
-
end
|
50
|
-
end
|
51
|
-
chain
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
end
|
@@ -1,48 +0,0 @@
|
|
1
|
-
module Olivander
|
2
|
-
module Resources
|
3
|
-
module DefaultCrudChain
|
4
|
-
def crud_chain_index_authorize_action
|
5
|
-
puts 'default crud chain: index_authorize_action'
|
6
|
-
end
|
7
|
-
|
8
|
-
def crud_chain_index_load_resource
|
9
|
-
puts 'default crud chain: index_load_resource'
|
10
|
-
end
|
11
|
-
|
12
|
-
def crud_chain_load_resource
|
13
|
-
puts 'default crud chain: load_resource'
|
14
|
-
end
|
15
|
-
|
16
|
-
def crud_chain_authorize_resource
|
17
|
-
raise 'Unauthorized' unless true
|
18
|
-
puts 'default crud chain: authorize_resource'
|
19
|
-
end
|
20
|
-
|
21
|
-
def crud_chain_assign
|
22
|
-
puts 'default crud chain: assign'
|
23
|
-
end
|
24
|
-
|
25
|
-
def crud_chain_update_if
|
26
|
-
puts 'default crud chain: update_if'
|
27
|
-
return true if %w[create update destroy].include?(action_name)
|
28
|
-
return false if %w[index new show edit].include?(action_name)
|
29
|
-
return false if request.method == 'GET'
|
30
|
-
|
31
|
-
true
|
32
|
-
end
|
33
|
-
|
34
|
-
def crud_chain_update
|
35
|
-
puts 'default crud chain: update'
|
36
|
-
true
|
37
|
-
end
|
38
|
-
|
39
|
-
def crud_chain_render_success
|
40
|
-
puts 'default crud chain: render_success'
|
41
|
-
end
|
42
|
-
|
43
|
-
def crud_chain_render_failure
|
44
|
-
puts 'default crud chain: render_failure'
|
45
|
-
end
|
46
|
-
end
|
47
|
-
end
|
48
|
-
end
|
@@ -1,35 +0,0 @@
|
|
1
|
-
module Olivander
|
2
|
-
class TestController < ApplicationController
|
3
|
-
include Olivander::Resources::CrudController
|
4
|
-
include Olivander::Resources::DefaultCrudChain
|
5
|
-
|
6
|
-
def index
|
7
|
-
execute_crud_chain(crud_action: :index) do |c|
|
8
|
-
c.authorize_resource { puts 'block: authorize_resource'; true }
|
9
|
-
.update { puts 'block: update'; true }
|
10
|
-
.before_assign { puts 'block: before assign' }
|
11
|
-
.after_assign { puts 'block: after assign' }
|
12
|
-
end
|
13
|
-
end
|
14
|
-
|
15
|
-
# def crud_chain_update
|
16
|
-
# puts 'controller: update'
|
17
|
-
# end
|
18
|
-
|
19
|
-
# def crud_chain_index_update
|
20
|
-
# puts 'controller: index_update'
|
21
|
-
# end
|
22
|
-
|
23
|
-
# def crud_chain_before_load
|
24
|
-
# puts 'controller: before_load'
|
25
|
-
# end
|
26
|
-
|
27
|
-
# def crud_chain_after_update
|
28
|
-
# puts 'controller: after_update'
|
29
|
-
# end
|
30
|
-
|
31
|
-
# def crud_chain_index_after_update
|
32
|
-
# puts 'controller: index_after_update'
|
33
|
-
# end
|
34
|
-
end
|
35
|
-
end
|