-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #105 from MITLibraries/tco-85
Add Detectors, Categories, and DetectorCategories to administrate dashboard
- Loading branch information
Showing
9 changed files
with
391 additions
and
20 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
# frozen_string_literal: true | ||
|
||
module Admin | ||
class CategoriesController < Admin::ApplicationController | ||
# Overwrite any of the RESTful controller actions to implement custom behavior | ||
# For example, you may want to send an email after a foo is updated. | ||
# | ||
# def update | ||
# super | ||
# send_foo_updated_email(requested_resource) | ||
# end | ||
|
||
# Override this method to specify custom lookup behavior. | ||
# This will be used to set the resource for the `show`, `edit`, and `update` | ||
# actions. | ||
# | ||
# def find_resource(param) | ||
# Foo.find_by!(slug: param) | ||
# end | ||
|
||
# The result of this lookup will be available as `requested_resource` | ||
|
||
# Override this if you have certain roles that require a subset | ||
# this will be used to set the records shown on the `index` action. | ||
# | ||
# def scoped_resource | ||
# if current_user.super_admin? | ||
# resource_class | ||
# else | ||
# resource_class.with_less_stuff | ||
# end | ||
# end | ||
|
||
# Override `resource_params` if you want to transform the submitted | ||
# data before it's persisted. For example, the following would turn all | ||
# empty values into nil values. It uses other APIs such as `resource_class` | ||
# and `dashboard`: | ||
# | ||
# def resource_params | ||
# params.require(resource_class.model_name.param_key). | ||
# permit(dashboard.permitted_attributes(action_name)). | ||
# transform_values { |value| value == "" ? nil : value } | ||
# end | ||
|
||
# See https://administrate-demo.herokuapp.com/customizing_controller_actions | ||
# for more information | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
# frozen_string_literal: true | ||
|
||
module Admin | ||
class DetectorCategoriesController < Admin::ApplicationController | ||
# Overwrite any of the RESTful controller actions to implement custom behavior | ||
# For example, you may want to send an email after a foo is updated. | ||
# | ||
# def update | ||
# super | ||
# send_foo_updated_email(requested_resource) | ||
# end | ||
|
||
# Override this method to specify custom lookup behavior. | ||
# This will be used to set the resource for the `show`, `edit`, and `update` | ||
# actions. | ||
# | ||
# def find_resource(param) | ||
# Foo.find_by!(slug: param) | ||
# end | ||
|
||
# The result of this lookup will be available as `requested_resource` | ||
|
||
# Override this if you have certain roles that require a subset | ||
# this will be used to set the records shown on the `index` action. | ||
# | ||
# def scoped_resource | ||
# if current_user.super_admin? | ||
# resource_class | ||
# else | ||
# resource_class.with_less_stuff | ||
# end | ||
# end | ||
|
||
# Override `resource_params` if you want to transform the submitted | ||
# data before it's persisted. For example, the following would turn all | ||
# empty values into nil values. It uses other APIs such as `resource_class` | ||
# and `dashboard`: | ||
# | ||
# def resource_params | ||
# params.require(resource_class.model_name.param_key). | ||
# permit(dashboard.permitted_attributes(action_name)). | ||
# transform_values { |value| value == "" ? nil : value } | ||
# end | ||
|
||
# See https://administrate-demo.herokuapp.com/customizing_controller_actions | ||
# for more information | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
# frozen_string_literal: true | ||
|
||
module Admin | ||
class DetectorsController < Admin::ApplicationController | ||
# Overwrite any of the RESTful controller actions to implement custom behavior | ||
# For example, you may want to send an email after a foo is updated. | ||
# | ||
# def update | ||
# super | ||
# send_foo_updated_email(requested_resource) | ||
# end | ||
|
||
# Override this method to specify custom lookup behavior. | ||
# This will be used to set the resource for the `show`, `edit`, and `update` | ||
# actions. | ||
# | ||
# def find_resource(param) | ||
# Foo.find_by!(slug: param) | ||
# end | ||
|
||
# The result of this lookup will be available as `requested_resource` | ||
|
||
# Override this if you have certain roles that require a subset | ||
# this will be used to set the records shown on the `index` action. | ||
# | ||
# def scoped_resource | ||
# if current_user.super_admin? | ||
# resource_class | ||
# else | ||
# resource_class.with_less_stuff | ||
# end | ||
# end | ||
|
||
# Override `resource_params` if you want to transform the submitted | ||
# data before it's persisted. For example, the following would turn all | ||
# empty values into nil values. It uses other APIs such as `resource_class` | ||
# and `dashboard`: | ||
# | ||
# def resource_params | ||
# params.require(resource_class.model_name.param_key). | ||
# permit(dashboard.permitted_attributes(action_name)). | ||
# transform_values { |value| value == "" ? nil : value } | ||
# end | ||
|
||
# See https://administrate-demo.herokuapp.com/customizing_controller_actions | ||
# for more information | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
# frozen_string_literal: true | ||
|
||
require 'administrate/base_dashboard' | ||
|
||
class CategoryDashboard < Administrate::BaseDashboard | ||
# ATTRIBUTE_TYPES | ||
# a hash that describes the type of each of the model's fields. | ||
# | ||
# Each different type represents an Administrate::Field object, | ||
# which determines how the attribute is displayed | ||
# on pages throughout the dashboard. | ||
ATTRIBUTE_TYPES = { | ||
id: Field::Number, | ||
description: Field::Text, | ||
detector_categories: Field::HasMany, | ||
detectors: Field::HasMany, | ||
name: Field::String, | ||
created_at: Field::DateTime, | ||
updated_at: Field::DateTime | ||
}.freeze | ||
|
||
# COLLECTION_ATTRIBUTES | ||
# an array of attributes that will be displayed on the model's index page. | ||
# | ||
# By default, it's limited to four items to reduce clutter on index pages. | ||
# Feel free to add, remove, or rearrange items. | ||
COLLECTION_ATTRIBUTES = %i[ | ||
id | ||
name | ||
description | ||
detector_categories | ||
detectors | ||
].freeze | ||
|
||
# SHOW_PAGE_ATTRIBUTES | ||
# an array of attributes that will be displayed on the model's show page. | ||
SHOW_PAGE_ATTRIBUTES = %i[ | ||
id | ||
name | ||
description | ||
detector_categories | ||
detectors | ||
created_at | ||
updated_at | ||
].freeze | ||
|
||
# FORM_ATTRIBUTES | ||
# an array of attributes that will be displayed | ||
# on the model's form (`new` and `edit`) pages. | ||
FORM_ATTRIBUTES = %i[ | ||
name | ||
description | ||
detector_categories | ||
detectors | ||
].freeze | ||
|
||
# COLLECTION_FILTERS | ||
# a hash that defines filters that can be used while searching via the search | ||
# field of the dashboard. | ||
# | ||
# For example to add an option to search for open resources by typing "open:" | ||
# in the search field: | ||
# | ||
# COLLECTION_FILTERS = { | ||
# open: ->(resources) { resources.where(open: true) } | ||
# }.freeze | ||
COLLECTION_FILTERS = {}.freeze | ||
|
||
# Overwrite this method to customize how categories are displayed | ||
# across all pages of the admin dashboard. | ||
# | ||
def display_resource(category) | ||
category.name | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
# frozen_string_literal: true | ||
|
||
require 'administrate/base_dashboard' | ||
|
||
class DetectorCategoryDashboard < Administrate::BaseDashboard | ||
# ATTRIBUTE_TYPES | ||
# a hash that describes the type of each of the model's fields. | ||
# | ||
# Each different type represents an Administrate::Field object, | ||
# which determines how the attribute is displayed | ||
# on pages throughout the dashboard. | ||
ATTRIBUTE_TYPES = { | ||
id: Field::Number, | ||
category: Field::BelongsTo, | ||
confidence: Field::Number.with_options(decimals: 2), | ||
detector: Field::BelongsTo, | ||
created_at: Field::DateTime, | ||
updated_at: Field::DateTime | ||
}.freeze | ||
|
||
# COLLECTION_ATTRIBUTES | ||
# an array of attributes that will be displayed on the model's index page. | ||
# | ||
# By default, it's limited to four items to reduce clutter on index pages. | ||
# Feel free to add, remove, or rearrange items. | ||
COLLECTION_ATTRIBUTES = %i[ | ||
id | ||
category | ||
detector | ||
confidence | ||
].freeze | ||
|
||
# SHOW_PAGE_ATTRIBUTES | ||
# an array of attributes that will be displayed on the model's show page. | ||
SHOW_PAGE_ATTRIBUTES = %i[ | ||
id | ||
category | ||
detector | ||
confidence | ||
created_at | ||
updated_at | ||
].freeze | ||
|
||
# FORM_ATTRIBUTES | ||
# an array of attributes that will be displayed | ||
# on the model's form (`new` and `edit`) pages. | ||
FORM_ATTRIBUTES = %i[ | ||
category | ||
detector | ||
confidence | ||
].freeze | ||
|
||
# COLLECTION_FILTERS | ||
# a hash that defines filters that can be used while searching via the search | ||
# field of the dashboard. | ||
# | ||
# For example to add an option to search for open resources by typing "open:" | ||
# in the search field: | ||
# | ||
# COLLECTION_FILTERS = { | ||
# open: ->(resources) { resources.where(open: true) } | ||
# }.freeze | ||
COLLECTION_FILTERS = {}.freeze | ||
|
||
# Overwrite this method to customize how detector categories are displayed | ||
# across all pages of the admin dashboard. | ||
# | ||
def display_resource(detector_category) | ||
"#{detector_category.category.name} - #{detector_category.detector.name} (#{detector_category.confidence})" | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
# frozen_string_literal: true | ||
|
||
require 'administrate/base_dashboard' | ||
|
||
class DetectorDashboard < Administrate::BaseDashboard | ||
# ATTRIBUTE_TYPES | ||
# a hash that describes the type of each of the model's fields. | ||
# | ||
# Each different type represents an Administrate::Field object, | ||
# which determines how the attribute is displayed | ||
# on pages throughout the dashboard. | ||
ATTRIBUTE_TYPES = { | ||
id: Field::Number, | ||
categories: Field::HasMany, | ||
detector_categories: Field::HasMany, | ||
name: Field::String, | ||
created_at: Field::DateTime, | ||
updated_at: Field::DateTime | ||
}.freeze | ||
|
||
# COLLECTION_ATTRIBUTES | ||
# an array of attributes that will be displayed on the model's index page. | ||
# | ||
# By default, it's limited to four items to reduce clutter on index pages. | ||
# Feel free to add, remove, or rearrange items. | ||
COLLECTION_ATTRIBUTES = %i[ | ||
id | ||
name | ||
categories | ||
detector_categories | ||
].freeze | ||
|
||
# SHOW_PAGE_ATTRIBUTES | ||
# an array of attributes that will be displayed on the model's show page. | ||
SHOW_PAGE_ATTRIBUTES = %i[ | ||
id | ||
name | ||
categories | ||
detector_categories | ||
created_at | ||
updated_at | ||
].freeze | ||
|
||
# FORM_ATTRIBUTES | ||
# an array of attributes that will be displayed | ||
# on the model's form (`new` and `edit`) pages. | ||
FORM_ATTRIBUTES = %i[ | ||
name | ||
categories | ||
detector_categories | ||
].freeze | ||
|
||
# COLLECTION_FILTERS | ||
# a hash that defines filters that can be used while searching via the search | ||
# field of the dashboard. | ||
# | ||
# For example to add an option to search for open resources by typing "open:" | ||
# in the search field: | ||
# | ||
# COLLECTION_FILTERS = { | ||
# open: ->(resources) { resources.where(open: true) } | ||
# }.freeze | ||
COLLECTION_FILTERS = {}.freeze | ||
|
||
# Overwrite this method to customize how detectors are displayed | ||
# across all pages of the admin dashboard. | ||
# | ||
def display_resource(detector) | ||
detector.name | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.