madmin 0.1.0 → 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/MIT-LICENSE +1 -1
- data/README.md +7 -82
- data/Rakefile +1 -6
- data/app/assets/config/manifest.js +2 -0
- data/app/assets/stylesheets/actiontext.scss +36 -0
- data/app/assets/stylesheets/{madmin/application.css → application.css} +2 -9
- data/app/controllers/madmin/application_controller.rb +6 -10
- data/app/controllers/madmin/dashboard_controller.rb +1 -3
- data/app/controllers/madmin/resource_controller.rb +72 -0
- data/app/helpers/madmin/application_helper.rb +1 -11
- data/app/views/layouts/madmin/application.html.erb +25 -26
- data/app/views/madmin/application/_form.html.erb +25 -0
- data/app/views/madmin/application/_navigation.html.erb +6 -0
- data/app/views/madmin/application/edit.html.erb +3 -0
- data/app/views/madmin/application/index.html.erb +35 -0
- data/app/views/madmin/application/new.html.erb +3 -0
- data/app/views/madmin/application/show.html.erb +24 -0
- data/app/views/madmin/dashboard/show.html.erb +1 -0
- data/app/views/madmin/fields/attachment/_form.html.erb +2 -0
- data/app/views/madmin/fields/attachment/_index.html.erb +3 -0
- data/app/views/madmin/fields/attachment/_show.html.erb +3 -0
- data/app/views/madmin/fields/attachments/_form.html.erb +2 -0
- data/app/views/madmin/fields/attachments/_index.html.erb +1 -0
- data/app/views/madmin/fields/attachments/_show.html.erb +7 -0
- data/app/views/madmin/fields/belongs_to/_form.html.erb +2 -14
- data/app/views/madmin/fields/belongs_to/_index.html.erb +2 -7
- data/app/views/madmin/fields/belongs_to/_show.html.erb +2 -8
- data/app/views/madmin/fields/boolean/_form.html.erb +2 -0
- data/app/views/madmin/fields/boolean/_index.html.erb +1 -0
- data/app/views/madmin/fields/boolean/_show.html.erb +1 -0
- data/app/views/madmin/fields/date/_form.html.erb +2 -0
- data/app/views/madmin/fields/date/_index.html.erb +1 -0
- data/app/views/madmin/fields/date/_show.html.erb +1 -0
- data/app/views/madmin/fields/date_time/_form.html.erb +2 -0
- data/app/views/madmin/fields/date_time/_index.html.erb +1 -0
- data/app/views/madmin/fields/date_time/_show.html.erb +1 -0
- data/app/views/madmin/fields/enum/_form.html.erb +3 -0
- data/app/views/madmin/fields/enum/_index.html.erb +1 -0
- data/app/views/madmin/fields/enum/_show.html.erb +1 -0
- data/app/views/madmin/fields/float/_form.html.erb +2 -0
- data/app/views/madmin/fields/float/_index.html.erb +1 -0
- data/app/views/madmin/fields/float/_show.html.erb +1 -0
- data/app/views/madmin/fields/has_many/_form.html.erb +2 -0
- data/app/views/madmin/fields/has_many/_index.html.erb +1 -0
- data/app/views/madmin/fields/has_many/_show.html.erb +4 -14
- data/app/views/madmin/fields/has_one/_form.html.erb +3 -0
- data/app/views/madmin/fields/has_one/_index.html.erb +3 -0
- data/app/views/madmin/fields/has_one/_show.html.erb +3 -12
- data/app/views/madmin/fields/integer/_form.html.erb +2 -0
- data/app/views/madmin/fields/integer/_index.html.erb +1 -0
- data/app/views/madmin/fields/integer/_show.html.erb +1 -0
- data/app/views/madmin/fields/json/_form.html.erb +2 -0
- data/app/views/madmin/fields/json/_index.html.erb +1 -0
- data/app/views/madmin/fields/json/_show.html.erb +1 -0
- data/app/views/madmin/fields/polymorphic/_form.html.erb +5 -32
- data/app/views/madmin/fields/polymorphic/_index.html.erb +3 -1
- data/app/views/madmin/fields/polymorphic/_show.html.erb +3 -14
- data/app/views/madmin/fields/rich_text/_form.html.erb +4 -0
- data/app/views/madmin/fields/rich_text/_index.html.erb +1 -0
- data/app/views/madmin/fields/rich_text/_show.html.erb +3 -0
- data/app/views/madmin/fields/string/_form.html.erb +2 -0
- data/app/views/madmin/fields/string/_index.html.erb +1 -0
- data/app/views/madmin/fields/string/_show.html.erb +1 -0
- data/app/views/madmin/fields/text/_form.html.erb +2 -4
- data/app/views/madmin/fields/text/_index.html.erb +1 -1
- data/app/views/madmin/fields/text/_show.html.erb +1 -8
- data/app/views/madmin/fields/time/_form.html.erb +2 -0
- data/app/views/madmin/fields/time/_index.html.erb +1 -0
- data/app/views/madmin/fields/time/_show.html.erb +1 -0
- data/lib/generators/madmin/install/install_generator.rb +24 -12
- data/lib/generators/madmin/resource/resource_generator.rb +83 -47
- data/lib/generators/madmin/resource/templates/controller.rb.tt +4 -0
- data/lib/generators/madmin/resource/templates/resource.rb.tt +11 -0
- data/lib/madmin.rb +33 -23
- data/lib/madmin/engine.rb +5 -2
- data/lib/madmin/field.rb +18 -47
- data/lib/madmin/fields/attachment.rb +6 -0
- data/lib/madmin/fields/attachments.rb +9 -0
- data/lib/madmin/fields/belongs_to.rb +18 -0
- data/lib/madmin/fields/boolean.rb +6 -0
- data/lib/madmin/fields/date.rb +6 -0
- data/lib/madmin/fields/date_time.rb +6 -0
- data/lib/madmin/fields/enum.rb +6 -0
- data/lib/madmin/fields/float.rb +6 -0
- data/lib/madmin/fields/has_many.rb +18 -0
- data/lib/madmin/fields/has_one.rb +6 -0
- data/lib/madmin/fields/integer.rb +6 -0
- data/lib/madmin/fields/json.rb +6 -0
- data/lib/madmin/fields/polymorphic.rb +17 -0
- data/lib/madmin/fields/rich_text.rb +6 -0
- data/lib/madmin/fields/string.rb +6 -0
- data/lib/madmin/fields/text.rb +6 -0
- data/lib/madmin/fields/time.rb +6 -0
- data/lib/madmin/generator_helpers.rb +24 -0
- data/lib/madmin/resource.rb +125 -0
- data/lib/madmin/version.rb +1 -1
- data/lib/tasks/madmin_tasks.rake +7 -0
- metadata +90 -97
- data/app/assets/config/madmin_manifest.js +0 -2
- data/app/assets/javascripts/madmin/application.js +0 -15
- data/app/assets/javascripts/madmin/dashboard.js +0 -2
- data/app/assets/javascripts/madmin/resources.js +0 -36
- data/app/assets/stylesheets/madmin/dashboard.css +0 -4
- data/app/assets/stylesheets/madmin/resources.css +0 -4
- data/app/controllers/madmin/base_controller.rb +0 -16
- data/app/controllers/madmin/resources_controller.rb +0 -97
- data/app/decorators/madmin/resource_decorator.rb +0 -16
- data/app/helpers/madmin/fields/polymorphic_helper.rb +0 -25
- data/app/jobs/madmin/application_job.rb +0 -4
- data/app/mailers/madmin/application_mailer.rb +0 -6
- data/app/models/madmin/application_record.rb +0 -5
- data/app/views/application/_navigation.html.erb +0 -17
- data/app/views/madmin/dashboard/index.html.erb +0 -6
- data/app/views/madmin/fields/check_box/_form.html.erb +0 -4
- data/app/views/madmin/fields/check_box/_index.html.erb +0 -1
- data/app/views/madmin/fields/check_box/_show.html.erb +0 -8
- data/app/views/madmin/fields/email/_form.html.erb +0 -4
- data/app/views/madmin/fields/email/_index.html.erb +0 -1
- data/app/views/madmin/fields/email/_show.html.erb +0 -8
- data/app/views/madmin/fields/number/_form.html.erb +0 -4
- data/app/views/madmin/fields/number/_index.html.erb +0 -1
- data/app/views/madmin/fields/number/_show.html.erb +0 -8
- data/app/views/madmin/fields/password/_form.html.erb +0 -4
- data/app/views/madmin/fields/password/_index.html.erb +0 -1
- data/app/views/madmin/fields/password/_show.html.erb +0 -8
- data/app/views/madmin/fields/select/_form.html.erb +0 -4
- data/app/views/madmin/fields/select/_index.html.erb +0 -1
- data/app/views/madmin/fields/select/_show.html.erb +0 -8
- data/app/views/madmin/fields/text_area/_form.html.erb +0 -4
- data/app/views/madmin/fields/text_area/_index.html.erb +0 -1
- data/app/views/madmin/fields/text_area/_show.html.erb +0 -8
- data/app/views/madmin/resources/_form.html.erb +0 -15
- data/app/views/madmin/resources/_scopes.html.erb +0 -10
- data/app/views/madmin/resources/edit.html.erb +0 -2
- data/app/views/madmin/resources/index.html.erb +0 -13
- data/app/views/madmin/resources/index/_content.html.erb +0 -33
- data/app/views/madmin/resources/new.html.erb +0 -2
- data/app/views/madmin/resources/show.html.erb +0 -10
- data/config/routes.rb +0 -11
- data/lib/generators/madmin/controller/USAGE +0 -8
- data/lib/generators/madmin/controller/controller_generator.rb +0 -10
- data/lib/generators/madmin/page/USAGE +0 -8
- data/lib/generators/madmin/page/page_generator.rb +0 -20
- data/lib/generators/madmin/page/templates/template.html.erb +0 -2
- data/lib/generators/madmin/page/templates/template.rb.erb +0 -10
- data/lib/generators/madmin/resource/templates/resource.rb.erb +0 -11
- data/lib/generators/madmin/views/views_generator.rb +0 -15
- data/lib/madmin/field/associatable.rb +0 -58
- data/lib/madmin/field/belongs_to.rb +0 -9
- data/lib/madmin/field/check_box.rb +0 -8
- data/lib/madmin/field/date_time.rb +0 -8
- data/lib/madmin/field/email.rb +0 -8
- data/lib/madmin/field/has_many.rb +0 -9
- data/lib/madmin/field/has_one.rb +0 -9
- data/lib/madmin/field/number.rb +0 -8
- data/lib/madmin/field/password.rb +0 -8
- data/lib/madmin/field/polymorphic.rb +0 -57
- data/lib/madmin/field/select.rb +0 -13
- data/lib/madmin/field/text.rb +0 -8
- data/lib/madmin/field/text_area.rb +0 -8
- data/lib/madmin/resourceable.rb +0 -72
- data/lib/madmin/resourceable/class_methods.rb +0 -152
- data/lib/madmin/resources.rb +0 -13
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 3ae907c78952efd333b7151ef50818dc6b171017239a11152c129c17bb45af10
|
4
|
+
data.tar.gz: 923a8e6ecb3e84bffd6973a511845cc16cc599e36adc5116525ab01e46bc1c16
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c696a1782666fdcc4a113d7709775c41e245a9f92ef298c93a6fb98a1c1f2db4f5a34f36d59a1c3da476a6db44bfcc864f5b37c8136ef8f8a155415344b74660
|
7
|
+
data.tar.gz: d7eef669f0b0366ccaf73f3cd68f85525067172ade70c55397b9cd27e7132c3008a067d68d5bc3d073e94441f1cbf8a9e893a11a2b91fbfd0dbdd6a695487230
|
data/MIT-LICENSE
CHANGED
data/README.md
CHANGED
@@ -1,102 +1,27 @@
|
|
1
1
|
# Madmin
|
2
2
|
|
3
|
-
|
3
|
+
### A robust admin interface for Ruby on Rails apps
|
4
4
|
|
5
|
-
|
5
|
+
[![Build Status](https://github.com/excid3/madmin/workflows/Tests/badge.svg)](https://github.com/excid3/madmin/actions) [![Gem Version](https://badge.fury.io/rb/madmin.svg)](https://badge.fury.io/rb/madmin)
|
6
6
|
|
7
|
+
## Usage
|
7
8
|
How to use my plugin.
|
8
9
|
|
9
10
|
## Installation
|
10
|
-
|
11
|
-
Add this line to your application's Gemfile:
|
12
|
-
|
13
|
-
```ruby
|
14
|
-
gem 'madmin'
|
15
|
-
```
|
16
|
-
|
17
|
-
And then execute:
|
18
|
-
|
19
|
-
```bash
|
20
|
-
$ bundle
|
21
|
-
```
|
22
|
-
|
23
|
-
Or install it yourself as:
|
24
|
-
|
25
|
-
```bash
|
26
|
-
$ gem install madmin
|
27
|
-
```
|
28
|
-
|
29
|
-
Then you can run the installer to generate resources for all models in
|
30
|
-
your app that inherit from `ActiveRecord::Base` by running:
|
31
|
-
|
32
|
-
```bash
|
33
|
-
rails generate madmin:install
|
34
|
-
```
|
35
|
-
|
36
|
-
## Generating Resources
|
37
|
-
|
38
|
-
To generate (or re-generate) a Madmin dashboard for a resource, you
|
39
|
-
can run the following command and pass in the model name
|
11
|
+
Add `madmin` to your application's Gemfile:
|
40
12
|
|
41
13
|
```bash
|
42
|
-
|
14
|
+
bundle add madmin
|
43
15
|
```
|
44
16
|
|
45
|
-
|
46
|
-
|
47
|
-
To implement user authentication for your admin dashboard, you can override `authenticate!` in `app/controllers/madmin/application_controller.rb`.
|
48
|
-
|
49
|
-
To access this controller run the following command
|
17
|
+
Then run the madmin generator:
|
50
18
|
|
51
19
|
```bash
|
52
|
-
rails
|
53
|
-
```
|
54
|
-
|
55
|
-
If you're using Devise, simply have `authenticate!` authenticate your resource
|
56
|
-
|
57
|
-
```ruby
|
58
|
-
class Madmin::ApplicationController < Madmin::BaseController
|
59
|
-
...
|
60
|
-
|
61
|
-
private
|
62
|
-
|
63
|
-
def authenticate!
|
64
|
-
authenticate_user!
|
65
|
-
end
|
66
|
-
end
|
67
|
-
```
|
68
|
-
|
69
|
-
If you're wanting to use simple HTTP Basic authentication, have `authenticate!` use `authenticate_with_http_basic` like the following
|
70
|
-
|
71
|
-
```ruby
|
72
|
-
class Madmin::ApplicationController < Madmin::BaseController
|
73
|
-
...
|
74
|
-
|
75
|
-
private
|
76
|
-
|
77
|
-
def authenticate!
|
78
|
-
authenticated = authenticate_with_http_basic { |user, password|
|
79
|
-
user == "user" && password == "password"
|
80
|
-
}
|
81
|
-
|
82
|
-
request_http_basic_authentication unless authenticated
|
83
|
-
end
|
84
|
-
end
|
85
|
-
```
|
86
|
-
|
87
|
-
## Autoloading Lib
|
88
|
-
|
89
|
-
If you want to avoid having to restart your Rails application everytime you make an adjustment to a `lib/madmin/resources.rb`, add the following to `config/application.rb`:
|
90
|
-
|
91
|
-
```ruby
|
92
|
-
# Autoload Madmin
|
93
|
-
config.autoload_paths += Dir["#{config.root}/lib/madmin/**/"]
|
20
|
+
rails g madmin:install
|
94
21
|
```
|
95
22
|
|
96
23
|
## Contributing
|
97
|
-
|
98
24
|
Contribution directions go here.
|
99
25
|
|
100
26
|
## License
|
101
|
-
|
102
27
|
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
|
data/Rakefile
CHANGED
@@ -8,17 +8,12 @@ require "rdoc/task"
|
|
8
8
|
|
9
9
|
RDoc::Task.new(:rdoc) do |rdoc|
|
10
10
|
rdoc.rdoc_dir = "rdoc"
|
11
|
-
rdoc.title
|
11
|
+
rdoc.title = "Madmin"
|
12
12
|
rdoc.options << "--line-numbers"
|
13
13
|
rdoc.rdoc_files.include("README.md")
|
14
14
|
rdoc.rdoc_files.include("lib/**/*.rb")
|
15
15
|
end
|
16
16
|
|
17
|
-
APP_RAKEFILE = File.expand_path("test/dummy/Rakefile", __dir__)
|
18
|
-
load "rails/tasks/engine.rake"
|
19
|
-
|
20
|
-
load "rails/tasks/statistics.rake"
|
21
|
-
|
22
17
|
require "bundler/gem_tasks"
|
23
18
|
|
24
19
|
require "rake/testtask"
|
@@ -0,0 +1,36 @@
|
|
1
|
+
//
|
2
|
+
// Provides a drop-in pointer for the default Trix stylesheet that will format the toolbar and
|
3
|
+
// the trix-editor content (whether displayed or under editing). Feel free to incorporate this
|
4
|
+
// inclusion directly in any other asset bundle and remove this file.
|
5
|
+
//
|
6
|
+
//= require trix/dist/trix
|
7
|
+
|
8
|
+
// We need to override trix.css’s image gallery styles to accommodate the
|
9
|
+
// <action-text-attachment> element we wrap around attachments. Otherwise,
|
10
|
+
// images in galleries will be squished by the max-width: 33%; rule.
|
11
|
+
.trix-content {
|
12
|
+
.attachment-gallery {
|
13
|
+
> action-text-attachment,
|
14
|
+
> .attachment {
|
15
|
+
flex: 1 0 33%;
|
16
|
+
padding: 0 0.5em;
|
17
|
+
max-width: 33%;
|
18
|
+
}
|
19
|
+
|
20
|
+
&.attachment-gallery--2,
|
21
|
+
&.attachment-gallery--4 {
|
22
|
+
> action-text-attachment,
|
23
|
+
> .attachment {
|
24
|
+
flex-basis: 50%;
|
25
|
+
max-width: 50%;
|
26
|
+
}
|
27
|
+
}
|
28
|
+
}
|
29
|
+
|
30
|
+
action-text-attachment {
|
31
|
+
.attachment {
|
32
|
+
padding: 0 !important;
|
33
|
+
max-width: 100% !important;
|
34
|
+
}
|
35
|
+
}
|
36
|
+
}
|
@@ -2,8 +2,8 @@
|
|
2
2
|
* This is a manifest file that'll be compiled into application.css, which will include all the files
|
3
3
|
* listed below.
|
4
4
|
*
|
5
|
-
* Any CSS and SCSS file within this directory, lib/assets/stylesheets,
|
6
|
-
*
|
5
|
+
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, or any plugin's
|
6
|
+
* vendor/assets/stylesheets directory can be referenced here using a relative path.
|
7
7
|
*
|
8
8
|
* You're free to add application-wide styles to this file and they'll appear at the bottom of the
|
9
9
|
* compiled file so the styles you add here take precedence over styles defined in any other CSS/SCSS
|
@@ -13,10 +13,3 @@
|
|
13
13
|
*= require_tree .
|
14
14
|
*= require_self
|
15
15
|
*/
|
16
|
-
|
17
|
-
.sidebar {
|
18
|
-
height: 100%;
|
19
|
-
left: 0;
|
20
|
-
position: fixed;
|
21
|
-
top: 0;
|
22
|
-
}
|
@@ -1,16 +1,12 @@
|
|
1
1
|
module Madmin
|
2
|
-
class ApplicationController <
|
3
|
-
|
4
|
-
|
5
|
-
before_action :authenticate!
|
2
|
+
class ApplicationController < ActionController::Base
|
3
|
+
include Pagy::Backend
|
6
4
|
|
7
|
-
|
5
|
+
protect_from_forgery with: :exception
|
8
6
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
# If using Devise, set this method to call:
|
13
|
-
# authenticate_user!
|
7
|
+
# Loads all the models for the sidebar
|
8
|
+
before_action do
|
9
|
+
Rails.application.eager_load!
|
14
10
|
end
|
15
11
|
end
|
16
12
|
end
|
@@ -0,0 +1,72 @@
|
|
1
|
+
module Madmin
|
2
|
+
class ResourceController < ApplicationController
|
3
|
+
before_action :set_record, except: [:index, :new, :create]
|
4
|
+
|
5
|
+
def index
|
6
|
+
@pagy, @records = pagy(resource.model.all)
|
7
|
+
end
|
8
|
+
|
9
|
+
def show
|
10
|
+
end
|
11
|
+
|
12
|
+
def new
|
13
|
+
@record = resource.model.new
|
14
|
+
end
|
15
|
+
|
16
|
+
def create
|
17
|
+
@record = resource.model.new(resource_params)
|
18
|
+
if @record.save
|
19
|
+
redirect_to resource.show_path(@record)
|
20
|
+
else
|
21
|
+
render :new
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
def edit
|
26
|
+
end
|
27
|
+
|
28
|
+
def update
|
29
|
+
if @record.update(resource_params)
|
30
|
+
redirect_to resource.show_path(@record)
|
31
|
+
else
|
32
|
+
render :edit
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def destroy
|
37
|
+
@record.destroy
|
38
|
+
redirect_to resource.index_path
|
39
|
+
end
|
40
|
+
|
41
|
+
private
|
42
|
+
|
43
|
+
def set_record
|
44
|
+
@record = resource.model.find(params[:id])
|
45
|
+
end
|
46
|
+
|
47
|
+
def resource
|
48
|
+
@resource ||= resource_name.constantize
|
49
|
+
end
|
50
|
+
helper_method :resource
|
51
|
+
|
52
|
+
def resource_name
|
53
|
+
"#{controller_path.singularize}_resource".delete_prefix("madmin/").classify
|
54
|
+
end
|
55
|
+
|
56
|
+
def resource_params
|
57
|
+
params.require(resource.param_key)
|
58
|
+
.permit(*resource.permitted_params)
|
59
|
+
.transform_values { |v| change_polymorphic(v) }
|
60
|
+
end
|
61
|
+
|
62
|
+
def change_polymorphic(data)
|
63
|
+
return data unless data.is_a?(ActionController::Parameters) && data[:type]
|
64
|
+
|
65
|
+
if data[:type] == "polymorphic"
|
66
|
+
GlobalID::Locator.locate(data[:value])
|
67
|
+
else
|
68
|
+
raise "Unrecognised param data: #{data.inspect}"
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
@@ -1,15 +1,5 @@
|
|
1
1
|
module Madmin
|
2
2
|
module ApplicationHelper
|
3
|
-
|
4
|
-
@available_resources ||= Madmin::Resources.gather.map { |model| madmin_resource_for(model: model) }
|
5
|
-
end
|
6
|
-
|
7
|
-
def madmin_resource_for(model:)
|
8
|
-
Object.const_get("::Madmin::Resources::#{model}").new
|
9
|
-
end
|
10
|
-
|
11
|
-
def pages
|
12
|
-
Madmin::Pages.all
|
13
|
-
end
|
3
|
+
include Pagy::Frontend
|
14
4
|
end
|
15
5
|
end
|
@@ -1,30 +1,29 @@
|
|
1
1
|
<!DOCTYPE html>
|
2
|
-
<html>
|
3
|
-
<head>
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
<
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
2
|
+
<html lang="<%= I18n.locale %>">
|
3
|
+
<head>
|
4
|
+
<meta charset="utf-8">
|
5
|
+
<meta name="ROBOTS" content="NOODP">
|
6
|
+
<meta name="viewport" content="initial-scale=1">
|
7
|
+
<title>
|
8
|
+
Madmin: <%= Rails.application.class %>
|
9
|
+
</title>
|
10
|
+
<link href="https://unpkg.com/tailwindcss@^2.0/dist/tailwind.min.css" rel="stylesheet" />
|
11
|
+
<link href="https://unpkg.com/@tailwindcss/forms/dist/forms.min.css" rel="stylesheet" />
|
12
|
+
<link href="https://unpkg.com/@tailwindcss/typography/dist/typography.min.css" rel="stylesheet" />
|
13
|
+
<%= stylesheet_link_tag "application", "data-turbo-track": "reload" %>
|
14
|
+
<%= javascript_pack_tag "madmin", "data-turbo-track": "reload" %>
|
15
|
+
<%= csrf_meta_tags %>
|
16
|
+
</head>
|
17
|
+
<body class="prose" style="max-width:none">
|
18
|
+
<div class="flex w-full p-4">
|
19
|
+
<div id="sidebar" class="w-64 flex-shrink-0">
|
20
|
+
<%= render "navigation" -%>
|
20
21
|
</div>
|
22
|
+
<main class="w-full" role="main">
|
23
|
+
<%#= render "flashes" -%>
|
24
|
+
<%= yield %>
|
25
|
+
</main>
|
21
26
|
</div>
|
22
|
-
|
23
|
-
|
24
|
-
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
|
25
|
-
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
|
26
|
-
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
|
27
|
-
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
|
28
|
-
<%= javascript_include_tag "madmin/application" %>
|
29
|
-
</body>
|
27
|
+
<%#= render "javascript" %>
|
28
|
+
</body>
|
30
29
|
</html>
|
@@ -0,0 +1,25 @@
|
|
1
|
+
<%= form_with model: [:madmin, record], url: (record.persisted? ? resource.show_path(record) : resource.index_path), local: true do |form| %>
|
2
|
+
<% if form.object.errors.any? %>
|
3
|
+
<div class="mb-4 rounded-md text-sm text-red-700 bg-red-100 p-4">
|
4
|
+
<div class="mb-2 font-medium leading-5 text-red-800">There was <%= pluralize form.object.errors.full_messages.count, "error" %> with your submission</div>
|
5
|
+
|
6
|
+
<% form.object.errors.full_messages.each do |message| %>
|
7
|
+
<div class="ml-4"><%= message %></div>
|
8
|
+
<% end %>
|
9
|
+
</div>
|
10
|
+
<% end %>
|
11
|
+
|
12
|
+
<% resource.attributes.each do |attribute| %>
|
13
|
+
<% next if attribute[:field].nil? %>
|
14
|
+
<% next unless attribute[:field].visible?(action_name) %>
|
15
|
+
<% next unless attribute[:field].visible?(:form) %>
|
16
|
+
|
17
|
+
<% field = attribute[:field] %>
|
18
|
+
|
19
|
+
<div class="mb-4 flex">
|
20
|
+
<%= render partial: field.to_partial_path("form"), locals: { field: field, record: record, form: form, resource: resource } %>
|
21
|
+
</div>
|
22
|
+
<% end %>
|
23
|
+
|
24
|
+
<%= form.submit class: "bg-white hover:bg-gray-100 text-gray-800 font-semibold py-2 px-4 border border-gray-400 rounded shadow" %>
|
25
|
+
<% end %>
|
@@ -0,0 +1,6 @@
|
|
1
|
+
<div class="text-sm">
|
2
|
+
<%= link_to "← Back to App", main_app.root_url, class: "block p-1" if main_app.respond_to?(:root_url) %>
|
3
|
+
<% Madmin.resources.each do |resource| %>
|
4
|
+
<%= link_to resource.friendly_name.pluralize, resource.index_path, class: "block p-1" %>
|
5
|
+
<% end %>
|
6
|
+
</div>
|
@@ -0,0 +1,35 @@
|
|
1
|
+
<h1><%= resource.friendly_name.pluralize %></h1>
|
2
|
+
<%= link_to "New #{resource.friendly_name}", resource.new_path %>
|
3
|
+
|
4
|
+
<table class="table-auto">
|
5
|
+
<thead>
|
6
|
+
<tr>
|
7
|
+
<% resource.attributes.each do |attribute| %>
|
8
|
+
<% next if attribute[:field].nil? %>
|
9
|
+
<% next unless attribute[:field].visible?(action_name) %>
|
10
|
+
|
11
|
+
<th><%= attribute[:name].to_s.titleize %></th>
|
12
|
+
<% end %>
|
13
|
+
<th>Actions</th>
|
14
|
+
</tr>
|
15
|
+
</thead>
|
16
|
+
|
17
|
+
<tbody>
|
18
|
+
<% @records.each do |record| %>
|
19
|
+
<tr>
|
20
|
+
<% resource.attributes.each do |attribute| %>
|
21
|
+
<% next if attribute[:field].nil? %>
|
22
|
+
<% next unless attribute[:field].visible?(action_name) %>
|
23
|
+
|
24
|
+
<% field = attribute[:field] %>
|
25
|
+
|
26
|
+
<td><%= render partial: field.to_partial_path("index"), locals: { field: field, record: record } %></td>
|
27
|
+
<% end %>
|
28
|
+
|
29
|
+
<td><%= link_to "View", resource.show_path(record) %></td>
|
30
|
+
</tr>
|
31
|
+
<% end %>
|
32
|
+
</tbody>
|
33
|
+
</table>
|
34
|
+
|
35
|
+
<%== pagy_nav(@pagy) if @pagy.pages > 1 %>
|