Commit e53b47b447b1f1ba8185aa07b8c53102c592ead8
1 parent
02c83f12
Exists in
master
and in
4 other branches
WebEditor: sceleton
Showing
3 changed files
with
30 additions
and
2 deletions
Show diff stats
app/controllers/tree_controller.rb
@@ -26,5 +26,13 @@ class TreeController < ProjectResourceController | @@ -26,5 +26,13 @@ class TreeController < ProjectResourceController | ||
26 | 26 | ||
27 | def update | 27 | def update |
28 | last_commit = @project.commits(@ref, @path, 1).first.sha | 28 | last_commit = @project.commits(@ref, @path, 1).first.sha |
29 | + file_editor = Gitlab::FileEditor.new(current_user, @project) | ||
30 | + if file_editor.can_edit?(@path, last_commit) | ||
31 | + file_editor.update(@path, params[:content]) | ||
32 | + redirect_to project_tree_path(@project, @id), :notice => "File has been successfully changed" | ||
33 | + else | ||
34 | + flash[:notice] = "You can't save file because it has been changed" | ||
35 | + render :edit | ||
36 | + end | ||
29 | end | 37 | end |
30 | end | 38 | end |
app/views/tree/edit.html.haml
@@ -8,9 +8,9 @@ | @@ -8,9 +8,9 @@ | ||
8 | #editor= @tree.data | 8 | #editor= @tree.data |
9 | 9 | ||
10 | .editor-commit-comment | 10 | .editor-commit-comment |
11 | - = label_tag 'text-commit' do | 11 | + = label_tag 'commit_message' do |
12 | %p.slead Commit message | 12 | %p.slead Commit message |
13 | - = text_area_tag 'text_commit' | 13 | + = text_area_tag 'commit_message' |
14 | .form-actions | 14 | .form-actions |
15 | = hidden_field_tag 'last_commit', @last_commit | 15 | = hidden_field_tag 'last_commit', @last_commit |
16 | = hidden_field_tag 'content' | 16 | = hidden_field_tag 'content' |
@@ -0,0 +1,20 @@ | @@ -0,0 +1,20 @@ | ||
1 | +module Gitlab | ||
2 | + class FileEditor | ||
3 | + | ||
4 | + attr_accessor :user, :project | ||
5 | + | ||
6 | + def initialize(user, project) | ||
7 | + self.user = user | ||
8 | + self.project = project | ||
9 | + end | ||
10 | + | ||
11 | + def can_edit?(path, last_commit) | ||
12 | + true | ||
13 | + end | ||
14 | + | ||
15 | + def update(path, content) | ||
16 | + true | ||
17 | + end | ||
18 | + | ||
19 | + end | ||
20 | +end |