From 5c8c6ed1960020e0958cf021f5f53e98de97fe8f Mon Sep 17 00:00:00 2001 From: Alexander Machehin Date: Thu, 19 Mar 2015 22:24:54 +0500 Subject: [PATCH 1/5] repository projects: ajax remove project + flash --- .../repository_projects_controller.js.coffee | 12 +- app/assets/javascripts/lib/notifier.js | 105 ++++++++++++++++++ app/assets/javascripts/new_application.js | 3 +- .../platforms/repositories_controller.rb | 6 +- .../repositories/_proj_list.html.slim | 7 +- .../repositories/_project.json.jbuilder | 1 + 6 files changed, 127 insertions(+), 7 deletions(-) create mode 100644 app/assets/javascripts/lib/notifier.js diff --git a/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee b/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee index e46915526..4cdf9e3ce 100644 --- a/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee +++ b/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee @@ -1,4 +1,4 @@ -RosaABF.controller 'RepositoryProjectsController', ['$scope', '$http', '$location', ($scope, $http, $location) -> +RosaABF.controller 'RepositoryProjectsController', ['$scope', '$http', '$location', 'confirmMessage', ($scope, $http, $location, confirmMessage) -> $scope.added = $('#added').val() $scope.platform_id = $('#platform_id').val() @@ -51,4 +51,14 @@ RosaABF.controller 'RepositoryProjectsController', ['$scope', '$http', '$locatio $scope.goToPage = (number) -> $location.search('page', number) + $scope.removeProject = (project) -> + return false unless confirmMessage.show() + $scope.processing = true + $http.delete(project.remove_path).success (data) -> + Notifier.success(data.message) + $scope.projects = _.reject($scope.projects, (pr) -> + return pr.id is project.id + ) + $scope.processing = false + ] \ No newline at end of file diff --git a/app/assets/javascripts/lib/notifier.js b/app/assets/javascripts/lib/notifier.js new file mode 100644 index 000000000..6f5db489a --- /dev/null +++ b/app/assets/javascripts/lib/notifier.js @@ -0,0 +1,105 @@ +// https://github.com/Srirangan/notifer.js + +(function($){ + + var config = window.NotifierjsConfig = { + defaultTimeOut: 5000, + position: ["top", "right"], + notificationStyles: { + padding: "12px 18px", + margin: "0 0 6px 0", + backgroundColor: "#000", + opacity: 0.8, + color: "#fff", + font: "normal 13px 'Droid Sans', sans-serif", + borderRadius: "3px", + boxShadow: "#999 0 0 12px", + width: "300px" + }, + notificationStylesHover: { + opacity: 1, + boxShadow: "#000 0 0 12px" + }, + container: $("
") + }; + + $(document).ready(function() { + config.container.css("position", "fixed"); + config.container.css("z-index", 9999); + config.container.css(config.position[0], "12px"); + config.container.css(config.position[1], "12px"); + $("body").append(config.container); + }); + + function getNotificationElement() { + return $("
").css(config.notificationStyles).hover(function() { + $(this).css(config.notificationStylesHover); + }, function() { + $(this).css(config.notificationStyles); + }); + } + + var Notifier = window.Notifier = {}; + + Notifier.notify = function(message, title, iconUrl, timeOut) { + var notificationElement = getNotificationElement(); + + timeOut = timeOut || config.defaultTimeOut; + + if (iconUrl) { + var iconElement = $("", { + src: iconUrl, + css: { + width: 36, + height: 36, + display: "inline-block", + verticalAlign: "middle" + } + }); + notificationElement.append(iconElement); + } + + var textElement = $("
").css({ + display: 'inline-block', + verticalAlign: 'middle', + padding: '0 12px' + }); + + if (title) { + var titleElement = $("
"); + titleElement.append(document.createTextNode(title)); + titleElement.css("font-weight", "bold"); + textElement.append(titleElement); + } + + if (message) { + var messageElement = $("
"); + messageElement.append(document.createTextNode(message)); + textElement.append(messageElement); + } + + notificationElement.delay(timeOut).fadeOut(function(){ + notificationElement.remove(); + }); + notificationElement.bind("click", function() { + notificationElement.hide(); + }); + + notificationElement.append(textElement); + config.container.prepend(notificationElement); + }; + + Notifier.info = function(message, title) { + Notifier.notify(message, title, "%3D%3D"); + }; + Notifier.warning = function(message, title) { + Notifier.notify(message, title, "%3D"); + }; + Notifier.error = function(message, title) { + Notifier.notify(message, title, "%3D%3D"); + }; + Notifier.success = function(message, title) { + Notifier.notify(message, title, "%3D"); + }; + +}(jQuery)); \ No newline at end of file diff --git a/app/assets/javascripts/new_application.js b/app/assets/javascripts/new_application.js index dfe401f79..cae47b1c4 100644 --- a/app/assets/javascripts/new_application.js +++ b/app/assets/javascripts/new_application.js @@ -30,8 +30,9 @@ //= require lib/Chart //= require lib/bootstrap-typeahead //= require lib/custom-bootstrap-typeahead -//= require extra/highlight +//= require lib/notifier +//= require extra/highlight //= require extra/pull //= require extra/scroller //= require extra/fork diff --git a/app/controllers/platforms/repositories_controller.rb b/app/controllers/platforms/repositories_controller.rb index d0a820b3e..a4787aa13 100644 --- a/app/controllers/platforms/repositories_controller.rb +++ b/app/controllers/platforms/repositories_controller.rb @@ -140,7 +140,11 @@ class Platforms::RepositoriesController < Platforms::BaseController end if params[:project_id].present? ProjectToRepository.where(project_id: params[:project_id], repository_id: @repository.id).destroy_all - redirect_to platform_repository_path(@platform, @repository), notice: t('flash.repository.project_removed') + message = t('flash.repository.project_removed') + respond_to do |format| + format.html {redirect_to platform_repository_path(@platform, @repository), notice: message} + format.json {render json: { message: message }} + end end end diff --git a/app/views/platforms/repositories/_proj_list.html.slim b/app/views/platforms/repositories/_proj_list.html.slim index 4e14eae61..d3a4eca52 100644 --- a/app/views/platforms/repositories/_proj_list.html.slim +++ b/app/views/platforms/repositories/_proj_list.html.slim @@ -35,10 +35,9 @@ div ng-controller='RepositoryProjectsController' td a ng-href='{{project.add_path}}' ng-show='project.add_path' = t('layout.add') - a[ng-href = '{{project.remove_path}}' - ng-show = 'project.remove_path' - data-method = 'delete' - data-confirm = t('layout.confirm')] + a[ng-href = '#' + ng-show = 'project.remove_path' + ng-click = 'removeProject(project)'] span.glyphicon.glyphicon-remove |   diff --git a/app/views/platforms/repositories/_project.json.jbuilder b/app/views/platforms/repositories/_project.json.jbuilder index c71009387..021a2c3d5 100644 --- a/app/views/platforms/repositories/_project.json.jbuilder +++ b/app/views/platforms/repositories/_project.json.jbuilder @@ -1,6 +1,7 @@ json.total_items @total_items json.projects @projects do |project| + json.id project.id json.visibility_class fa_visibility_icon(project) json.path project_path(project.name_with_owner) json.name project.name_with_owner From cc5c009ff71bb64c4e26f7479793b2620665f079 Mon Sep 17 00:00:00 2001 From: Alexander Machehin Date: Thu, 19 Mar 2015 23:47:43 +0500 Subject: [PATCH 2/5] fix mistype --- .../platforms/repository_projects_controller.js.coffee | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee b/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee index 4cdf9e3ce..409aeaeb9 100644 --- a/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee +++ b/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee @@ -59,6 +59,5 @@ RosaABF.controller 'RepositoryProjectsController', ['$scope', '$http', '$locatio $scope.projects = _.reject($scope.projects, (pr) -> return pr.id is project.id ) - $scope.processing = false - + $scope.processing = false ] \ No newline at end of file From dabab0561d61fc1c20fcaa01f564642b7b0de466 Mon Sep 17 00:00:00 2001 From: Alexander Machehin Date: Fri, 20 Mar 2015 15:07:35 +0500 Subject: [PATCH 3/5] use rails-assets-notifyjs gem from rails-assets.org --- Gemfile | 3 + Gemfile.lock | 3 + .../repository_projects_controller.js.coffee | 12 +- app/assets/javascripts/lib/notifier.js | 105 ------------------ app/assets/javascripts/new_application.js | 4 +- .../platforms/repositories_controller.rb | 2 +- .../repositories/_proj_list.html.slim | 2 +- 7 files changed, 17 insertions(+), 114 deletions(-) delete mode 100644 app/assets/javascripts/lib/notifier.js diff --git a/Gemfile b/Gemfile index 3748cbcf3..97f528df5 100644 --- a/Gemfile +++ b/Gemfile @@ -98,6 +98,9 @@ gem 'sitemap_generator' gem 'codemirror-rails', '~> 4.5' +source 'https://rails-assets.org' do + gem 'rails-assets-notifyjs' +end group :production do gem 'airbrake' diff --git a/Gemfile.lock b/Gemfile.lock index 646254365..82491fe8e 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -51,6 +51,7 @@ GIT GEM remote: https://rubygems.org/ + remote: https://rails-assets.org/ specs: RedCloth (4.2.9) actionmailer (4.1.9) @@ -370,6 +371,7 @@ GEM bundler (>= 1.3.0, < 2.0) railties (= 4.1.9) sprockets-rails (~> 2.0) + rails-assets-notifyjs (0.3.2) rails3-generators (1.0.0) railties (>= 3.0.0) rails3-jquery-autocomplete (1.0.15) @@ -635,6 +637,7 @@ DEPENDENCIES puma rack-throttle (~> 0.3.0) rails (= 4.1.9) + rails-assets-notifyjs! rails3-generators rails3-jquery-autocomplete rake diff --git a/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee b/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee index 409aeaeb9..1a3bda291 100644 --- a/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee +++ b/app/assets/javascripts/angularjs/platforms/repository_projects_controller.js.coffee @@ -53,11 +53,11 @@ RosaABF.controller 'RepositoryProjectsController', ['$scope', '$http', '$locatio $scope.removeProject = (project) -> return false unless confirmMessage.show() - $scope.processing = true $http.delete(project.remove_path).success (data) -> - Notifier.success(data.message) - $scope.projects = _.reject($scope.projects, (pr) -> - return pr.id is project.id - ) - $scope.processing = false + $.notify(data.message, 'success') + + $scope.projects = _.reject($scope.projects, (pr) -> + return pr.id is project.id + ) + false ] \ No newline at end of file diff --git a/app/assets/javascripts/lib/notifier.js b/app/assets/javascripts/lib/notifier.js deleted file mode 100644 index 6f5db489a..000000000 --- a/app/assets/javascripts/lib/notifier.js +++ /dev/null @@ -1,105 +0,0 @@ -// https://github.com/Srirangan/notifer.js - -(function($){ - - var config = window.NotifierjsConfig = { - defaultTimeOut: 5000, - position: ["top", "right"], - notificationStyles: { - padding: "12px 18px", - margin: "0 0 6px 0", - backgroundColor: "#000", - opacity: 0.8, - color: "#fff", - font: "normal 13px 'Droid Sans', sans-serif", - borderRadius: "3px", - boxShadow: "#999 0 0 12px", - width: "300px" - }, - notificationStylesHover: { - opacity: 1, - boxShadow: "#000 0 0 12px" - }, - container: $("
") - }; - - $(document).ready(function() { - config.container.css("position", "fixed"); - config.container.css("z-index", 9999); - config.container.css(config.position[0], "12px"); - config.container.css(config.position[1], "12px"); - $("body").append(config.container); - }); - - function getNotificationElement() { - return $("
").css(config.notificationStyles).hover(function() { - $(this).css(config.notificationStylesHover); - }, function() { - $(this).css(config.notificationStyles); - }); - } - - var Notifier = window.Notifier = {}; - - Notifier.notify = function(message, title, iconUrl, timeOut) { - var notificationElement = getNotificationElement(); - - timeOut = timeOut || config.defaultTimeOut; - - if (iconUrl) { - var iconElement = $("", { - src: iconUrl, - css: { - width: 36, - height: 36, - display: "inline-block", - verticalAlign: "middle" - } - }); - notificationElement.append(iconElement); - } - - var textElement = $("
").css({ - display: 'inline-block', - verticalAlign: 'middle', - padding: '0 12px' - }); - - if (title) { - var titleElement = $("
"); - titleElement.append(document.createTextNode(title)); - titleElement.css("font-weight", "bold"); - textElement.append(titleElement); - } - - if (message) { - var messageElement = $("
"); - messageElement.append(document.createTextNode(message)); - textElement.append(messageElement); - } - - notificationElement.delay(timeOut).fadeOut(function(){ - notificationElement.remove(); - }); - notificationElement.bind("click", function() { - notificationElement.hide(); - }); - - notificationElement.append(textElement); - config.container.prepend(notificationElement); - }; - - Notifier.info = function(message, title) { - Notifier.notify(message, title, "%3D%3D"); - }; - Notifier.warning = function(message, title) { - Notifier.notify(message, title, "%3D"); - }; - Notifier.error = function(message, title) { - Notifier.notify(message, title, "%3D%3D"); - }; - Notifier.success = function(message, title) { - Notifier.notify(message, title, "%3D"); - }; - -}(jQuery)); \ No newline at end of file diff --git a/app/assets/javascripts/new_application.js b/app/assets/javascripts/new_application.js index cae47b1c4..fded2f68c 100644 --- a/app/assets/javascripts/new_application.js +++ b/app/assets/javascripts/new_application.js @@ -27,10 +27,12 @@ //= require zeroclipboard +//= require notifyjs +//= require notifyjs/styles/bootstrap/notify-bootstrap + //= require lib/Chart //= require lib/bootstrap-typeahead //= require lib/custom-bootstrap-typeahead -//= require lib/notifier //= require extra/highlight //= require extra/pull diff --git a/app/controllers/platforms/repositories_controller.rb b/app/controllers/platforms/repositories_controller.rb index a4787aa13..298b9d97a 100644 --- a/app/controllers/platforms/repositories_controller.rb +++ b/app/controllers/platforms/repositories_controller.rb @@ -139,7 +139,7 @@ class Platforms::RepositoriesController < Platforms::BaseController redirect_to platform_repository_path(@platform, @repository), notice: t('flash.repository.projects_will_be_removed') end if params[:project_id].present? - ProjectToRepository.where(project_id: params[:project_id], repository_id: @repository.id).destroy_all + #ProjectToRepository.where(project_id: params[:project_id], repository_id: @repository.id).destroy_all message = t('flash.repository.project_removed') respond_to do |format| format.html {redirect_to platform_repository_path(@platform, @repository), notice: message} diff --git a/app/views/platforms/repositories/_proj_list.html.slim b/app/views/platforms/repositories/_proj_list.html.slim index d3a4eca52..d39ef607f 100644 --- a/app/views/platforms/repositories/_proj_list.html.slim +++ b/app/views/platforms/repositories/_proj_list.html.slim @@ -23,7 +23,7 @@ div ng-controller='RepositoryProjectsController' th= t("activerecord.attributes.project.description") th tbody ng-hide='processing' - tr ng-repeat='project in projects' + tr ng-repeat='project in projects' ng-cloak = true td i.fa ng-class='project.visibility_class' From 70ee7fd208ad4312694e0d524958cc36007ca4c6 Mon Sep 17 00:00:00 2001 From: Alexander Machehin Date: Fri, 20 Mar 2015 15:12:33 +0500 Subject: [PATCH 4/5] remove debug --- app/controllers/platforms/repositories_controller.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/controllers/platforms/repositories_controller.rb b/app/controllers/platforms/repositories_controller.rb index 298b9d97a..a4787aa13 100644 --- a/app/controllers/platforms/repositories_controller.rb +++ b/app/controllers/platforms/repositories_controller.rb @@ -139,7 +139,7 @@ class Platforms::RepositoriesController < Platforms::BaseController redirect_to platform_repository_path(@platform, @repository), notice: t('flash.repository.projects_will_be_removed') end if params[:project_id].present? - #ProjectToRepository.where(project_id: params[:project_id], repository_id: @repository.id).destroy_all + ProjectToRepository.where(project_id: params[:project_id], repository_id: @repository.id).destroy_all message = t('flash.repository.project_removed') respond_to do |format| format.html {redirect_to platform_repository_path(@platform, @repository), notice: message} From ea32cf368536ddb8e18c0f53fdbebfaea51a314d Mon Sep 17 00:00:00 2001 From: Alexander Machehin Date: Fri, 20 Mar 2015 15:26:10 +0500 Subject: [PATCH 5/5] dont reload page after removing a project from repository --- app/views/platforms/repositories/_proj_list.html.slim | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/app/views/platforms/repositories/_proj_list.html.slim b/app/views/platforms/repositories/_proj_list.html.slim index d39ef607f..718f34041 100644 --- a/app/views/platforms/repositories/_proj_list.html.slim +++ b/app/views/platforms/repositories/_proj_list.html.slim @@ -35,9 +35,9 @@ div ng-controller='RepositoryProjectsController' td a ng-href='{{project.add_path}}' ng-show='project.add_path' = t('layout.add') - a[ng-href = '#' - ng-show = 'project.remove_path' - ng-click = 'removeProject(project)'] + a.pointer[ng-href = '' + ng-show = 'project.remove_path' + ng-click = 'removeProject(project)'] span.glyphicon.glyphicon-remove |