aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-server/src/main/webapp/coffee/coding-rules/mockjax.coffee3
-rw-r--r--sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profile-view.coffee11
-rw-r--r--sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profiles-view.coffee1
-rw-r--r--sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-view.coffee22
-rw-r--r--sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-list-item-view.coffee1
-rw-r--r--sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-quality-profile-activation-view.coffee9
-rw-r--r--sonar-server/src/main/webapp/templates/coding-rules/coding-rules-quality-profile-activation.hbs26
7 files changed, 56 insertions, 17 deletions
diff --git a/sonar-server/src/main/webapp/coffee/coding-rules/mockjax.coffee b/sonar-server/src/main/webapp/coffee/coding-rules/mockjax.coffee
index acefc6dd9f1..2163fac2a64 100644
--- a/sonar-server/src/main/webapp/coffee/coding-rules/mockjax.coffee
+++ b/sonar-server/src/main/webapp/coffee/coding-rules/mockjax.coffee
@@ -97,6 +97,7 @@ define ['jquery.mockjax'], ->
'edit': 'Edit'
'markdown.helplink': 'Markdown Help'
'moreCriteria': '+ More Criteria'
+ 'save': 'Save'
'search_verb': 'Search'
'severity': 'Severity'
'update': 'Update'
@@ -115,6 +116,7 @@ define ['jquery.mockjax'], ->
'coding_rules.bulk_change': 'Bulk Change'
'coding_rules.change_severity': 'Change Severity'
'coding_rules.change_severity_in': 'Change Severity In'
+ 'coding_rules.change_details': 'Change Details of Quality Profile'
'coding_rules.extend_description': 'Extend Description'
'coding_rules.deactivate_in': 'Deactivate In'
'coding_rules.deactivate': 'Deactivate'
@@ -222,7 +224,6 @@ define ['jquery.mockjax'], ->
key: 'S1190'
parameters: [
{ key: 'someParameter', type: 'INT', default: 4, description: 'Some parameter description' }
- { key: 'boolParameter', type: 'BOOL', description: 'Bool parameter description' }
]
description: '''
<p>
diff --git a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profile-view.coffee b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profile-view.coffee
index 2f3ec432cd4..063b8378929 100644
--- a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profile-view.coffee
+++ b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profile-view.coffee
@@ -6,7 +6,7 @@ define [
Templates
) ->
- class CodingRulesDetailQualityProfilesView extends Marionette.ItemView
+ class CodingRulesDetailQualityProfileView extends Marionette.ItemView
className: 'coding-rules-detail-quality-profile'
template: Templates['coding-rules-detail-quality-profile']
@@ -15,6 +15,15 @@ define [
change: '.coding-rules-detail-quality-profile-change'
+ events:
+ 'click @ui.change': 'change'
+
+
+ change: ->
+ @options.app.codingRulesQualityProfileActivationView.model = @model
+ @options.app.codingRulesQualityProfileActivationView.show()
+
+
enableUpdate: ->
@ui.update.prop 'disabled', false
diff --git a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profiles-view.coffee b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profiles-view.coffee
index 0b6f7ec680e..71b0b311062 100644
--- a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profiles-view.coffee
+++ b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-quality-profiles-view.coffee
@@ -10,4 +10,5 @@ define [
itemView: CodingRulesDetailQualityProfileView
itemViewOptions: ->
+ app: @options.app
qualityProfiles: @collection \ No newline at end of file
diff --git a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-view.coffee b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-view.coffee
index 641748825c9..4cf361c7a5c 100644
--- a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-view.coffee
+++ b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-detail-view.coffee
@@ -33,7 +33,8 @@ define [
extendDescriptionSpinner: '#coding-rules-detail-extend-description-spinner'
cancelExtendDescription: '#coding-rules-detail-extend-description-cancel'
- qualityProfileActivate: '#coding-rules-quality-profile-activate'
+ activateQualityProfile: '#coding-rules-quality-profile-activate'
+ changeQualityProfile: '.coding-rules-detail-quality-profile-update'
events:
@@ -44,11 +45,13 @@ define [
'click @ui.cancelExtendDescription': 'hideExtendDescriptionForm'
'click @ui.extendDescriptionSubmit': 'submitExtendDescription'
- 'click @ui.qualityProfileActivate': 'activateQualityProfile'
+ 'click @ui.activateQualityProfile': 'activateQualityProfile'
+ 'click @ui.changeQualityProfile': 'changeQualityProfile'
initialize: (options) ->
@qualityProfilesView = new CodingRulesDetailQualityProfilesView
+ app: @options.app
collection: new Backbone.Collection options.model.get 'qualityProfiles'
@@ -104,16 +107,25 @@ define [
@render()
+ getContextQualilyProfile: ->
+ contextQualityProfile = @options.app.getQualityProfile()
+ _.findWhere @model.get('qualityProfiles'), key: contextQualityProfile
+
+
activateQualityProfile: ->
- @options.app.codingRulesQualityProfileActivationView.model = @model
+ @options.app.codingRulesQualityProfileActivationView.model = null
+ @options.app.codingRulesQualityProfileActivationView.show()
+
+
+ changeQualityProfile: ->
+ @options.app.codingRulesQualityProfileActivationView.model = new Backbone.Model @getContextQualilyProfile()
@options.app.codingRulesQualityProfileActivationView.show()
serializeData: ->
contextQualityProfile = @options.app.getQualityProfile()
- qualityProfile = _.findWhere @model.get('qualityProfiles'), key: contextQualityProfile
_.extend super,
contextQualityProfile: contextQualityProfile
contextQualityProfileName: @options.app.qualityProfileFilter.view.renderValue()
- qualityProfile: qualityProfile \ No newline at end of file
+ qualityProfile: @getContextQualilyProfile() \ No newline at end of file
diff --git a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-list-item-view.coffee b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-list-item-view.coffee
index 5331efec1e7..69a9e5fdaff 100644
--- a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-list-item-view.coffee
+++ b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-list-item-view.coffee
@@ -27,6 +27,7 @@ define [
url: "#{baseUrl}/api/codingrules/show"
.done (r) =>
@model.set r.codingrule
+ @options.app.codingRulesQualityProfileActivationView.rule = @model
detailView = new CodingRulesDetailView
app: @options.app
model: @model
diff --git a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-quality-profile-activation-view.coffee b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-quality-profile-activation-view.coffee
index f314464e3d7..70aa55a5daf 100644
--- a/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-quality-profile-activation-view.coffee
+++ b/sonar-server/src/main/webapp/coffee/coding-rules/views/coding-rules-quality-profile-activation-view.coffee
@@ -52,7 +52,8 @@ define [
return state.text unless state.id
"<i class='icon-severity-#{state.id.toLowerCase()}'></i> #{state.text}"
- @ui.qualityProfileSeverity.val @model.get 'severity'
+ severity = if @model then @model.get 'severity' else @rule.get 'severity'
+ @ui.qualityProfileSeverity.val severity
@ui.qualityProfileSeverity.select2
width: '250px'
minimumResultsForSearch: 999
@@ -71,10 +72,14 @@ define [
getAvailableQualityProfiles: ->
_.reject @options.app.qualityProfiles, (profile) =>
- _.findWhere @model.get('qualityProfiles'), key: profile.key
+ _.findWhere @rule.get('qualityProfiles'), key: profile.key
serializeData: ->
+ parameters = if @model then @model.get('parameters') else @rule.get('parameters')
+
_.extend super,
+ rule: @rule.toJSON()
+ parameters: parameters
qualityProfiles: @getAvailableQualityProfiles()
severities: ['BLOCKER', 'CRITICAL', 'MAJOR', 'MINOR', 'INFO']
diff --git a/sonar-server/src/main/webapp/templates/coding-rules/coding-rules-quality-profile-activation.hbs b/sonar-server/src/main/webapp/templates/coding-rules/coding-rules-quality-profile-activation.hbs
index 0360cab6f3b..cfd8d6df01d 100644
--- a/sonar-server/src/main/webapp/templates/coding-rules/coding-rules-quality-profile-activation.hbs
+++ b/sonar-server/src/main/webapp/templates/coding-rules/coding-rules-quality-profile-activation.hbs
@@ -1,6 +1,10 @@
<form>
<div class="modal-head">
- <h2>{{t 'coding_rules.activate_in_quality_profile'}}</h2>
+ {{#if key}}
+ <h2>{{t 'coding_rules.change_details'}}</h2>
+ {{else}}
+ <h2>{{t 'coding_rules.activate_in_quality_profile'}}</h2>
+ {{/if}}
</div>
<div class="modal-body">
@@ -10,11 +14,15 @@
<tr class="property">
<th><h3>{{t 'coding_rules.quality_profile'}}</h3></th>
<td>
- <select id="coding-rules-quality-profile-activation-select">
- {{#each qualityProfiles}}
- <option value="{{key}}">{{name}}</option>
- {{/each}}
- </select>
+ {{#if key}}
+ {{name}}
+ {{else}}
+ <select id="coding-rules-quality-profile-activation-select">
+ {{#each qualityProfiles}}
+ <option value="{{key}}">{{name}}</option>
+ {{/each}}
+ </select>
+ {{/if}}
</td>
</tr>
<tr class="property">
@@ -31,7 +39,7 @@
<tr class="property">
<th><h3>{{key}}</h3></th>
<td>
- <input type="text" {{#if default}}value="{{default}}"{{/if}}>
+ <input type="text" value="{{value}}" placeholder="{{default}}">
<div class="note">{{description}}</div>
{{#if extra}}
<div class="note">{{extra}}</div>
@@ -43,7 +51,9 @@
</div>
<div class="modal-foot">
- <button id="coding-rules-quality-profile-activation-activate">{{t 'coding_rules.activate'}}</button>
+ <button id="coding-rules-quality-profile-activation-activate">
+ {{#if key}}{{t 'save'}}{{else}}{{t 'coding_rules.activate'}}{{/if}}
+ </button>
<a id="coding-rules-quality-profile-activation-cancel" class="action">{{t 'cancel'}}</a>
</div>
</form> \ No newline at end of file