summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/content_editor/components/formatting_toolbar.vue
blob: 36ca3b8cfb602f26647ba7f87812f7461483717b (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
<script>
import EditorModeDropdown from '~/vue_shared/components/markdown/editor_mode_dropdown.vue';
import trackUIControl from '../services/track_ui_control';
import ToolbarButton from './toolbar_button.vue';
import ToolbarImageButton from './toolbar_image_button.vue';
import ToolbarLinkButton from './toolbar_link_button.vue';
import ToolbarTableButton from './toolbar_table_button.vue';
import ToolbarTextStyleDropdown from './toolbar_text_style_dropdown.vue';
import ToolbarMoreDropdown from './toolbar_more_dropdown.vue';

export default {
  components: {
    EditorModeDropdown,
    ToolbarButton,
    ToolbarTextStyleDropdown,
    ToolbarLinkButton,
    ToolbarTableButton,
    ToolbarImageButton,
    ToolbarMoreDropdown,
  },
  methods: {
    trackToolbarControlExecution({ contentType, value }) {
      trackUIControl({ property: contentType, value });
    },
    handleEditorModeChanged(mode) {
      if (mode === 'markdown') {
        this.$emit('enableMarkdownEditor');
      }
    },
  },
};
</script>
<template>
  <div class="gl-display-flex gl-flex-wrap gl-pb-3 gl-pt-3">
    <toolbar-text-style-dropdown
      data-testid="text-styles"
      class="gl-mr-3"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-button
      data-testid="bold"
      content-type="bold"
      icon-name="bold"
      class="gl-mx-2"
      editor-command="toggleBold"
      :label="__('Bold text')"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-button
      data-testid="italic"
      content-type="italic"
      icon-name="italic"
      class="gl-mx-2"
      editor-command="toggleItalic"
      :label="__('Italic text')"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-button
      data-testid="blockquote"
      content-type="blockquote"
      icon-name="quote"
      class="gl-mx-2"
      editor-command="toggleBlockquote"
      :label="__('Insert a quote')"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-button
      data-testid="code"
      content-type="code"
      icon-name="code"
      class="gl-mx-2"
      editor-command="toggleCode"
      :label="__('Code')"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-link-button data-testid="link" @execute="trackToolbarControlExecution" />
    <toolbar-button
      data-testid="bullet-list"
      content-type="bulletList"
      icon-name="list-bulleted"
      class="gl-mx-2 gl-display-none gl-sm-display-inline"
      editor-command="toggleBulletList"
      :label="__('Add a bullet list')"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-button
      data-testid="ordered-list"
      content-type="orderedList"
      icon-name="list-numbered"
      class="gl-mx-2 gl-display-none gl-sm-display-inline"
      editor-command="toggleOrderedList"
      :label="__('Add a numbered list')"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-button
      data-testid="task-list"
      content-type="taskList"
      icon-name="list-task"
      class="gl-mx-2 gl-display-none gl-sm-display-inline"
      editor-command="toggleTaskList"
      :label="__('Add a checklist')"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-image-button
      ref="imageButton"
      data-testid="image"
      @execute="trackToolbarControlExecution"
    />
    <toolbar-table-button data-testid="table" @execute="trackToolbarControlExecution" />
    <toolbar-more-dropdown data-testid="more" @execute="trackToolbarControlExecution" />

    <editor-mode-dropdown class="gl-ml-auto" value="richText" @input="handleEditorModeChanged" />
  </div>
</template>
<style>
.gl-spinner-container {
  text-align: left;
}
</style>