lesli_support 1.0.0 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. checksums.yaml +4 -4
  2. data/app/controllers/lesli_support/item/discussions_controller.rb +6 -0
  3. data/app/controllers/lesli_support/item/tasks_controller.rb +6 -0
  4. data/app/controllers/lesli_support/tickets_controller.rb +6 -5
  5. data/app/models/lesli_support/item/activity.rb +4 -0
  6. data/app/models/lesli_support/item/discussion.rb +6 -0
  7. data/app/models/lesli_support/item/task.rb +6 -0
  8. data/app/models/lesli_support/ticket.rb +14 -9
  9. data/app/views/lesli_support/dashboards/_component-latest-tickets.html.erb +1 -1
  10. data/app/views/lesli_support/tickets/show.html.erb +10 -7
  11. data/db/migrate/v1/0702000110_create_lesli_support_accounts.rb +7 -0
  12. data/db/migrate/v1/0702110110_create_lesli_support_tickets.rb +0 -7
  13. data/db/seeds.rb +1 -1
  14. data/lib/lesli_support/version.rb +2 -2
  15. metadata +8 -29
  16. data/app/controllers/lesli_support/options_controller.rb +0 -23
  17. data/app/controllers/lesli_support/ticket/actions_controller.rb +0 -4
  18. data/app/helpers/lesli_support/options_helper.rb +0 -4
  19. data/app/helpers/lesli_support/ticket/actions_helper.rb +0 -4
  20. data/app/models/lesli_support/option.rb +0 -4
  21. data/app/models/lesli_support/ticket/action.rb +0 -6
  22. data/app/views/lesli_support/options/_form.html.erb +0 -17
  23. data/app/views/lesli_support/options/_option.html.erb +0 -2
  24. data/app/views/lesli_support/options/edit.html.erb +0 -10
  25. data/app/views/lesli_support/options/index.html.erb +0 -14
  26. data/app/views/lesli_support/options/new.html.erb +0 -9
  27. data/app/views/lesli_support/options/show.html.erb +0 -10
  28. data/lib/scss/application.scss +0 -0
  29. data/lib/vue/application.js +0 -93
  30. data/lib/vue/apps/dashboard/components/engine-version.vue +0 -71
  31. data/lib/vue/apps/dashboard/components/my-tasks.vue +0 -77
  32. data/lib/vue/apps/tickets/components/assignments.vue +0 -93
  33. data/lib/vue/apps/tickets/components/form.vue +0 -305
  34. data/lib/vue/apps/tickets/components/internal-comments.vue +0 -107
  35. data/lib/vue/apps/tickets/components/sla-info.vue +0 -115
  36. data/lib/vue/apps/tickets/components/table.vue +0 -94
  37. data/lib/vue/apps/tickets/index.vue +0 -145
  38. data/lib/vue/apps/tickets/new.vue +0 -78
  39. data/lib/vue/apps/tickets/show.vue +0 -183
  40. data/lib/vue/stores/tickets.js +0 -276
  41. data/lib/vue/stores/translations.json +0 -162
@@ -1,77 +0,0 @@
1
- <script setup>
2
- /*
3
- Lesli
4
-
5
- Copyright (c) 2023, Lesli Technologies, S. A.
6
-
7
- This program is free software: you can redistribute it and/or modify
8
- it under the terms of the GNU General Public License as published by
9
- the Free Software Foundation, either version 3 of the License, or
10
- (at your option) any later version.
11
-
12
- This program is distributed in the hope that it will be useful,
13
- but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
- GNU General Public License for more details.
16
-
17
- You should have received a copy of the GNU General Public License
18
- along with this program. If not, see http://www.gnu.org/licenses/.
19
-
20
- Lesli · Ruby on Rails SaaS Development Framework.
21
-
22
- Made with ♥ by https://www.lesli.tech
23
- Building a better future, one line of code at a time.
24
-
25
- @contact hello@lesli.tech
26
- @website https://www.lesli.tech
27
- @license GPLv3 http://www.gnu.org/licenses/gpl-3.0.en.html
28
-
29
- // · ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~
30
- // ·
31
- */
32
-
33
-
34
- // ·
35
- import { onMounted, inject, ref } from "vue"
36
-
37
-
38
- // ·
39
- import { lesliChartBar } from "lesli-vue/components"
40
-
41
-
42
- // ·
43
- const url = inject("url")
44
- const http = inject("http")
45
-
46
-
47
- // ·
48
- const lesliVersion = ref({
49
- name: "",
50
- code: "",
51
- path: "",
52
- version: "",
53
- build: ""
54
- })
55
-
56
-
57
- // ·
58
- onMounted(() => {
59
- console.log("component works")
60
- // http.get(url.lesli("about")).then(result => {
61
- // lesliVersion.value = result.find(engine => engine.name == "Lesli")
62
- // }).catch(error => {
63
- // console.log(error)
64
- // })
65
- })
66
- </script>
67
- <template>
68
- <lesli-card>
69
- <h6 class="title is-6 mb-2">
70
- hola
71
- </h6>
72
- <lesli-chart-bar
73
- :labels="['hola1', 'hola2', 'hola3', 'hola4', 'hola5']"
74
- :series="[{ data:[4, 1, 4, 2, 5] }]">
75
- </lesli-chart-bar>
76
- </lesli-card>
77
- </template>
@@ -1,93 +0,0 @@
1
- <script setup>
2
- /*
3
- Copyright (c) 2022, all rights reserved.
4
-
5
- All the information provided by this platform is protected by international laws related to
6
- industrial property, intellectual property, copyright and relative international laws.
7
- All intellectual or industrial property rights of the code, texts, trade mark, design,
8
- pictures and any other information belongs to the owner of this platform.
9
-
10
- Without the written permission of the owner, any replication, modification,
11
- transmission, publication is strictly forbidden.
12
-
13
- For more information read the license file including with this software.
14
-
15
- // · ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~
16
- // ·
17
- */
18
-
19
-
20
- // · import vue tools
21
- import { onMounted } from "vue"
22
-
23
- // · import lesli stores
24
- import { useAssignments } from "LesliSupport/vue/stores/tickets/assignment"
25
-
26
- // · import vue router composable
27
- import { useRoute } from "vue-router"
28
-
29
- // · implement stores
30
- const storeAssignments = useAssignments()
31
-
32
- // · initialize/inject plugins
33
- const route = useRoute()
34
-
35
- // ·
36
- const translations = {
37
- users: I18n.t("core.users"),
38
- shared: I18n.t("core.shared"),
39
- sla: I18n.t('help.slas'),
40
- main: I18n.t('help.tickets')
41
- }
42
-
43
- const columns = [{
44
- field: "name",
45
- label: translations.users.view_table_header_name
46
- }, {
47
- field: "email",
48
- label: translations.users.view_table_header_email
49
- }, {
50
- field: "roles",
51
- label: translations.users.view_table_header_role
52
- }, {
53
- field: "assigned",
54
- label: ""
55
- }]
56
-
57
-
58
- onMounted(() => {
59
- storeAssignments.ticket_id = route.params.id
60
- storeAssignments.fetchTicket(route.params.id)
61
- })
62
-
63
- /**
64
- * @description This action is used to verify if a user is assigned or unassigned
65
- * @param {Object} user The user to be checked
66
- */
67
- function submitAssignment(user){
68
- if(!user.checked){
69
- storeAssignments.postAssignment(user)
70
- }else{
71
- storeAssignments.deleteAssignment(user.assignment_id)
72
- }
73
- }
74
-
75
- </script>
76
- <template>
77
- <h5 class="title is-5">{{translations.main.view_tab_title_assignments}}</h5>
78
- <lesli-table
79
- :records="storeAssignments.users"
80
- :columns="columns">
81
- <template #roles="{ column, value }">
82
- <span
83
- v-for="role in value"
84
- :key="role.id"
85
- class="tag is-success is-small is-rounded mr-1">
86
- {{ role.name }}
87
- </span>
88
- </template>
89
- <template #assigned="{ record, value }">
90
- <input type="checkbox" v-model="record.checked" @input="submitAssignment(record)">
91
- </template>
92
- </lesli-table>
93
- </template>
@@ -1,305 +0,0 @@
1
- <script setup>
2
- /*
3
- Lesli
4
-
5
- Copyright (c) 2023, Lesli Technologies, S. A.
6
-
7
- This program is free software: you can redistribute it and/or modify
8
- it under the terms of the GNU General Public License as published by
9
- the Free Software Foundation, either version 3 of the License, or
10
- (at your option) any later version.
11
-
12
- This program is distributed in the hope that it will be useful,
13
- but WITHOUT ANY WARRANTY; without even the implied warranty of
14
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
- GNU General Public License for more details.
16
-
17
- You should have received a copy of the GNU General Public License
18
- along with this program. If not, see http://www.gnu.org/licenses/.
19
-
20
- Lesli · Ruby on Rails SaaS Development Framework.
21
-
22
- Made with ♥ by https://www.lesli.tech
23
- Building a better future, one line of code at a time.
24
-
25
- @contact hello@lesli.tech
26
- @website https://www.lesli.tech
27
- @license GPLv3 http://www.gnu.org/licenses/gpl-3.0.en.html
28
-
29
- // · ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~
30
- // ·
31
- */
32
-
33
-
34
- // · import vue tools
35
- import { inject, onMounted, ref, onUnmounted } from "vue"
36
-
37
-
38
- // · import vue router composable
39
- import { useRouter, useRoute } from "vue-router"
40
-
41
-
42
- // · initialize/inject plugins
43
- const router = useRouter()
44
- const route = useRoute()
45
- const date = inject("date")
46
- const url = inject("url")
47
-
48
-
49
- // ·
50
- import { LesliTextEditor } from "lesli-vue/components"
51
-
52
-
53
- // · import lesli stores
54
- import { useTickets } from "LesliSupport/vue/stores/tickets"
55
- //import { useAssignments } from "LesliSupport/stores/tickets/assignment"
56
-
57
-
58
- // · implement stores
59
- const storeTickets = useTickets()
60
- //const storeAssignments = useAssignments()
61
-
62
-
63
- // · defining props
64
- const props = defineProps({
65
- editable: {
66
- type: Boolean,
67
- required: false,
68
- default: false,
69
- },
70
- path: {
71
- type: String,
72
- required: false,
73
- default: "help/tickets",
74
- }
75
- })
76
-
77
-
78
- // ·
79
- const translations = {
80
- tickets: i18n.t("lesli_support.tickets"),
81
- lesli: { shared: i18n.t("lesli.shared") },
82
-
83
- users: I18n.t("core.users"),
84
- shared: I18n.t("core.shared"),
85
- main: I18n.t('help.tickets')
86
- }
87
-
88
-
89
- // ·
90
- function onUpdate() {
91
- console.log("update")
92
- storeTickets.updateTicket()
93
- }
94
-
95
-
96
- // ·
97
- const onCreate = () => {
98
- console.log("create")
99
- storeTickets.postTicket().then(result => {
100
- //this.msg.success(I18n.t("core.users.messages_success_operation"))
101
- router.push(url.support('tickets/:id', result.id).toString())
102
- }).catch(error => {
103
- this.msg.danger(I18n.t("core.shared.messages_danger_internal_error"))
104
- })
105
- }
106
-
107
-
108
- // ·
109
- onMounted(() => {
110
- storeTickets.getOptions()
111
- // storeTickets.ticket = {}
112
- // storeTickets.tags = []
113
- })
114
- </script>
115
- <template>
116
- <lesli-form
117
- :editable="props.editable"
118
- @submit="route.params.id ? onUpdate() : onCreate()"
119
- disabled="storeTickets.ticket.status=='closed'">
120
-
121
- <!-- Ticket subject -->
122
- <div class="field" v-if="props.editable">
123
- <label class="label">
124
- {{ translations.tickets.column_subject }}
125
- <span class="is-danger">*</span>
126
- </label>
127
- <div class="control">
128
- <input name="subject" class="input" required v-model="storeTickets.ticket.subject">
129
- </div>
130
- </div>
131
-
132
- <fieldset v-if="route.params.id">
133
- <legend></legend>
134
-
135
- <!-- Ticket creator name -->
136
- <div class="field">
137
- <label class="label">ID</label>
138
- <div class="control">
139
- <input class="input" disabled v-model="storeTickets.ticket.id">
140
- </div>
141
- </div>
142
-
143
- <!-- Ticket reference url -->
144
- <div class="field" v-if="!props.editable">
145
- <label class="label">Reference URL</label>
146
- <div class="control">
147
- <input name="reference_url" disabled type="text" class="input" v-model="storeTickets.ticket.reference_url">
148
- </div>
149
- </div>
150
-
151
- <!-- Ticket workspace -->
152
- <div class="field">
153
- <label class="label">Workspace</label>
154
- <div class="control">
155
- <lesli-select
156
- v-if="storeTickets.options.workspaces"
157
- :options="storeTickets.options.workspaces"
158
- v-model="storeTickets.ticket.catalog_workspace_id">
159
- </lesli-select>
160
- </div>
161
- </div>
162
- </fieldset>
163
-
164
- <!-- Ticket assigned users
165
- <div class="field" v-if="route.params.id">
166
- <label class="label">Assigned users</label>
167
- <div class="control">
168
- <div v-for="assignment in storeTickets.ticket.assignment_attributes" :key="assignment">
169
- <span class="tag is-success">{{assignment.assignable_name}}
170
- <button class="delete is-small" @click="storeAssignments.deleteAssignment(assignment.id)" type="button"></button>
171
- </span>
172
- </div>
173
- </div>
174
- </div>
175
- -->
176
-
177
- <fieldset v-if="route.params.id">
178
- <legend></legend>
179
- <lesli-columns>
180
-
181
- <!-- Ticket types -->
182
- <lesli-column>
183
- <div class="field">
184
- <label class="label">
185
- Type
186
- </label>
187
- <div class="control">
188
- <lesli-select
189
- :options="storeTickets.options.types"
190
- v-model="storeTickets.ticket.catalog_type_id">
191
- </lesli-select>
192
- </div>
193
- </div>
194
- </lesli-column>
195
-
196
- <!-- Ticket category -->
197
- <lesli-column>
198
- <div class="field">
199
- <label class="label">
200
- Category
201
- </label>
202
- <div class="control">
203
- <lesli-select
204
- v-if="storeTickets.options.categories"
205
- :options="storeTickets.options.categories"
206
- v-model="storeTickets.ticket.catalog_category_id">
207
- </lesli-select>
208
- </div>
209
- </div>
210
- </lesli-column>
211
-
212
- <!-- Ticket priority -->
213
- <lesli-column>
214
- <div class="field">
215
- <label class="label">
216
- Priority
217
- </label>
218
- <div class="control">
219
- <lesli-select
220
- v-if="storeTickets.options.priorities"
221
- :options="storeTickets.options.priorities"
222
- v-model="storeTickets.ticket.catalog_priority_id">
223
- </lesli-select>
224
- </div>
225
- </div>
226
- </lesli-column>
227
- </lesli-columns>
228
-
229
-
230
- <lesli-columns v-if="route.params.id">
231
-
232
- <!-- Ticket deadline -->
233
- <lesli-column>
234
- <div class="field">
235
- <label class="label">
236
- Deadline
237
- </label>
238
- <div class="control">
239
- <lesli-calendar mode="dateTime" v-model="storeTickets.ticket.deadline">
240
- </lesli-calendar>
241
- </div>
242
- </div>
243
- </lesli-column>
244
-
245
-
246
- <!-- Ticket started at date -->
247
- <lesli-column>
248
- <div class="field">
249
- <label class="label">
250
- Started At
251
- </label>
252
- <div class="control">
253
- <lesli-calendar v-model="storeTickets.ticket.started_at">
254
- </lesli-calendar>
255
- </div>
256
- </div>
257
- </lesli-column>
258
-
259
- <!-- Ticket finished at date -->
260
- <lesli-column>
261
- <div class="field">
262
- <label class="label">
263
- Completed at
264
- </label>
265
- <div class="control">
266
- <lesli-calendar v-model="storeTickets.ticket.completed_at">
267
- </lesli-calendar>
268
- </div>
269
- </div>
270
- </lesli-column>
271
- </lesli-columns>
272
- </fieldset>
273
-
274
- <!-- Ticket hours worked -->
275
- <div class="field" v-if="route.params.id">
276
- <label class="label">
277
- Hours worked
278
- </label>
279
- <div class="control">
280
- <input name="Hours_worked" class="input" type="number" step="any" v-model="storeTickets.ticket.hours_worked">
281
- </div>
282
- </div>
283
-
284
- <!-- Ticket description -->
285
- <div class="field">
286
- <label class="label">
287
- Description
288
- </label>
289
- <div class="control">
290
- <lesli-text-editor :editable="props.editable" mode="normal" v-model="storeTickets.ticket.description">
291
- </lesli-text-editor>
292
- </div>
293
- </div>
294
-
295
-
296
- <div class="field">
297
- <label class="label"></label>
298
- <div class="control">
299
- <lesli-button icon="save">
300
- {{ translations.lesli.shared.button_save }}
301
- </lesli-button>
302
- </div>
303
- </div>
304
- </lesli-form>
305
- </template>
@@ -1,107 +0,0 @@
1
- <script setup>
2
- /*
3
- Copyright (c) 2022, all rights reserved.
4
-
5
- All the information provided by this platform is protected by international laws related to
6
- industrial property, intellectual property, copyright and relative international laws.
7
- All intellectual or industrial property rights of the code, texts, trade mark, design,
8
- pictures and any other information belongs to the owner of this platform.
9
-
10
- Without the written permission of the owner, any replication, modification,
11
- transmission, publication is strictly forbidden.
12
-
13
- For more information read the license file including with this software.
14
-
15
- // · ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~
16
- // ·
17
- */
18
-
19
-
20
- // · import vue tools
21
- import { onMounted } from "vue"
22
-
23
- // · import lesli stores
24
- import { useHistory } from "LesliSupport/vue/stores/tickets/history"
25
-
26
- // · import vue router composable
27
- import { useRoute } from "vue-router"
28
-
29
- // · implement stores
30
- const storeHistories = useHistory()
31
-
32
- // · initialize/inject plugins
33
- const route = useRoute()
34
-
35
- // ·
36
- const translations = {
37
- shared: I18n.t("core.shared"),
38
- histories: I18n.t('help.ticket/histories'),
39
- help:{
40
- shared: I18n.t('help.shared')
41
- },
42
- core: I18n.t('core.shared'),
43
- main: I18n.t('help.ticket/histories')
44
- }
45
-
46
- const columns = [{
47
- field: "created_at",
48
- label: translations.core.column_created_at,
49
- }, {
50
- field: "user_creator_name",
51
- label: translations.main.column_users_id,
52
- }, {
53
- field: "content",
54
- label: translations.main.column_content
55
- }]
56
-
57
- onMounted(() => {
58
- storeHistories.getHistories(route.params.id)
59
- storeHistories.ticket_id = route.params.id
60
- })
61
-
62
- /**
63
- * @description This function is used to create a new internal comment
64
- */
65
- const onCreate = () => {
66
- storeHistories.createHistory()
67
-
68
- }
69
-
70
-
71
- </script>
72
- <template>
73
-
74
- <h2>{{translations.histories.view_title_main}}</h2>
75
-
76
- <div class="block">
77
- <form @submit.prevent="onCreate()">
78
- <div class="columns">
79
- <div class="column is-6">
80
- <input name="comment" type="text" :placeholder="translations.histories.view_placeholder_add_history" class="input" v-model="storeHistories.history">
81
- </div>
82
- <div class="column is-6">
83
- <lesli-button icon="save">{{ translations.shared.view_btn_save }}</lesli-button>
84
- </div>
85
- </div>
86
-
87
- </form>
88
- </div>
89
-
90
- <lesli-table
91
- :records="storeHistories.histories"
92
- :columns="columns"
93
- :loading="storeHistories.loading"
94
- >
95
- <template #options="{ record, value }">
96
- <a class="dropdown-item" @click="storeHistories.deleteHistory(record)">
97
- <span class="material-icons">
98
- delete
99
- </span>
100
- <span>
101
- {{translations.help.shared.view_tab_title_delete_section}}
102
- </span>
103
- </a>
104
- </template>
105
- </lesli-table>
106
-
107
- </template>
@@ -1,115 +0,0 @@
1
- <script setup>
2
- /*
3
- Copyright (c) 2022, all rights reserved.
4
-
5
- All the information provided by this platform is protected by international laws related to
6
- industrial property, intellectual property, copyright and relative international laws.
7
- All intellectual or industrial property rights of the code, texts, trade mark, design,
8
- pictures and any other information belongs to the owner of this platform.
9
-
10
- Without the written permission of the owner, any replication, modification,
11
- transmission, publication is strictly forbidden.
12
-
13
- For more information read the license file including with this software.
14
-
15
- // · ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~
16
- // ·
17
- */
18
-
19
-
20
- // · import vue tools
21
- import { onMounted } from "vue"
22
-
23
- // · import lesli stores
24
- import { useTickets } from "LesliSupport/vue/stores/tickets"
25
-
26
- // · import vue router composable
27
- import { useRoute } from "vue-router"
28
-
29
- // · implement stores
30
- const storeTickets = useTickets()
31
-
32
- // · initialize/inject plugins
33
- const route = useRoute()
34
-
35
- // ·
36
- const translations = {
37
- users: I18n.t("core.users"),
38
- shared: I18n.t("core.shared"),
39
- sla: I18n.t('help.slas')
40
- }
41
-
42
-
43
- </script>
44
- <template>
45
- <h2>SLA</h2>
46
- <div class="box" v-if="!storeTickets.loading">
47
- <div class="columns">
48
- <div class="column">
49
- <label>{{translations.sla.column_name}}</label>
50
- <p>{{storeTickets.ticket.sla?.name}}</p>
51
- </div>
52
-
53
- <div class="column">
54
- <label>{{translations.sla.column_default}}</label>
55
- <p v-if="storeTickets.ticket.sla?.default">yes</p>
56
- <p v-else> no </p>
57
- </div>
58
- </div>
59
-
60
- <div class="columns">
61
- <div class="column">
62
- <label>{{translations.sla.column_expected_response_time}}</label>
63
- <p>{{storeTickets.ticket.sla?.expected_response_time}}</p>
64
- </div>
65
-
66
- <div class="column">
67
- <label>{{translations.sla.column_expected_resolution_time}}</label>
68
- <p>{{storeTickets.ticket.sla?.expected_resolution_time}}</p>
69
- </div>
70
-
71
- <div class="column">
72
- <label>{{translations.sla.column_price_per_hour}}</label>
73
- <p> {{storeTickets.ticket.sla?.price_per_hour}}</p>
74
- </div>
75
- </div>
76
-
77
- <div class="colums">
78
- <div class="column">
79
- <label>{{translations.sla.view_tab_title_associations}}</label>
80
- <div v-for="association in storeTickets.ticket.sla?.association_attributes" :key="association.id">
81
- <span class="tag is-info">{{association.ticket_type_name}}</span>
82
- </div>
83
- </div>
84
- </div>
85
-
86
- <div class="field">
87
- <label class="label">{{translations.sla.column_body}}</label>
88
- <div class="control">
89
- <textarea class="textarea is-small" :v-model="storeTickets.ticket.sla?.body" disabled></textarea>
90
- </div>
91
- </div>
92
-
93
- <div class="field">
94
- <label class="label">{{translations.sla.column_client_repercussions}}</label>
95
- <div class="control">
96
- <textarea class="textarea is-small" :v-model="storeTickets.ticket.sla?.client_repercussions" disabled></textarea>
97
- </div>
98
- </div>
99
-
100
- <div class="field">
101
- <label class="label">{{translations.sla.column_provider_repercussions}}</label>
102
- <div class="control">
103
- <textarea class="textarea is-small" :v-model="storeTickets.ticket.sla?.provider_repercussions" disabled></textarea>
104
- </div>
105
- </div>
106
-
107
- <div class="field">
108
- <label class="label">{{translations.sla.column_exceptions}}</label>
109
- <div class="control">
110
- <textarea class="textarea is-small" :v-model="storeTickets.ticket.sla?.exceptions" disabled></textarea>
111
- </div>
112
- </div>
113
- </div>
114
-
115
- </template>