summaryrefslogtreecommitdiff
path: root/app/views/shared/snippets/_form.html.haml
blob: 198735df5eebbaa37fccbb6fc8e2d6a9e2401385 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
- if Feature.enabled?(:snippets_edit_vue, default_enabled: true)
  - available_visibility_levels = available_visibility_levels(@snippet)
  #js-snippet-edit.snippet-form{ data: {'project_path': @snippet.project&.full_path, 'snippet-gid': @snippet.new_record? ? '' : @snippet.to_global_id, 'markdown-preview-path': preview_markdown_path(parent), 'markdown-docs-path': help_page_path('user/markdown'), 'visibility-help-link': help_page_path("public_access/public_access"), 'visibility_levels': available_visibility_levels, 'selected_level': snippets_selected_visibility_level(available_visibility_levels, @snippet.visibility_level), 'multiple_levels_restricted': multiple_visibility_levels_restricted? } }
- else
  .snippet-form-holder
    = form_for @snippet, url: url,
           html: { class: "snippet-form js-requires-input js-quick-submit common-note-form" },
           data: { "snippet-type": @snippet.project_id ? 'project' : 'personal'} do |f|
      = form_errors(@snippet)

      .form-group
        = f.label :title, class: 'label-bold'
        = f.text_field :title, class: 'form-control', required: true, autofocus: true, data: { qa_selector: 'snippet_title_field' }

      .form-group.js-description-input
        - description_placeholder = s_('Snippets|Optionally add a description about what your snippet does or how to use it...')
        - is_expanded = @snippet.description && !@snippet.description.empty?
        = f.label :description, s_("Snippets|Description (optional)"), class: 'label-bold'
        .js-collapsible-input
          .js-collapsed{ class: ('d-none' if is_expanded) }
            = text_field_tag nil, nil, class: 'form-control', placeholder: description_placeholder, data: { qa_selector: 'description_placeholder' }
          .js-expanded{ class: ('d-none' if !is_expanded) }
            = render layout: 'shared/md_preview', locals: { url: preview_markdown_path(@project), referenced_users: true } do
              = render 'shared/zen', f: f, attr: :description, classes: 'note-textarea', placeholder: description_placeholder, qa_selector: 'snippet_description_field'
              = render 'shared/notes/hints'

      .form-group.file-editor
        = f.label :file_name, s_('Snippets|File')
        .file-holder.snippet
          .js-file-title.file-title-flex-parent
            = f.text_field :file_name, placeholder: s_("Snippets|Give your file a name to add code highlighting, e.g. example.rb for Ruby"), class: 'form-control js-snippet-file-name', data: { qa_selector: 'file_name_field' }
          .file-content.code
            #editor{ data: { 'editor-loading': true } }<
              %pre.editor-loading-content= @snippet.content
            = f.hidden_field :content, class: 'snippet-file-content'

      .form-group
        .font-weight-bold
          = _('Visibility level')
          = link_to sprite_icon('question-o'), help_page_path('public_access/public_access'), target: '_blank'
        = render 'shared/visibility_level', f: f, visibility_level: @snippet.visibility_level, can_change_visibility_level: true, form_model: @snippet, with_label: false

      - if params[:files]
        - params[:files].each_with_index do |file, index|
          = hidden_field_tag "files[]", file, id: "files_#{index}"

      .form-actions
        - if @snippet.new_record?
          = f.submit 'Create snippet', class: "btn-success btn", data: { qa_selector: 'submit_button' }
        - else
          = f.submit 'Save changes', class: "btn-success btn", data: { qa_selector: 'submit_button' }

        - if @snippet.project_id
          = link_to "Cancel", project_snippets_path(@project), class: "btn btn-cancel"
        - else
          = link_to "Cancel", snippets_path(@project), class: "btn btn-cancel"