summaryrefslogtreecommitdiff
path: root/qa/qa/page/component/design_management.rb
blob: 71c24b6cac8881fbf7723a2eb36bb5fb43d5129a (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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
# frozen_string_literal: true

module QA
  module Page
    module Component
      module DesignManagement
        extend QA::Page::PageConcern

        def self.included(base)
          super

          base.class_eval do
            view 'app/assets/javascripts/design_management/components/design_notes/design_discussion.vue' do
              element :design_discussion_content
            end

            view 'app/assets/javascripts/design_management/components/design_notes/design_note.vue' do
              element :note_content
            end

            view 'app/assets/javascripts/design_management/components/design_notes/design_reply_form.vue' do
              element :note_textarea
              element :save_comment_button
            end

            view 'app/assets/javascripts/design_management/components/design_overlay.vue' do
              element :design_image_button
            end

            view 'app/assets/javascripts/design_management/components/list/item.vue' do
              element :design_file_name
              element :design_image
              element :design_status_icon
            end

            view 'app/assets/javascripts/design_management/pages/index.vue' do
              element :archive_button
              element :design_checkbox
              element :design_dropzone_content
            end

            view 'app/assets/javascripts/design_management/components/delete_button.vue' do
              element :confirm_archiving_button
            end
          end
        end

        def add_annotation(note)
          click_element(:design_image_button)
          fill_element(:note_textarea, note)
          click_element(:save_comment_button)

          # It takes a moment for the annotation to be saved.
          # We'll check for the annotation in a test, but here we'll at least
          # wait for the "Save comment" button to disappear
          saved = has_no_element?(:save_comment_button)
          return if saved

          raise RSpec::Expectations::ExpectationNotMetError, %q(There was a problem while adding the annotation)
        end

        def add_design(design_file_path)
          # `attach_file` doesn't seem able to find element via data attributes.
          # It accepts a `class:` option, but that only works for class attributes
          # It doesn't work as a CSS selector.
          # So instead we use the name attribute as a locator
          within_element(:design_dropzone_content) do
            page.attach_file("upload_file", design_file_path, make_visible: { display: 'block' })
          end

          filename = ::File.basename(design_file_path)

          wait_until(reload: false, sleep_interval: 1, message: "Design upload") do
            image = find_element(:design_image, filename: filename)

            has_element?(:design_file_name, text: filename) && image["complete"] && image["naturalWidth"].to_i > 0
          end
        end

        def update_design(filename)
          filepath = ::File.join(Runtime::Path.fixtures_path, 'designs', 'update', filename)
          add_design(filepath)
        end

        def click_design(filename)
          click_element(:design_file_name, text: filename)
        end

        def select_design(filename)
          click_element(:design_checkbox, design: filename)
        end

        def archive_selected_designs
          click_element(:archive_button)
          click_element(:confirm_archiving_button)
        end

        def has_annotation?(note)
          within_element_by_index(:design_discussion_content, 0) do
            has_element?(:note_content, text: note)
          end
        end

        def has_design?(filename)
          has_element?(:design_file_name, text: filename)
        end

        def has_no_design?(filename)
          has_no_element?(:design_file_name, text: filename)
        end

        def has_created_icon?
          has_element?(:design_status_icon, status: 'file-addition-solid')
        end

        def has_modified_icon?
          has_element?(:design_status_icon, status: 'file-modified-solid')
        end
      end
    end
  end
end