Commit cadbd3f0c1bd53fed7d081ef514833c4030a19da

Authored by Dmitriy Zaporozhets
2 parents 753a2f17 ef404d8e

Merge pull request #6027 from jvanbaarsen/snippet-fix

Removed expiration from snippets
app/views/projects/snippets/_form.html.haml
@@ -2,7 +2,7 @@ @@ -2,7 +2,7 @@
2 = @snippet.new_record? ? "New Snippet" : "Edit Snippet ##{@snippet.id}" 2 = @snippet.new_record? ? "New Snippet" : "Edit Snippet ##{@snippet.id}"
3 %hr 3 %hr
4 .snippet-form-holder 4 .snippet-form-holder
5 - = form_for [@project, @snippet], as: :project_snippet, url: url do |f| 5 + = form_for [@project, @snippet], as: :project_snippet, url: url, html: {class: "form-horizontal snippet-form"} do |f|
6 -if @snippet.errors.any? 6 -if @snippet.errors.any?
7 .alert.alert-danger 7 .alert.alert-danger
8 %ul 8 %ul
@@ -10,14 +10,11 @@ @@ -10,14 +10,11 @@
10 %li= msg 10 %li= msg
11 11
12 .form-group 12 .form-group
13 - = f.label :title 13 + = f.label :title, class: 'control-label'
14 .col-sm-10= f.text_field :title, placeholder: "Example Snippet", class: 'form-control', required: true 14 .col-sm-10= f.text_field :title, placeholder: "Example Snippet", class: 'form-control', required: true
15 .form-group 15 .form-group
16 - = f.label "Lifetime"  
17 - .col-sm-10= f.select :expires_at, lifetime_select_options, {}, {class: 'select2 span2'}  
18 - .form-group  
19 .file-editor 16 .file-editor
20 - = f.label :file_name, "File" 17 + = f.label :file_name, "File", class: 'control-label'
21 .col-sm-10 18 .col-sm-10
22 .file-holder.snippet 19 .file-holder.snippet
23 .file-title 20 .file-title
@@ -31,10 +28,11 @@ @@ -31,10 +28,11 @@
31 = f.submit 'Create snippet', class: "btn-create btn" 28 = f.submit 'Create snippet', class: "btn-create btn"
32 - else 29 - else
33 = f.submit 'Save', class: "btn-save btn" 30 = f.submit 'Save', class: "btn-save btn"
34 - = link_to "Cancel", project_snippets_path(@project), class: "btn btn-cancel"  
35 31
36 - - unless @snippet.new_record?  
37 - = link_to 'Remove snippet', project_snippet_path(@project, @snippet), data: { confirm: 'Are you sure?' }, method: :delete, class: "btn pull-right btn-remove delete-snippet prepend-left-10", id: "destroy_snippet_#{@snippet.id}" 32 + - unless @snippet.new_record?
  33 + .pull-right.prepend-left-20
  34 + = link_to 'Remove snippet', project_snippet_path(@project, @snippet), data: { confirm: 'Are you sure?' }, method: :delete, class: "btn pull-right btn-remove delete-snippet prepend-left-10", id: "destroy_snippet_#{@snippet.id}"
  35 + = link_to "Cancel", project_snippets_path(@project), class: "btn btn-cancel"
38 36
39 :javascript 37 :javascript
40 var editor = ace.edit("editor"); 38 var editor = ace.edit("editor");
doc/api/project_snippets.md
@@ -57,7 +57,6 @@ Parameters: @@ -57,7 +57,6 @@ Parameters:
57 + `id` (required) - The ID of a project 57 + `id` (required) - The ID of a project
58 + `title` (required) - The title of a snippet 58 + `title` (required) - The title of a snippet
59 + `file_name` (required) - The name of a snippet file 59 + `file_name` (required) - The name of a snippet file
60 -+ `lifetime` (optional) - The expiration date of a snippet  
61 + `code` (required) - The content of a snippet 60 + `code` (required) - The content of a snippet
62 61
63 62
@@ -75,7 +74,6 @@ Parameters: @@ -75,7 +74,6 @@ Parameters:
75 + `snippet_id` (required) - The ID of a project's snippet 74 + `snippet_id` (required) - The ID of a project's snippet
76 + `title` (optional) - The title of a snippet 75 + `title` (optional) - The title of a snippet
77 + `file_name` (optional) - The name of a snippet file 76 + `file_name` (optional) - The name of a snippet file
78 -+ `lifetime` (optional) - The expiration date of a snippet  
79 + `code` (optional) - The content of a snippet 77 + `code` (optional) - The content of a snippet
80 78
81 79
features/steps/project/project_snippets.rb
@@ -53,7 +53,6 @@ class ProjectSnippets < Spinach::FeatureSteps @@ -53,7 +53,6 @@ class ProjectSnippets < Spinach::FeatureSteps
53 53
54 And 'I submit new snippet "Snippet three"' do 54 And 'I submit new snippet "Snippet three"' do
55 fill_in "project_snippet_title", :with => "Snippet three" 55 fill_in "project_snippet_title", :with => "Snippet three"
56 - select "forever", :from => "project_snippet_expires_at"  
57 fill_in "project_snippet_file_name", :with => "my_snippet.rb" 56 fill_in "project_snippet_file_name", :with => "my_snippet.rb"
58 within('.file-editor') do 57 within('.file-editor') do
59 find(:xpath, "//input[@id='project_snippet_content']").set 'Content of snippet three' 58 find(:xpath, "//input[@id='project_snippet_content']").set 'Content of snippet three'
lib/api/project_snippets.rb
@@ -41,7 +41,6 @@ module API @@ -41,7 +41,6 @@ module API
41 # id (required) - The ID of a project 41 # id (required) - The ID of a project
42 # title (required) - The title of a snippet 42 # title (required) - The title of a snippet
43 # file_name (required) - The name of a snippet file 43 # file_name (required) - The name of a snippet file
44 - # lifetime (optional) - The expiration date of a snippet  
45 # code (required) - The content of a snippet 44 # code (required) - The content of a snippet
46 # Example Request: 45 # Example Request:
47 # POST /projects/:id/snippets 46 # POST /projects/:id/snippets
@@ -50,7 +49,6 @@ module API @@ -50,7 +49,6 @@ module API
50 required_attributes! [:title, :file_name, :code] 49 required_attributes! [:title, :file_name, :code]
51 50
52 attrs = attributes_for_keys [:title, :file_name] 51 attrs = attributes_for_keys [:title, :file_name]
53 - attrs[:expires_at] = params[:lifetime] if params[:lifetime].present?  
54 attrs[:content] = params[:code] if params[:code].present? 52 attrs[:content] = params[:code] if params[:code].present?
55 @snippet = user_project.snippets.new attrs 53 @snippet = user_project.snippets.new attrs
56 @snippet.author = current_user 54 @snippet.author = current_user
@@ -69,7 +67,6 @@ module API @@ -69,7 +67,6 @@ module API
69 # snippet_id (required) - The ID of a project snippet 67 # snippet_id (required) - The ID of a project snippet
70 # title (optional) - The title of a snippet 68 # title (optional) - The title of a snippet
71 # file_name (optional) - The name of a snippet file 69 # file_name (optional) - The name of a snippet file
72 - # lifetime (optional) - The expiration date of a snippet  
73 # code (optional) - The content of a snippet 70 # code (optional) - The content of a snippet
74 # Example Request: 71 # Example Request:
75 # PUT /projects/:id/snippets/:snippet_id 72 # PUT /projects/:id/snippets/:snippet_id
@@ -78,7 +75,6 @@ module API @@ -78,7 +75,6 @@ module API
78 authorize! :modify_project_snippet, @snippet 75 authorize! :modify_project_snippet, @snippet
79 76
80 attrs = attributes_for_keys [:title, :file_name] 77 attrs = attributes_for_keys [:title, :file_name]
81 - attrs[:expires_at] = params[:lifetime] if params[:lifetime].present?  
82 attrs[:content] = params[:code] if params[:code].present? 78 attrs[:content] = params[:code] if params[:code].present?
83 79
84 if @snippet.update_attributes attrs 80 if @snippet.update_attributes attrs