diff --git a/app/assets/stylesheets/shared/content/text.scss b/app/assets/stylesheets/shared/content/text.scss index 8be86e487..049c7573e 100644 --- a/app/assets/stylesheets/shared/content/text.scss +++ b/app/assets/stylesheets/shared/content/text.scss @@ -27,7 +27,7 @@ max-width: 100%; } - .content__text-body:hover:not(.edit):not(.locked) { + .content__text-body:hover:not(.edit):not(.component__element--locked) { background: $color-concrete; } } diff --git a/app/controllers/results_controller.rb b/app/controllers/results_controller.rb index aa0eeb97c..f32b977c4 100644 --- a/app/controllers/results_controller.rb +++ b/app/controllers/results_controller.rb @@ -4,7 +4,7 @@ class ResultsController < ApplicationController include Breadcrumbs skip_before_action :verify_authenticity_token, only: %i(create update destroy duplicate) before_action :load_my_module - before_action :load_vars, only: %i(destroy elements assets upload_attachment + before_action :load_vars, only: %i(destroy elements assets upload_attachment archive restore destroy update_view_state update_asset_view_mode update duplicate) before_action :check_destroy_permissions, only: :destroy before_action :set_breadcrumbs_items, only: %i(index) @@ -14,7 +14,11 @@ class ResultsController < ApplicationController respond_to do |format| format.json do # API endpoint - @results = @my_module.results.active + @results = if params[:view_mode] == 'archived' + @my_module.results.archived + else + @my_module.results.active + end apply_sort! apply_filters! @@ -56,23 +60,18 @@ class ResultsController < ApplicationController end def archive - result = @my_module.results.find(params[:result_id]) - result.archive(current_user) + if @result.archive(current_user) + render json: {}, status: :ok + else + render json: { errors: @result.errors.full_messages }, status: :unprocessable_entity + end + end - if result.save - Activities::CreateActivityService - .call(activity_type: :destroy_result, - owner: current_user, - subject: result, - team: @my_module.team, - project: @my_module.project, - message_items: { result: result.id }) - - flash[:success] = t('my_modules.module_archive.archive_flash', - result: result.name, - module: @my_module.name) - - redirect_to my_module_results_path(@my_module) + def restore + if @result.restore(current_user) + render json: {}, status: :ok + else + render json: { errors: @result.errors.full_messages }, status: :unprocessable_entity end end @@ -126,26 +125,11 @@ class ResultsController < ApplicationController end def destroy - result_type = if @result.is_text - t('activities.result_type.text') - elsif @result.is_table - t('activities.result_type.table') - elsif @result.is_asset - t('activities.result_type.asset') - end - Activities::CreateActivityService - .call(activity_type: :destroy_result, - owner: current_user, - subject: @result, - team: @my_module.team, - project: @my_module.project, - message_items: { result: @result.id, - type_of_result: result_type }) - flash[:success] = t('my_modules.module_archive.delete_flash', - result: @result.name, - module: @my_module.name) - @result.destroy - redirect_to archive_my_module_path(@my_module) + if @result.destroy + render json: {}, status: :ok + else + render json: { errors: @result.errors.full_messages }, status: :unprocessable_entity + end end def duplicate diff --git a/app/helpers/secondary_navigation_helper.rb b/app/helpers/secondary_navigation_helper.rb index a08da817e..fc4fd9484 100644 --- a/app/helpers/secondary_navigation_helper.rb +++ b/app/helpers/secondary_navigation_helper.rb @@ -41,7 +41,7 @@ module SecondaryNavigationHelper end def is_module_results? - %w(index).include?(action_name) && controller_name == 'results' + %w(index).include?(action_name) && controller_name == 'results' && !%w(archived).include?(params[:view_mode]) end def is_module_activities? @@ -49,7 +49,7 @@ module SecondaryNavigationHelper end def is_module_archive? - action_name == 'archive' + %w(index).include?(action_name) && controller_name == 'results' && %w(archived).include?(params[:view_mode]) end def title_element diff --git a/app/javascript/vue/results/result.vue b/app/javascript/vue/results/result.vue index 937b85853..ce0269db8 100644 --- a/app/javascript/vue/results/result.vue +++ b/app/javascript/vue/results/result.vue @@ -4,7 +4,7 @@
@@ -334,16 +340,23 @@ }); }, archiveResult() { - if (this.urls.archive_url) { - axios.post(this.urls.archive_url).then((response) => { - this.$emit('resultArchived', response.data); - location.reload(); - }); - } + axios.post(this.urls.archive_url).then((response) => { + this.$emit('result:archived', this.result.attributes.id); + }); + }, + restoreResult() { + axios.post(this.urls.restore_url).then((response) => { + this.$emit('result:restored', this.result.attributes.id); + }); + }, + deleteResult() { + axios.delete(this.urls.delete_url).then((response) => { + this.$emit('result:deleted', this.result.attributes.id); + }); }, duplicateResult() { axios.post(this.urls.duplicate_url).then((_) => { - this.$emit('duplicated'); + this.$emit('result:duplicated'); }); }, moveElement(position, target_id) { diff --git a/app/javascript/vue/results/results.vue b/app/javascript/vue/results/results.vue index f3cf7ca64..1f4b77fb5 100644 --- a/app/javascript/vue/results/results.vue +++ b/app/javascript/vue/results/results.vue @@ -1,6 +1,7 @@