mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-09-29 00:14:41 +08:00
Improve expand/collapse for results [SCI-11918]
This commit is contained in:
parent
60ae88f64e
commit
4fc7cd5e01
4 changed files with 19 additions and 18 deletions
|
@ -443,6 +443,14 @@ class MyModulesController < ApplicationController
|
|||
render json: my_modules
|
||||
end
|
||||
|
||||
def change_results_state
|
||||
@my_module.results.find_each do |result|
|
||||
current_user.settings['result_states'][result.id.to_s] = params[:collapsed].present?
|
||||
end
|
||||
current_user.save!
|
||||
render json: { status: :ok }
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def load_vars
|
||||
|
|
|
@ -74,7 +74,8 @@ export default {
|
|||
archived: { type: String, required: true },
|
||||
active_url: { type: String, required: true },
|
||||
archived_url: { type: String, required: true },
|
||||
userSettingsUrl: { type: String, required: false }
|
||||
userSettingsUrl: { type: String, required: false },
|
||||
changeStatesUrl: { type: String, required: false }
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
|
@ -218,25 +219,15 @@ export default {
|
|||
this.resultsCollapsed = false;
|
||||
},
|
||||
updateResultStateSettings(newState) {
|
||||
const updatedData = this.results.reduce((acc, currentResult) => {
|
||||
acc[currentResult.id] = newState;
|
||||
return acc;
|
||||
}, {});
|
||||
const data = {};
|
||||
|
||||
this.results = this.results.map((result) => ({
|
||||
...result,
|
||||
attributes: {
|
||||
...result.attributes,
|
||||
collapsed: newState
|
||||
}
|
||||
}));
|
||||
if (newState) {
|
||||
data.collapsed = true;
|
||||
} else {
|
||||
data.expanded = true;
|
||||
}
|
||||
|
||||
const settings = {
|
||||
key: 'result_states',
|
||||
data: updatedData
|
||||
};
|
||||
|
||||
axios.put(this.userSettingsUrl, { settings: [settings] });
|
||||
axios.post(this.changeStatesUrl, data);
|
||||
},
|
||||
removeResult(result_id) {
|
||||
this.results = this.results.filter((r) => r.id != result_id);
|
||||
|
|
|
@ -21,6 +21,7 @@
|
|||
<results url="<%= my_module_results_url(@my_module, view_mode: params[:view_mode]) %>"
|
||||
active_url="<%= my_module_results_url(@my_module) %>"
|
||||
archived_url="<%= my_module_results_url(@my_module, view_mode: :archived) %>"
|
||||
change-states-url="<%= change_results_state_my_module_path(@my_module) %>"
|
||||
can-create=<%= can_create_results?(@my_module) && !(params[:view_mode] == 'archived') %>
|
||||
archived=<%= params[:view_mode] == 'archived' %>>
|
||||
</div>
|
||||
|
|
|
@ -478,6 +478,7 @@ Rails.application.routes.draw do
|
|||
get :permissions
|
||||
get :actions_dropdown
|
||||
get :provisioning_status
|
||||
post :change_results_state
|
||||
end
|
||||
resources :my_module_tags, path: '/tags', only: [:index, :create, :destroy] do
|
||||
collection do
|
||||
|
|
Loading…
Add table
Reference in a new issue