Skip to content

Commit

Permalink
Prototyping an initial implementation for the disk storage quota usag…
Browse files Browse the repository at this point in the history
…e component in the Project Show View
  • Loading branch information
jrgriffiniii committed Dec 19, 2024
1 parent 11044ca commit 2a58a1e
Show file tree
Hide file tree
Showing 8 changed files with 327 additions and 131 deletions.
159 changes: 84 additions & 75 deletions app/assets/stylesheets/_projects.scss
Original file line number Diff line number Diff line change
Expand Up @@ -3,94 +3,103 @@
@import "bootstrap";

#project-details-heading {
margin-bottom: 1.5em;
margin-bottom: 1.5em;

.status {
float: right;
border-radius: 0.5em;
padding: 0.5em 0.75em 0.5em 0.5em;
text-transform: capitalize;
font-weight: bold;
}
.status {
float: right;
border-radius: 0.5em;
padding: 0.5em 0.75em 0.5em 0.5em;
text-transform: capitalize;
font-weight: bold;
}

.status::before {
content: "";
width: 20px;
height: 20px;
}
.status::before {
content: "";
width: 20px;
height: 20px;
}

.active {
background: url("status_active.svg") no-repeat;
background-color: $status-info;
background-position: left;
padding-left: 20px;
color: $blue-dark;
}
.active {
background: url("status_active.svg") no-repeat;
background-color: $status-info;
background-position: left;
padding-left: 20px;
color: $blue-dark;
}

.pending {
background: url("status_pending.svg") no-repeat;
background-color: $status-warning;
background-position: left;
padding-left: 20px;
color: $yellow-dark;
.pending {
background: url("status_pending.svg") no-repeat;
background-color: $status-warning;
background-position: left;
padding-left: 20px;
color: $yellow-dark;

}
}

.approved {
background: url("status_approved.svg") no-repeat;
background-color: $status-success;
background-position: left;
padding-left: 20px;
color: $green-dark;
}
.approved {
background: url("status_approved.svg") no-repeat;
background-color: $status-success;
background-position: left;
padding-left: 20px;
color: $green-dark;
}

.rejected {
background: url("status_rejected.svg") no-repeat;
background-color: $status-error;
background-position: left;
padding-left: 20px;
color: $red-darker;
}
#project-description {
color: $black;
font-family: "Libre Franklin";
font-size: 1em;
font-style: normal;
font-weight: 400;
line-height: 1.5em;
}
.rejected {
background: url("status_rejected.svg") no-repeat;
background-color: $status-error;
background-position: left;
padding-left: 20px;
color: $red-darker;
}

#project-description {
color: $black;
font-family: "Libre Franklin";
font-size: 1em;
font-style: normal;
font-weight: 400;
line-height: 1.5em;
}

.truncate {
overflow: hidden;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
}
.truncate {
overflow: hidden;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
}

a#show-more-less-link {
color: $gray-60;
}
a#show-more-less-link {
color: $gray-60;
}

.label {
font-weight: bold;
}

.date-and-data-info ul {
padding: 0;
}

.date-and-data-info li {
float: left;
list-style-type: none;
line-height: 1em;
}

.date-and-data-info li:first-child:after {
content: "|";
padding: 0 .5em;
}

.label {
.storage-quota {
border-radius: 0.5rem;
&-total {
font-weight: bold;
}

.date-and-data-info ul {
padding: 0;
}

.date-and-data-info li {
float: left;
list-style-type: none;
line-height: 1em;
@include media-breakpoint-up(lg) {
max-width: 75%;
}

.date-and-data-info li:first-child:after {
content: "|";
padding: 0 .5em;
}

}
}

.latest-download-link {
Expand Down
6 changes: 5 additions & 1 deletion app/assets/stylesheets/_variables.scss
Original file line number Diff line number Diff line change
Expand Up @@ -29,4 +29,8 @@ $status-error: #F3D9D9;
$status-warning: #FFF6DF;
$status-info: #E6EEF8;

$libre-franklin: "Libre Franklin", sans-serif;
$libre-franklin: "Libre Franklin", sans-serif;

$progress-bar-bg: $princeton-orange;
$progress-height: 2rem;

4 changes: 3 additions & 1 deletion app/javascript/entrypoints/pulDataTables.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,9 @@ export function setupTable(tableId) {

// If we have a table initialize it with DataTables
if (table) {
table.dataTable(datasetOptions);
if (table.dataTable) {
table.dataTable(datasetOptions);
}
}
}

Expand Down
6 changes: 5 additions & 1 deletion app/models/project.rb
Original file line number Diff line number Diff line change
Expand Up @@ -212,8 +212,12 @@ def asset_count(session_id:)
values.fetch(:total_file_count, 0)
end

def self.default_storage_unit
"KB"
end

def self.default_storage_usage
"0 KB"
"0 {default_storage_unit}"
end

def storage_usage(session_id:)
Expand Down
104 changes: 103 additions & 1 deletion app/presenters/project_show_presenter.rb
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# frozen_string_literal: true
class ProjectShowPresenter
delegate "id", "in_mediaflux?", "mediaflux_id", "pending?", "status", "title", to: :project
delegate "description", "project_id", "storage_capacity", "storage_performance_expectations", "project_purpose", to: :project_metadata
delegate "description", "project_id", "storage_performance_expectations", "project_purpose", to: :project_metadata

attr_reader :project, :project_metadata

Expand Down Expand Up @@ -30,4 +30,106 @@ def data_manager
def project_directory
project.project_directory.gsub(Mediaflux::Connection.hidden_root, "")
end

# This might not be needed
def storage_unit
return Project.default_storage_unit unless project.metadata.key?("storage_capacity")

root = project.metadata["storage_capacity"]
return Project.default_storage_unit unless root.key?("unit")

units = root["unit"]
return Project.default_storage_unit unless units.key?("approved")

units["approved"]
end

# This might not be needed
def storage_unit_tb?
storage_unit == "TB"
end

# This might not be needed
def storage_unit_gb?
storage_unit == "GB"
end

# This might not be needed
def storage_unit_mb?
storage_unit == "MB"
end

# This might not be needed
def divisor
if storage_unit_tb?
1024.0
elsif storage_unit_gb?
1.0
elsif storage_unit_mb?
1.0/(1024.0**1)
else
1.0/(1024.0**2)
end
end

# Usage is in MB
def default_usage_divisor
1.0/(1024.0**1)
end

# Capacity is in bytes
def default_capacity_divisor
1.0/(1024.0**3)
end

# This assumed that the storage usage is recorded in the same units as the units specified in the StorageCapacity metadata
def storage_usage(session_id:)
persisted = project.storage_usage_raw(session_id: session_id)
value = persisted.to_f

value*default_usage_divisor
end

def formatted_storage_usage(session_id:)
value = storage_usage(session_id: session_id)
format("%.3f", value)
end

def storage_capacity(session_id: nil)
return project_metadata.storage_capacity if session_id.nil?

persisted = project.storage_capacity_raw(session_id: session_id)
value = persisted.to_f

value*default_capacity_divisor
end

def formatted_storage_capacity(session_id:)
value = storage_capacity(session_id: session_id)
format("%.3f", value)
end

def storage_remaining(session_id:)
capacity = storage_capacity(session_id: session_id)
return 0.0 if capacity.zero?

usage = storage_usage(session_id: session_id)

capacity - usage
end

def formatted_storage_remaining(session_id:)
value = storage_remaining(session_id:)
format("%.3f", value)
end

def storage_usage_percent(session_id:)
capacity = storage_capacity(session_id: session_id)
return 0.0 if capacity.zero?

usage = storage_usage(session_id: session_id)

value = (usage/capacity)*100.0
format("%.1f", value)
end
end
Loading

0 comments on commit 2a58a1e

Please sign in to comment.