diff options
author | Stas Vilchik <vilchiks@gmail.com> | 2014-11-24 13:35:12 +0100 |
---|---|---|
committer | Stas Vilchik <vilchiks@gmail.com> | 2014-11-24 14:25:40 +0100 |
commit | b8caa51ab68d5a2c58be4fe956375158a4ed6c6a (patch) | |
tree | d8b3844ae272cac77af91b2684cd6c77e67e93bf | |
parent | d0dfc007c17837fb4c3ac77a12ceb70851988239 (diff) | |
download | sonarqube-b8caa51ab68d5a2c58be4fe956375158a4ed6c6a.tar.gz sonarqube-b8caa51ab68d5a2c58be4fe956375158a4ed6c6a.zip |
SONAR-5718 Handle big files
3 files changed, 45 insertions, 28 deletions
diff --git a/server/sonar-web/src/main/coffee/issues/component-viewer/main.coffee b/server/sonar-web/src/main/coffee/issues/component-viewer/main.coffee index ad050678606..981f29799dc 100644 --- a/server/sonar-web/src/main/coffee/issues/component-viewer/main.coffee +++ b/server/sonar-web/src/main/coffee/issues/component-viewer/main.coffee @@ -15,9 +15,10 @@ define [ $ = jQuery API_SOURCES = "#{baseUrl}/api/sources/show" - LINES_AROUND = 500 + LINES_AROUND = 200 TOP_OFFSET = 38 BOTTOM_OFFSET = 10 + ISSUES_LIMIT = 100 class extends Marionette.ItemView @@ -41,9 +42,7 @@ define [ formattedSource: [] @component = new Backbone.Model() @issues = new Issues() - @listenTo @issues, 'add', @addIssue @listenTo options.app.state, 'change:selectedIndex', @select - @bindShortcuts() @loadSourceBeforeThrottled = _.throttle @loadSourceBefore, 1000 @loadSourceAfterThrottled = _.throttle @loadSourceAfter, 1000 @scrollTimer = null @@ -154,8 +153,14 @@ define [ renderIssues: -> + @hiddenIssues = false @issues.forEach (issue) => @renderIssue issue + if @hiddenIssues + issues = @$('.issue').length + warn = $('<div class="process-spinner shown">' + tp('issues.issues_limit_reached', issues) + '</div>') + $('body').append warn + setTimeout (-> warn.remove()), 3000 addIssue: (issue) -> @@ -163,18 +168,21 @@ define [ renderIssue: (issue) -> - line = issue.get 'line' || 0 + line = issue.get('line') || 0 row = @$("[data-line-number=#{line}]") issueView = new IssueView app: @options.app, model: issue - if row.length == 0 + if line == 0 issueView.render().$el.insertBefore @$('.issues-workspace-component-viewer-code') else - line = row.find '.line' - line.addClass 'has-issues' - issues = line.find '.issue-list' - if issues.length == 0 - issues = $('<div class="issue-list"></div>').appendTo line - issueView.render().$el.appendTo issues + showBox = Math.abs(issue.get('index') - @model.get('issueIndex')) < ISSUES_LIMIT / 2 + @hiddenIssues = true unless showBox + if showBox && row.length > 0 + line = row.find '.line' + line.addClass 'has-issues' + issues = line.find '.issue-list' + if issues.length == 0 + issues = $('<div class="issue-list"></div>').appendTo line + issueView.render().$el.appendTo issues select: -> @@ -184,6 +192,7 @@ define [ selectedKey = selectedIssue.get 'key' @scrollToIssue selectedKey else + @unbindShortcuts() @options.app.controller.showComponentViewer selectedIssue @@ -214,14 +223,18 @@ define [ $(window).scrollTop viewTop - TOP_OFFSET if viewBottom > windowBottom $(window).scrollTop $(window).scrollTop() - windowBottom + viewBottom + BOTTOM_OFFSET + else + @unbindShortcuts() + selected = @options.app.state.get 'selectedIndex' + selectedIssue = @options.app.issues.at selected + @options.app.controller.showComponentViewer selectedIssue openFileByIssue: (issue) -> componentKey = issue.get 'component' - @issues.reset @options.app.issues.filter (issue) => issue.get('component') == componentKey line = issue.get('line') || 0 - @model.set key: componentKey, issueLine: line + @model.set key: componentKey, issueLine: line, issueIndex: issue.get('index') # disable clipping effect of the black header @$el.addClass 'full-height' @@ -237,35 +250,35 @@ define [ @model.set hasSourceBefore: firstLine > 1 hasSourceAfter: lastLine == line + LINES_AROUND - @render() - @bindScrollEvents() - @requestIssues() + @requestIssues().done => + @issues.reset @options.app.issues.filter (issue) => issue.get('component') == componentKey + @render() + @bindScrollEvents() + @bindShortcuts() + @$el.removeClass 'full-height' + @scrollToLine issue.get 'line' .fail => @source.set source: [] formattedSource: [] @model.set hasSourceBefore: false, hasSourceAfter: false + @issues.reset @options.app.issues.filter (issue) => issue.get('component') == componentKey @render() - .always => + @bindShortcuts() @$el.removeClass 'full-height' @scrollToLine issue.get 'line' + requestSources: (lineFrom, lineTo) -> lineFrom = Math.max 0, lineFrom $.get API_SOURCES, key: @model.get('key'), from: lineFrom, to: lineTo requestIssues: -> - lastIssue = @options.app.issues.at @options.app.issues.length - 1 - lastLine = _.last(@source.get('formattedSource')).lineNumber - needMore = !@options.app.state.get('maxResultsReached') - needMore = needMore && (lastIssue.get('component') == @model.get 'key') - needMore = needMore && (lastIssue.get('line') <= lastLine) - if needMore - @options.app.controller.fetchNextPage().done => - @addNextIssuesPage() - @requestIssues() + if @options.app.issues.last().get('component') == @model.get('key') + @options.app.controller.fetchNextPage() + else $.Deferred().resolve().promise() addNextIssuesPage: -> diff --git a/server/sonar-web/src/main/less/ui.less b/server/sonar-web/src/main/less/ui.less index 71c52412a9f..77321ea0e5a 100644 --- a/server/sonar-web/src/main/less/ui.less +++ b/server/sonar-web/src/main/less/ui.less @@ -411,9 +411,12 @@ input[type=button] { .process-spinner { position: fixed; + z-index: 2000; top: 0; left: 50%; - width: 300px; + min-width: 300px; + max-width: 900px; margin-left: -150px; + padding: 0 10px; line-height: 22px; background-color: #f0e8ac; border-radius: 0 0 3px 3px; 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 32c52343264..24fd83f4fb7 100644 --- a/sonar-core/src/main/resources/org/sonar/l10n/core.properties +++ b/sonar-core/src/main/resources/org/sonar/l10n/core.properties @@ -684,7 +684,8 @@ issue.technical_debt=Technical Debt: issue.technical_debt_short=Debt issue.technical_debt_deleted=Rule not configured to generate technical debt estimate. issue.creation_date=Created -issues.return_to_list=Return To List +issues.return_to_list=Return to List +issues.issues_limit_reached=For usability reasons, only the {0} issues are displayed. #------------------------------------------------------------------------------ |