aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Baptiste Lievremont <jean-baptiste.lievremont@sonarsource.com>2014-07-18 18:06:02 +0200
committerJean-Baptiste Lievremont <jean-baptiste.lievremont@sonarsource.com>2014-07-18 18:06:10 +0200
commit18a85015feb7a27bee89bcfda4421b92f0a9b8c7 (patch)
tree02eb02d65b07e9c7bfced1070edcdcf2b835bf70
parente93420742f6d1361b5043eb56b15cbdbf7d00690 (diff)
downloadsonarqube-18a85015feb7a27bee89bcfda4421b92f0a9b8c7.tar.gz
sonarqube-18a85015feb7a27bee89bcfda4421b92f0a9b8c7.zip
SONAR-3373 Integrate management of manual rules in Rules space
-rw-r--r--server/sonar-web/src/main/coffee/coding-rules/app.coffee11
-rw-r--r--server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-detail-view.coffee15
-rw-r--r--server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-manual-rule-creation-view.coffee134
-rw-r--r--server/sonar-web/src/main/coffee/coding-rules/views/header-view.coffee5
-rw-r--r--server/sonar-web/src/main/hbs/coding-rules/coding-rules-detail.hbs12
-rw-r--r--server/sonar-web/src/main/hbs/coding-rules/coding-rules-header.hbs1
-rw-r--r--server/sonar-web/src/main/hbs/coding-rules/coding-rules-manual-rule-creation.hbs47
-rw-r--r--server/sonar-web/src/main/hbs/coding-rules/coding-rules-manual-rule-reactivation.hbs7
-rw-r--r--sonar-core/src/main/resources/org/sonar/l10n/core.properties1
9 files changed, 225 insertions, 8 deletions
diff --git a/server/sonar-web/src/main/coffee/coding-rules/app.coffee b/server/sonar-web/src/main/coffee/coding-rules/app.coffee
index 1add838f708..6aecd42562e 100644
--- a/server/sonar-web/src/main/coffee/coding-rules/app.coffee
+++ b/server/sonar-web/src/main/coffee/coding-rules/app.coffee
@@ -34,6 +34,7 @@ requirejs [
'coding-rules/views/coding-rules-bulk-change-dropdown-view',
'coding-rules/views/coding-rules-facets-view',
'coding-rules/views/coding-rules-custom-rule-creation-view',
+ 'coding-rules/views/coding-rules-manual-rule-creation-view',
# filters
'navigator/filters/base-filters',
@@ -70,6 +71,7 @@ requirejs [
CodingRulesBulkChangeDropdownView,
CodingRulesFacetsView,
CodingRulesCustomRuleCreationView,
+ CodingRulesManualRuleCreationView,
# filters
BaseFilters,
@@ -274,6 +276,11 @@ requirejs [
language: 'none'
+ App.createManualRule = ->
+ App.codingRulesManualRuleCreationView.model = new Backbone.Model()
+ App.codingRulesManualRuleCreationView.show()
+
+
# Construct layout
App.addInitializer ->
@layout = new CodingRulesLayout app: @
@@ -317,6 +324,10 @@ requirejs [
@codingRulesCustomRuleCreationView = new CodingRulesCustomRuleCreationView app: @
+ # Construct custom rule creation view
+ App.addInitializer ->
+ @codingRulesManualRuleCreationView = new CodingRulesManualRuleCreationView app: @
+
# Define filters
App.addInitializer ->
@filters = new BaseFilters.Filters
diff --git a/server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-detail-view.coffee b/server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-detail-view.coffee
index 636c6a2cf17..772cd484040 100644
--- a/server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-detail-view.coffee
+++ b/server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-detail-view.coffee
@@ -52,7 +52,8 @@ define [
changeQualityProfile: '.coding-rules-detail-quality-profile-update'
createCustomRule: '#coding-rules-custom-rules-create'
changeCustomRule: '#coding-rules-detail-custom-rule-change'
- deleteCustomRule: '#coding-rules-detail-custom-rule-delete'
+ changeManualRule: '#coding-rules-detail-manual-rule-change'
+ deleteCustomRule: '#coding-rules-detail-rule-delete'
events:
@@ -69,7 +70,8 @@ define [
'click @ui.changeQualityProfile': 'changeQualityProfile'
'click @ui.createCustomRule': 'createCustomRule'
'click @ui.changeCustomRule': 'changeCustomRule'
- 'click @ui.deleteCustomRule': 'deleteCustomRule'
+ 'click @ui.changeManualRule': 'changeManualRule'
+ 'click @ui.deleteCustomRule': 'deleteRule'
'click .coding-rules-detail-parameter-details': 'showParamPopup'
'click .coding-rules-subcharacteristic': 'showDebtPopup'
@@ -293,7 +295,12 @@ define [
@options.app.codingRulesCustomRuleCreationView.show()
- deleteCustomRule: ->
+ changeManualRule: ->
+ @options.app.codingRulesManualRuleCreationView.model = @model
+ @options.app.codingRulesManualRuleCreationView.show()
+
+
+ deleteRule: ->
confirmDialog
title: t 'delete'
html: t 'are_you_sure'
@@ -313,6 +320,7 @@ define [
contextQualityProfile = @options.app.getQualityProfile()
repoKey = @model.get 'repo'
isManual = (@options.app.manualRepository().key == repoKey)
+ isCustom = (@model.get('templateKey') != null)
qualityProfilesVisible = not isManual
if qualityProfilesVisible
@@ -330,6 +338,7 @@ define [
repository: _.find(@options.app.repositories, (repo) -> repo.key == repoKey).name
isManual: isManual
canWrite: @options.app.canWrite
+ isEditable: (@options.app.canWrite and (isManual or isCustom))
qualityProfilesVisible: qualityProfilesVisible
subcharacteristic: @options.app.getSubcharacteristicName(@model.get 'debtSubChar')
createdAt: new Date(@model.get 'createdAt')
diff --git a/server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-manual-rule-creation-view.coffee b/server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-manual-rule-creation-view.coffee
new file mode 100644
index 00000000000..4adb0d9afe4
--- /dev/null
+++ b/server/sonar-web/src/main/coffee/coding-rules/views/coding-rules-manual-rule-creation-view.coffee
@@ -0,0 +1,134 @@
+define [
+ 'backbone.marionette',
+ 'templates/coding-rules'
+], (
+ Marionette,
+ Templates
+) ->
+
+ class CodingRulesManualRuleCreationView extends Marionette.ItemView
+ className: 'modal'
+ template: Templates['coding-rules-manual-rule-creation']
+
+
+ ui:
+ manualRuleCreationKey: '#coding-rules-manual-rule-creation-key'
+ manualRuleCreationName: '#coding-rules-manual-rule-creation-name'
+ manualRuleCreationHtmlDescription: '#coding-rules-manual-rule-creation-html-description'
+ manualRuleCreationSeverity: '#coding-rules-manual-rule-creation-severity'
+ manualRuleCreationStatus: '#coding-rules-manual-rule-creation-status'
+ manualRuleCreationParameters: '[name]'
+ manualRuleCreationCreate: '#coding-rules-manual-rule-creation-create'
+ manualRuleCreationReactivate: '#coding-rules-manual-rule-creation-reactivate'
+ modalFoot: '.modal-foot'
+
+
+ events:
+ 'input @ui.manualRuleCreationName': 'generateKey'
+ 'keydown @ui.manualRuleCreationName': 'generateKey'
+ 'keyup @ui.manualRuleCreationName': 'generateKey'
+
+ 'input @ui.manualRuleCreationKey': 'flagKey'
+ 'keydown @ui.manualRuleCreationKey': 'flagKey'
+ 'keyup @ui.manualRuleCreationKey': 'flagKey'
+
+ 'click #coding-rules-manual-rule-creation-cancel': 'hide'
+ 'click @ui.manualRuleCreationCreate': 'create'
+ 'click @ui.manualRuleCreationReactivate': 'reactivate'
+
+
+ generateKey: ->
+ unless @keyModifiedByUser
+ if @ui.manualRuleCreationKey
+ generatedKey = @ui.manualRuleCreationName.val().latinize().replace(/[^A-Za-z0-9]/g, '_')
+ @ui.manualRuleCreationKey.val generatedKey
+
+ flagKey: ->
+ @keyModifiedByUser = true
+ # Cannot use @ui.manualRuleCreationReactivate.hide() directly since it was not there at initial render
+ jQuery(@ui.manualRuleCreationReactivate.selector).hide()
+
+
+ create: ->
+ action = 'create'
+ if @model and @model.has 'key'
+ action = 'update'
+
+ postData =
+ name: @ui.manualRuleCreationName.val()
+ markdown_description: @ui.manualRuleCreationHtmlDescription.val()
+
+ if @model && @model.has 'key'
+ postData.key = @model.get 'key'
+ else
+ postData.manual_key = @ui.manualRuleCreationKey.val()
+ postData.prevent_reactivation = true
+
+ @sendRequest(action, postData)
+
+
+ reactivate: ->
+ postData =
+ name: @existingRule.name
+ markdown_description: @existingRule.mdDesc
+ manual_key: @ui.manualRuleCreationKey.val()
+ prevent_reactivation: false
+
+ @sendRequest('create', postData)
+
+
+ sendRequest: (action, postData) ->
+ @$('.modal-error').hide()
+ @$('.modal-warning').hide()
+
+ origFooter = @ui.modalFoot.html()
+ @ui.modalFoot.html '<i class="spinner"></i>'
+
+ jQuery.ajax
+ type: 'POST'
+ url: "#{baseUrl}/api/rules/" + action
+ data: postData
+ error: () ->
+ .done (r) =>
+ @options.app.showRule r.rule.key
+ @hide()
+ .fail (jqXHR, textStatus, errorThrown) =>
+ if jqXHR.status == 409
+ @existingRule = jqXHR.responseJSON.rule
+ @$('.modal-warning').show()
+ @ui.modalFoot.html Templates['coding-rules-manual-rule-reactivation'](@)
+ else
+ jQuery.ajaxSettings.error(jqXHR, textStatus, errorThrown)
+ @ui.modalFoot.html origFooter
+
+
+ onRender: ->
+ @$el.dialog
+ dialogClass: 'no-close',
+ width: '600px',
+ draggable: false,
+ autoOpen: false,
+ modal: true,
+ minHeight: 50,
+ resizable: false,
+ title: null
+
+ @keyModifiedByUser = false
+
+ format = (state) ->
+ return state.text unless state.id
+ "<i class='icon-severity-#{state.id.toLowerCase()}'></i> #{state.text}"
+
+
+ show: ->
+ @render()
+ @$el.dialog 'open'
+
+
+ hide: ->
+ @$el.dialog 'close'
+
+
+ serializeData: ->
+ _.extend super,
+ change: @model && @model.has 'key'
diff --git a/server/sonar-web/src/main/coffee/coding-rules/views/header-view.coffee b/server/sonar-web/src/main/coffee/coding-rules/views/header-view.coffee
index 9e2ddf78b24..b3554347edf 100644
--- a/server/sonar-web/src/main/coffee/coding-rules/views/header-view.coffee
+++ b/server/sonar-web/src/main/coffee/coding-rules/views/header-view.coffee
@@ -12,7 +12,12 @@ define [
events:
'click #coding-rules-new-search': 'newSearch'
+ 'click #coding-rules-create-rule': 'createRule'
newSearch: ->
@options.app.router.emptyQuery()
+
+
+ createRule: ->
+ @options.app.createManualRule()
diff --git a/server/sonar-web/src/main/hbs/coding-rules/coding-rules-detail.hbs b/server/sonar-web/src/main/hbs/coding-rules/coding-rules-detail.hbs
index 2d4cb44417f..1762144fc35 100644
--- a/server/sonar-web/src/main/hbs/coding-rules/coding-rules-detail.hbs
+++ b/server/sonar-web/src/main/hbs/coding-rules/coding-rules-detail.hbs
@@ -51,15 +51,17 @@
<div class="coding-rules-detail-description rule-desc markdown">{{{htmlDesc}}}</div>
-{{#if templateKey}}
- {{#if canWrite}}
+{{#if isEditable}}
<div class="coding-rules-detail-description">
<div class="button-group">
- <button id="coding-rules-detail-custom-rule-change">{{t 'edit'}}</button>
- <button id="coding-rules-detail-custom-rule-delete" class="button-red">{{t 'delete'}}</button>
+ {{#if isManual}}
+ <button id="coding-rules-detail-manual-rule-change">{{t 'edit'}}</button>
+ {{else}}
+ <button id="coding-rules-detail-custom-rule-change">{{t 'edit'}}</button>
+ {{/if}}
+ <button id="coding-rules-detail-rule-delete" class="button-red">{{t 'delete'}}</button>
</div>
</div>
- {{/if}}
{{else}}
{{#unless isManual}}
<div class="coding-rules-detail-description coding-rules-detail-description-extra">
diff --git a/server/sonar-web/src/main/hbs/coding-rules/coding-rules-header.hbs b/server/sonar-web/src/main/hbs/coding-rules/coding-rules-header.hbs
index 598ded5a8a6..12fbc46ac5c 100644
--- a/server/sonar-web/src/main/hbs/coding-rules/coding-rules-header.hbs
+++ b/server/sonar-web/src/main/hbs/coding-rules/coding-rules-header.hbs
@@ -2,4 +2,5 @@
<div class="navigator-header-actions button-group">
<button id="coding-rules-new-search">{{t 'coding_rules.new_search'}}</button>
+ <button id="coding-rules-create-rule">{{t 'coding_rules.create'}}</button>
</div>
diff --git a/server/sonar-web/src/main/hbs/coding-rules/coding-rules-manual-rule-creation.hbs b/server/sonar-web/src/main/hbs/coding-rules/coding-rules-manual-rule-creation.hbs
new file mode 100644
index 00000000000..f7b027215b6
--- /dev/null
+++ b/server/sonar-web/src/main/hbs/coding-rules/coding-rules-manual-rule-creation.hbs
@@ -0,0 +1,47 @@
+<form>
+ <div class="modal-head">
+ {{#if change}}
+ <h2>{{t 'coding_rules.update_manual_rule'}}</h2>
+ {{else}}
+ <h2>{{t 'coding_rules.create_manual_rule'}}</h2>
+ {{/if}}
+ </div>
+
+ <div class="modal-body">
+ <div class="modal-error"></div>
+ <div class="modal-warning">{{t 'coding_rules.reactivate.help'}}</div>
+
+ <table>
+ <tr class="property">
+ <th><h3>{{t 'name'}} <em class="mandatory">*</em></h3></th>
+ <td>
+ <input type="text" name="name" id="coding-rules-manual-rule-creation-name" value="{{name}}"/>
+ </td>
+ </tr>
+ <tr class="property">
+ <th><h3>{{t 'key'}}{{#unless change}} <em class="mandatory">*</em>{{/unless}}</h3></th>
+ <td>
+ {{#if change}}
+ {{key}}
+ {{else}}
+ <input type="text" name="key" id="coding-rules-manual-rule-creation-key" value="{{internalKey}}"/>
+ {{/if}}
+ </td>
+ </tr>
+ <tr class="property">
+ <th><h3>{{t 'description'}} <em class="mandatory">*</em></h3></th>
+ <td>
+ <textarea type="textarea" name="markdown_description" id="coding-rules-manual-rule-creation-html-description"
+ rows="4" style="width: 100%; margin-bottom: 4px;">{{{mdDesc}}}</textarea>
+ </td>
+ </tr>
+ </table>
+ </div>
+
+ <div class="modal-foot">
+ <button id="coding-rules-manual-rule-creation-create">
+ {{#if change}}{{t 'save'}}{{else}}{{t 'create'}}{{/if}}
+ </button>
+ <a id="coding-rules-manual-rule-creation-cancel" class="action">{{t 'cancel'}}</a>
+ </div>
+</form>
diff --git a/server/sonar-web/src/main/hbs/coding-rules/coding-rules-manual-rule-reactivation.hbs b/server/sonar-web/src/main/hbs/coding-rules/coding-rules-manual-rule-reactivation.hbs
new file mode 100644
index 00000000000..2410c7fd95f
--- /dev/null
+++ b/server/sonar-web/src/main/hbs/coding-rules/coding-rules-manual-rule-reactivation.hbs
@@ -0,0 +1,7 @@
+<button id="coding-rules-manual-rule-creation-reactivate">
+ {{t 'coding_rules.reactivate'}}
+</button>
+<button id="coding-rules-manual-rule-creation-create">
+ {{#if change}}{{t 'save'}}{{else}}{{t 'create'}}{{/if}}
+</button>
+<a id="coding-rules-manual-rule-creation-cancel" class="action">{{t 'cancel'}}</a>
diff --git a/sonar-core/src/main/resources/org/sonar/l10n/core.properties b/sonar-core/src/main/resources/org/sonar/l10n/core.properties
index 9b2d5383ed9..67f213fd1a1 100644
--- a/sonar-core/src/main/resources/org/sonar/l10n/core.properties
+++ b/sonar-core/src/main/resources/org/sonar/l10n/core.properties
@@ -1712,6 +1712,7 @@ coding_rules.change_severity_in=Change Severity In
coding_rules.change_details=Change Details of Quality Profile
coding_rules.create=Create
coding_rules.create_custom_rule=Create Custom Rule
+coding_rules.create_manual_rule=Create Manual Rule
coding_rules.custom_rule=Custom Rule
coding_rules.custom_rule.title=This rule has been created through customization of a rule template
coding_rules.custom_rules=Custom Rules