Commit beb4df53 authored by Phil Hughes's avatar Phil Hughes

Merge branch 'ee-update-todo-in-ui' into 'master'

EE:  Change "Todo" to "To Do" in UI

See merge request gitlab-org/gitlab-ee!14548
parents 16b8a14c 80efba3e
...@@ -82,7 +82,7 @@ export default class Todos { ...@@ -82,7 +82,7 @@ export default class Todos {
}) })
.catch(() => { .catch(() => {
this.updateRowState(target, true); this.updateRowState(target, true);
return flash(__('Error updating todo status.')); return flash(__('Error updating status of to-do item.'));
}); });
} }
...@@ -124,7 +124,7 @@ export default class Todos { ...@@ -124,7 +124,7 @@ export default class Todos {
this.updateAllState(target, data); this.updateAllState(target, data);
this.updateBadges(data); this.updateBadges(data);
}) })
.catch(() => flash(__('Error updating status for all todos.'))); .catch(() => flash(__('Error updating status for all to-do items.')));
} }
updateAllState(target, data) { updateAllState(target, data) {
......
...@@ -5,8 +5,8 @@ import { GlLoadingIcon } from '@gitlab/ui'; ...@@ -5,8 +5,8 @@ import { GlLoadingIcon } from '@gitlab/ui';
import Icon from '~/vue_shared/components/icon.vue'; import Icon from '~/vue_shared/components/icon.vue';
const MARK_TEXT = __('Mark todo as done'); const MARK_TEXT = __('Mark as done');
const TODO_TEXT = __('Add todo'); const TODO_TEXT = __('Add a To Do');
export default { export default {
directives: { directives: {
......
...@@ -22,7 +22,7 @@ class Dashboard::TodosController < Dashboard::ApplicationController ...@@ -22,7 +22,7 @@ class Dashboard::TodosController < Dashboard::ApplicationController
format.html do format.html do
redirect_to dashboard_todos_path, redirect_to dashboard_todos_path,
status: 302, status: 302,
notice: _('Todo was successfully marked as done.') notice: _('To-do item successfully marked as done.')
end end
format.js { head :ok } format.js { head :ok }
format.json { render json: todos_counts } format.json { render json: todos_counts }
...@@ -33,7 +33,7 @@ class Dashboard::TodosController < Dashboard::ApplicationController ...@@ -33,7 +33,7 @@ class Dashboard::TodosController < Dashboard::ApplicationController
updated_ids = TodoService.new.mark_todos_as_done(@todos, current_user) updated_ids = TodoService.new.mark_todos_as_done(@todos, current_user)
respond_to do |format| respond_to do |format|
format.html { redirect_to dashboard_todos_path, status: 302, notice: _('All todos were marked as done.') } format.html { redirect_to dashboard_todos_path, status: 302, notice: _('Everything on your to-do list is marked as done.') }
format.js { head :ok } format.js { head :ok }
format.json { render json: todos_counts.merge(updated_ids: updated_ids) } format.json { render json: todos_counts.merge(updated_ids: updated_ids) }
end end
......
...@@ -390,8 +390,8 @@ module IssuablesHelper ...@@ -390,8 +390,8 @@ module IssuablesHelper
def issuable_todo_button_data(issuable, is_collapsed) def issuable_todo_button_data(issuable, is_collapsed)
{ {
todo_text: _('Add todo'), todo_text: _('Add a To Do'),
mark_text: _('Mark todo as done'), mark_text: _('Mark as done'),
todo_icon: sprite_icon('todo-add'), todo_icon: sprite_icon('todo-add'),
mark_icon: sprite_icon('todo-done', css_class: 'todo-undone'), mark_icon: sprite_icon('todo-done', css_class: 'todo-undone'),
issuable_id: issuable[:id], issuable_id: issuable[:id],
......
...@@ -16,7 +16,7 @@ module PreferencesHelper ...@@ -16,7 +16,7 @@ module PreferencesHelper
project_activity: _("Your Projects' Activity"), project_activity: _("Your Projects' Activity"),
starred_project_activity: _("Starred Projects' Activity"), starred_project_activity: _("Starred Projects' Activity"),
groups: _("Your Groups"), groups: _("Your Groups"),
todos: _("Your Todos"), todos: _("Your To-Do List"),
issues: _("Assigned Issues"), issues: _("Assigned Issues"),
merge_requests: _("Assigned Merge Requests"), merge_requests: _("Assigned Merge Requests"),
operations: _("Operations Dashboard") operations: _("Operations Dashboard")
......
...@@ -49,5 +49,5 @@ ...@@ -49,5 +49,5 @@
- else - else
.todo-actions .todo-actions
= link_to restore_dashboard_todo_path(todo), method: :patch, class: 'btn btn-loading js-add-todo', data: { href: restore_dashboard_todo_path(todo) } do = link_to restore_dashboard_todo_path(todo), method: :patch, class: 'btn btn-loading js-add-todo', data: { href: restore_dashboard_todo_path(todo) } do
Add todo Add a To Do
= icon('spinner spin') = icon('spinner spin')
- @hide_top_links = true - @hide_top_links = true
- page_title "Todos" - page_title "To-Do List"
- header_title "Todos", dashboard_todos_path - header_title "To-Do List", dashboard_todos_path
= render_dashboard_gold_trial(current_user) = render_dashboard_gold_trial(current_user)
.page-title-holder.d-flex.align-items-center .page-title-holder.d-flex.align-items-center
%h1.page-title= _('Todos') %h1.page-title= _('To-Do List')
- if current_user.todos.any? - if current_user.todos.any?
.top-area .top-area
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
%li.todos-pending{ class: active_when(params[:state].blank? || params[:state] == 'pending') }> %li.todos-pending{ class: active_when(params[:state].blank? || params[:state] == 'pending') }>
= link_to todos_filter_path(state: 'pending') do = link_to todos_filter_path(state: 'pending') do
%span %span
Todos To Do
%span.badge.badge-pill %span.badge.badge-pill
= number_with_delimiter(todos_pending_count) = number_with_delimiter(todos_pending_count)
%li.todos-done{ class: active_when(params[:state] == 'done') }> %li.todos-done{ class: active_when(params[:state] == 'done') }>
...@@ -102,24 +102,24 @@ ...@@ -102,24 +102,24 @@
%p %p
Are you looking for things to do? Take a look at Are you looking for things to do? Take a look at
= succeed "," do = succeed "," do
= link_to "the opened issues", issues_dashboard_path = link_to "open issues", issues_dashboard_path
contribute to contribute to
= link_to "merge requests", merge_requests_dashboard_path = link_to "a merge request\,", merge_requests_dashboard_path
or mention someone in a comment to assign a new todo automatically. or mention someone in a comment to automatically assign them a new to-do item.
- else - else
%h4.text-center %h4.text-center
There are no todos to show. Nothing is on your to-do list. Nice work!
- else - else
.todos-empty .todos-empty
.todos-empty-hero.svg-content .todos-empty-hero.svg-content
= image_tag 'illustrations/todos_empty.svg' = image_tag 'illustrations/todos_empty.svg'
.todos-empty-content .todos-empty-content
%h4 %h4
Todos let you see what you should do next Your To-Do List shows what to work on next
%p %p
When an issue or merge request is assigned to you, or when you When an issue or merge request is assigned to you, or when you receive a
%strong %strong
@mention @mention
in a comment, this will trigger a new item in your todo list, automatically. in a comment, this automatically triggers a new item in your To-Do List.
%p %p
You will always know what to work on next. It's how you always know what to work on next.
...@@ -53,7 +53,7 @@ ...@@ -53,7 +53,7 @@
= number_with_delimiter(merge_requests_count) = number_with_delimiter(merge_requests_count)
- if header_link?(:todos) - if header_link?(:todos)
= nav_link(controller: 'dashboard/todos', html_options: { class: "user-counter" }) do = nav_link(controller: 'dashboard/todos', html_options: { class: "user-counter" }) do
= link_to dashboard_todos_path, title: _('Todos'), aria: { label: _('Todos') }, class: 'shortcuts-todos', data: {toggle: 'tooltip', placement: 'bottom', container: 'body'} do = link_to dashboard_todos_path, title: _('To-Do List'), aria: { label: _('To-Do List') }, class: 'shortcuts-todos', data: {toggle: 'tooltip', placement: 'bottom', container: 'body'} do
= sprite_icon('todo-done', size: 16) = sprite_icon('todo-done', size: 16)
%span.badge.badge-pill.todos-count{ class: ('hidden' if todos_pending_count.zero?) } %span.badge.badge-pill.todos-count{ class: ('hidden' if todos_pending_count.zero?) }
= todos_count_format(todos_pending_count) = todos_count_format(todos_pending_count)
......
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
.block.issuable-sidebar-header .block.issuable-sidebar-header
- if signed_in - if signed_in
%span.issuable-header-text.hide-collapsed.float-left %span.issuable-header-text.hide-collapsed.float-left
= _('Todo') = _('To Do')
%a.gutter-toggle.float-right.js-sidebar-toggle.has-tooltip{ role: "button", href: "#", "aria-label" => "Toggle sidebar", title: sidebar_gutter_tooltip_text, data: { container: 'body', placement: 'left', boundary: 'viewport' } } %a.gutter-toggle.float-right.js-sidebar-toggle.has-tooltip{ role: "button", href: "#", "aria-label" => "Toggle sidebar", title: sidebar_gutter_tooltip_text, data: { container: 'body', placement: 'left', boundary: 'viewport' } }
= sidebar_gutter_toggle_icon = sidebar_gutter_toggle_icon
- if signed_in - if signed_in
......
---
title: Changes "Todo" to "To Do" in the UI for clarity
merge_request: 28844
author:
type: other
...@@ -4,8 +4,8 @@ ...@@ -4,8 +4,8 @@
# If you come up with a fun one, please feel free to contribute it to GitLab! # If you come up with a fun one, please feel free to contribute it to GitLab!
# https://about.gitlab.com/contributing/ # https://about.gitlab.com/contributing/
--- ---
- Good job! Looks like you don't have any todos left - Good job! Looks like you don't have anything left on your To-Do List
- Isn't an empty todo list beautiful? - Isn't an empty To-Do List beautiful?
- Give yourself a pat on the back! - Give yourself a pat on the back!
- Nothing left to do, high five! - Nothing left to do. High five!
- Henceforth you shall be known as "Todo Destroyer" - Henceforth, you shall be known as "To-Do Destroyer"
...@@ -39,11 +39,14 @@ after it is closed. ...@@ -39,11 +39,14 @@ after it is closed.
![Report Abuse](img/report-abuse.png) ![Report Abuse](img/report-abuse.png)
#### 2. Todos #### 2. To Do
You can click **add todo** to add the issue to your [GitLab Todo](../../../workflow/todos.md) You can add issues to and remove issues from your [GitLab To-Do List](../../../workflow/todos.md).
list. If it is already on your todo list, the buttom will show **mark todo as done**,
which you can click to mark that issue as done (which will be reflected in the Todo list). The button to do this has a different label depending on whether the issue is already on your To-Do List or not. If the issue is:
- Already on your To-Do List: The button is labeled **Mark as done**. Click the button to remove the issue from your To-Do List.
- Not on your To-Do List: The button is labelled **Add a To Do**. Click the button to add the issue to your To-Do List.
#### 3. Assignee #### 3. Assignee
...@@ -206,6 +209,14 @@ You can filter what is displayed in the issue history by clicking on **Show all ...@@ -206,6 +209,14 @@ You can filter what is displayed in the issue history by clicking on **Show all
and selecting either **Show comments only**, which only shows discussions and hides and selecting either **Show comments only**, which only shows discussions and hides
updates to the issue, or **Show history only**, which hides discussions and only shows updates. updates to the issue, or **Show history only**, which hides discussions and only shows updates.
- You can mention a user or a group present in your GitLab instance with
`@username` or `@groupname` and they will be notified via To-Do items
and email, unless they have [disabled all notifications](#13-notifications)
in their profile settings.
- Mentions for yourself (the current logged in user), will be highlighted
in a different color, allowing you to easily see which comments involve you,
helping you focus on them quickly.
![Show all activity](img/show-all-activity.png) ![Show all activity](img/show-all-activity.png)
#### 22. Create Merge Request #### 22. Create Merge Request
......
...@@ -16,8 +16,8 @@ discussions, and descriptions: ...@@ -16,8 +16,8 @@ discussions, and descriptions:
|:---------------------------|:------------------------------ |:------|:--------------| |:---------------------------|:------------------------------ |:------|:--------------|
| `/tableflip <Comment>` | Append the comment with `(╯°□°)╯︵ ┻━┻` | ✓ | ✓ | | `/tableflip <Comment>` | Append the comment with `(╯°□°)╯︵ ┻━┻` | ✓ | ✓ |
| `/shrug <Comment>` | Append the comment with `¯\_(ツ)_/¯` | ✓ | ✓ | | `/shrug <Comment>` | Append the comment with `¯\_(ツ)_/¯` | ✓ | ✓ |
| `/todo` | Add a todo | ✓ | ✓ | | `/todo` | Add a To Do | ✓ | ✓ |
| `/done` | Mark todo as done | ✓ | ✓ | | `/done` | Mark To Do as done | ✓ | ✓ |
| `/subscribe` | Subscribe | ✓ | ✓ | | `/subscribe` | Subscribe | ✓ | ✓ |
| `/unsubscribe` | Unsubscribe | ✓ | ✓ | | `/unsubscribe` | Unsubscribe | ✓ | ✓ |
| `/close` | Close | ✓ | ✓ | | `/close` | Close | ✓ | ✓ |
...@@ -75,8 +75,8 @@ The following quick actions are applicable for epics threads and description: ...@@ -75,8 +75,8 @@ The following quick actions are applicable for epics threads and description:
|:---------------------------|:----------------------------------------| |:---------------------------|:----------------------------------------|
| `/tableflip <Comment>` | Append the comment with `(╯°□°)╯︵ ┻━┻` | | `/tableflip <Comment>` | Append the comment with `(╯°□°)╯︵ ┻━┻` |
| `/shrug <Comment>` | Append the comment with `¯\_(ツ)_/¯` | | `/shrug <Comment>` | Append the comment with `¯\_(ツ)_/¯` |
| `/todo` | Add a todo | | `/todo` | Add a To Do |
| `/done` | Mark todo as done | | `/done` | Mark To Do as done |
| `/subscribe` | Subscribe | | `/subscribe` | Subscribe |
| `/unsubscribe` | Unsubscribe | | `/unsubscribe` | Unsubscribe |
| `/close` | Close | | `/close` | Close |
......
...@@ -97,10 +97,10 @@ quickly access issues and merge requests created or assigned to you within that ...@@ -97,10 +97,10 @@ quickly access issues and merge requests created or assigned to you within that
![search per project - shortcut](img/project_search.png) ![search per project - shortcut](img/project_search.png)
## Todos ## To-Do List
Your [todos](../../workflow/todos.md#gitlab-todos) can be searched by "to do" and "done". Your [To-Do List](../../workflow/todos.md#gitlab-to-do-list) can be searched by "to do" and "done".
You can [filter](../../workflow/todos.md#filtering-your-todos) them per project, You can [filter](../../workflow/todos.md#filtering-your-to-do-list) them per project,
author, type, and action. Also, you can sort them by author, type, and action. Also, you can sort them by
[**Label priority**](../../user/project/labels.md#label-priority), [**Label priority**](../../user/project/labels.md#label-priority),
**Last created** and **Oldest created**. **Last created** and **Oldest created**.
......
# GitLab Todos # GitLab To-Do List
> [Introduced][ce-2817] in GitLab 8.5. > [Introduced][ce-2817] in GitLab 8.5.
When you log into GitLab, you normally want to see where you should spend your When you log into GitLab, you normally want to see where you should spend your
time and take some action, or what you need to keep an eye on. All without the time, take some action, or know what you need to keep an eye on without
mess of a huge pile of e-mail notifications. GitLab is where you do your work, a huge pile of e-mail notifications. GitLab is where you do your work,
so being able to get started quickly is very important. so being able to get started quickly is important.
Todos is a chronological list of to-dos that are waiting for your input, all Your To-Do List offers a chronological list of items that are waiting for your input, all
in a simple dashboard. in a simple dashboard.
![Todos screenshot showing a list of items to check on](img/todos_index.png) ![To Do screenshot showing a list of items to check on](img/todos_index.png)
--- ---
You can quickly access the Todos dashboard using the checkmark icon next to the You can quickly access your To-Do List by clicking the checkmark icon next to the
search bar in the upper right corner. The number in blue is the number of Todos search bar in the top navigation. If the count is:
you still have open if the count is < 100, else it's 99+. The exact number
will still be shown in the body of the _To do_ tab.
![Todos icon](img/todos_icon.png) - Less than 100, the number in blue is the number of To-Do items.
- 100 or more, the number displays as 99+. The exact number displays
on the To-Do List.
you still have open. Otherwise, the number displays as 99+. The exact number
displays on the To-Do List.
## What triggers a Todo ![To Do icon](img/todos_icon.png)
A Todo appears in your Todos dashboard when: ## What triggers a To Do
- an issue or merge request is assigned to you A To Do displays on your To-Do List when:
- you are `@mentioned` in the description or in a comment of an issue, merge request, or epic **[ULTIMATE]**
- you are `@mentioned` in a comment on a commit,
- a job in the CI pipeline running for your merge request failed, but this
job is not allowed to fail.
- an open merge request becomes unmergeable due to conflict, and you are either:
- the author, or
- have set it to automatically merge once pipeline succeeds.
Todo triggers are not affected by [GitLab Notification Email settings](notifications.md). - An issue or merge request is assigned to you
- You are `@mentioned` in the description or comment of an:
- Issue
- Merge Request
- Epic **[ULTIMATE]**
- You are `@mentioned` in a comment on a commit
- A job in the CI pipeline running for your merge request failed, but this
job is not allowed to fail
- An open merge request becomes unmergeable due to conflict, and you are either:
- The author
- Have set it to automatically merge once the pipeline succeeds
To-do triggers are not affected by [GitLab Notification Email settings](notifications.md).
NOTE: **Note:** NOTE: **Note:**
When an user no longer has access to a resource related to a Todo like an issue, merge request, project or group the related Todos, for security reasons, gets deleted within the next hour. The delete is delayed to prevent data loss in case user got their access revoked by mistake. When a user no longer has access to a resource related to a To Do (like an issue, merge request, project, or group) the related To-Do items are deleted within the next hour for security reasons. The delete is delayed to prevent data loss, in case the user's access was revoked by mistake.
### Directly addressed Todos ### Directly addressing a To Do
> [Introduced][ce-7926] in GitLab 9.0. > [Introduced][ce-7926] in GitLab 9.0.
If you are mentioned at the start of a line, the todo you receive will be listed If you are mentioned at the start of a line, the To Do you receive will be listed
as 'directly addressed'. For instance, in this comment: as 'directly addressed'. For example, in this comment:
```markdown ```markdown
@alice What do you think? cc: @bob @alice What do you think? cc: @bob
...@@ -58,67 +65,80 @@ as 'directly addressed'. For instance, in this comment: ...@@ -58,67 +65,80 @@ as 'directly addressed'. For instance, in this comment:
@erin @frank thank you! @erin @frank thank you!
``` ```
The people receiving directly addressed todos are `@alice`, `@erin`, and The people receiving directly addressed To-Do items are `@alice`, `@erin`, and
`@frank`. Directly addressed todos only differ from mention todos in their type, `@frank`. Directly addressed To-Do items only differ from mentions in their type
for filtering; otherwise, they appear as normal. for filtering purposes; otherwise, they appear as normal.
### Manually creating a To Do
You can also add the following to your To-Do List by clicking the **Add a To Do** button on an:
### Manually creating a Todo - Issue
- Merge Request
- Epic **[ULTIMATE]**
You can also add an issue, merge request or epic to your Todos dashboard by clicking ![Adding a To Do from the issuable sidebar](img/todos_add_todo_sidebar.png)
the "Add todo" button in the sidebar of the issue, merge request, or epic **[ULTIMATE]**.
![Adding a Todo from the issuable sidebar](img/todos_add_todo_sidebar.png) ## Marking a To Do as done
## Marking a Todo as done Any action to the following will mark the corresponding To Do as done:
Any action to the corresponding issue, merge request or epic **[ULTIMATE]** will mark your Todo as - Issue
**Done**. Actions that dismiss Todos include: - Merge Request
- Epic **[ULTIMATE]**
- changing the assignee Actions that dismiss To-Do items include:
- changing the milestone
- adding/removing a label - Changing the assignee
- commenting on the issue - Changing the milestone
- Adding/removing a label
- Commenting on the issue
--- ---
Todos are personal, and they're only marked as done if the action is coming from Your To-Do List is personal, and items are only marked as done if the action comes from
you. If you close the issue or merge request, your Todo will automatically you. If you close the issue or merge request, your To Do is automatically
be marked as done. marked as done.
To prevent other users from closing issues without you being notified, if someone else closes, merges, or takes action on the any of the following, your To Do will remain pending:
If someone else closes, merges, or takes action on the issue, epic or merge - Issue
request, your Todo will remain pending. This prevents other users from closing issues without you being notified. - Merge request
- Epic **[ULTIMATE]**
There is just one Todo per issue, epic or merge request, so mentioning a user a There is just one To Do for each of these, so mentioning a user a hundred times in an issue will only trigger one To Do.
hundred times in an issue will only trigger one Todo.
--- ---
If no action is needed, you can manually mark the Todo as done by clicking the If no action is needed, you can manually mark the To Do as done by clicking the
corresponding **Done** button, and it will disappear from your Todo list. corresponding **Done** button, and it will disappear from your To-Do List.
![A To Do in the To-Do List](img/todo_list_item.png)
![A Todo in the Todos dashboard](img/todo_list_item.png) You can also mark a To Do as done by clicking the **Mark as done** button in the sidebar of the following:
A Todo can also be marked as done from the issue, merge request or epic sidebar using - Issue
the "Mark todo as done" button. - Merge Request
- Epic **[ULTIMATE]**
![Mark todo as done from the issuable sidebar](img/todos_mark_done_sidebar.png) ![Mark as done from the issuable sidebar](img/todos_mark_done_sidebar.png)
You can mark all your Todos as done at once by clicking on the **Mark all as You can mark all your To-Do items as done at once by clicking the **Mark all as
done** button. done** button.
## Filtering your Todos ## Filtering your To-Do List
There are four kinds of filters you can use on your Todos dashboard. There are four kinds of filters you can use on your To-Do List.
| Filter | Description | | Filter | Description |
| ------- | ----------- | | ------- | ----------- |
| Project | Filter by project | | Project | Filter by project |
| Group | Filter by group | | Group | Filter by group |
| Author | Filter by the author that triggered the Todo | | Author | Filter by the author that triggered the To Do |
| Type | Filter by issue, merge request, or epic **[ULTIMATE]** | | Type | Filter by issue, merge request, or epic **[ULTIMATE]** |
| Action | Filter by the action that triggered the Todo | | Action | Filter by the action that triggered the To Do |
You can also filter by more than one of these at the same time. The possible Actions are `Any Action`, `Assigned`, `Mentioned`, `Added`, `Pipelines`, and `Directly Addressed`, [as described above](#what-triggers-a-todo). You can also filter by more than one of these at the same time. The possible Actions are `Any Action`, `Assigned`, `Mentioned`, `Added`, `Pipelines`, and `Directly Addressed`, [as described above](#what-triggers-a-to-do).
[ce-2817]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/2817 [ce-2817]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/2817
[ce-7926]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/7926 [ce-7926]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/7926
...@@ -24,7 +24,7 @@ export default { ...@@ -24,7 +24,7 @@ export default {
<template> <template>
<div class="block issuable-sidebar-header"> <div class="block issuable-sidebar-header">
<span class="issuable-header-text hide-collapsed float-left">{{ __('Todo') }}</span> <span class="issuable-header-text hide-collapsed float-left">{{ __('To Do') }}</span>
<toggle-sidebar <toggle-sidebar
:collapsed="sidebarCollapsed" :collapsed="sidebarCollapsed"
css-classes="float-right" css-classes="float-right"
......
...@@ -74,9 +74,9 @@ export const requestEpicTodoToggleFailure = ({ commit, state }, data) => { ...@@ -74,9 +74,9 @@ export const requestEpicTodoToggleFailure = ({ commit, state }, data) => {
commit(types.REQUEST_EPIC_TODO_TOGGLE_FAILURE, data); commit(types.REQUEST_EPIC_TODO_TOGGLE_FAILURE, data);
if (state.todoExists) { if (state.todoExists) {
flash(__('There was an error deleting the todo.')); flash(__('There was an error deleting the To Do.'));
} else { } else {
flash(__('There was an error adding a todo.')); flash(__('There was an error adding a To Do.'));
} }
}; };
export const triggerTodoToggleEvent = (_, { count }) => { export const triggerTodoToggleEvent = (_, { count }) => {
......
...@@ -14,9 +14,9 @@ describe 'Manually create a todo item from epic', :js do ...@@ -14,9 +14,9 @@ describe 'Manually create a todo item from epic', :js do
it 'creates todo when clicking button' do it 'creates todo when clicking button' do
page.within '.issuable-sidebar' do page.within '.issuable-sidebar' do
click_button 'Add todo' click_button 'Add a To Do'
expect(page).to have_content 'Mark todo as done' expect(page).to have_content 'Mark as done'
end end
page.within '.header-content .todos-count' do page.within '.header-content .todos-count' do
...@@ -26,7 +26,7 @@ describe 'Manually create a todo item from epic', :js do ...@@ -26,7 +26,7 @@ describe 'Manually create a todo item from epic', :js do
it 'marks a todo as done' do it 'marks a todo as done' do
page.within '.issuable-sidebar' do page.within '.issuable-sidebar' do
click_button 'Add todo' click_button 'Add a To Do'
end end
expect(page).to have_selector('.todos-count', visible: true) expect(page).to have_selector('.todos-count', visible: true)
...@@ -35,7 +35,7 @@ describe 'Manually create a todo item from epic', :js do ...@@ -35,7 +35,7 @@ describe 'Manually create a todo item from epic', :js do
end end
page.within '.issuable-sidebar' do page.within '.issuable-sidebar' do
click_button 'Mark todo as done' click_button 'Mark as done'
end end
expect(page).to have_selector('.todos-count', visible: false) expect(page).to have_selector('.todos-count', visible: false)
......
...@@ -38,7 +38,7 @@ describe('SidebarHeaderComponent', () => { ...@@ -38,7 +38,7 @@ describe('SidebarHeaderComponent', () => {
const todoEl = vm.$el.querySelector('.issuable-header-text.hide-collapsed.float-left'); const todoEl = vm.$el.querySelector('.issuable-header-text.hide-collapsed.float-left');
expect(todoEl).not.toBeNull(); expect(todoEl).not.toBeNull();
expect(todoEl.innerText.trim()).toBe('Todo'); expect(todoEl.innerText.trim()).toBe('To Do');
}); });
it('renders Todo toggle button element when sidebar is expanded', done => { it('renders Todo toggle button element when sidebar is expanded', done => {
......
...@@ -284,7 +284,7 @@ describe('Epic Store Actions', () => { ...@@ -284,7 +284,7 @@ describe('Epic Store Actions', () => {
); );
}); });
it('Should show flash error with message "There was an error deleting the todo." when `state.todoExists` is `true`', () => { it('Should show flash error with message "There was an error deleting the To Do." when `state.todoExists` is `true`', () => {
actions.requestEpicTodoToggleFailure( actions.requestEpicTodoToggleFailure(
{ {
commit: () => {}, commit: () => {},
...@@ -294,11 +294,11 @@ describe('Epic Store Actions', () => { ...@@ -294,11 +294,11 @@ describe('Epic Store Actions', () => {
); );
expect(document.querySelector('.flash-container .flash-text').innerText.trim()).toBe( expect(document.querySelector('.flash-container .flash-text').innerText.trim()).toBe(
'There was an error deleting the todo.', 'There was an error deleting the To Do.',
); );
}); });
it('Should show flash error with message "There was an error adding a todo." when `state.todoExists` is `false`', () => { it('Should show flash error with message "There was an error adding a To Do." when `state.todoExists` is `false`', () => {
actions.requestEpicTodoToggleFailure( actions.requestEpicTodoToggleFailure(
{ {
commit: () => {}, commit: () => {},
...@@ -308,7 +308,7 @@ describe('Epic Store Actions', () => { ...@@ -308,7 +308,7 @@ describe('Epic Store Actions', () => {
); );
expect(document.querySelector('.flash-container .flash-text').innerText.trim()).toBe( expect(document.querySelector('.flash-container .flash-text').innerText.trim()).toBe(
'There was an error adding a todo.', 'There was an error adding a To Do.',
); );
}); });
}); });
......
...@@ -146,8 +146,8 @@ module Gitlab ...@@ -146,8 +146,8 @@ module Gitlab
@updates[:todo_event] = 'add' @updates[:todo_event] = 'add'
end end
desc _('Mark todo as done') desc _('Mark to do as done')
explanation _('Marks todo as done.') explanation _('Marks to do as done.')
types Issuable types Issuable
condition do condition do
quick_action_target.persisted? && quick_action_target.persisted? &&
......
...@@ -770,6 +770,9 @@ msgstr "" ...@@ -770,6 +770,9 @@ msgstr ""
msgid "Add a Grafana button in the admin sidebar, monitoring section, to access a variety of statistics on the health and performance of GitLab." msgid "Add a Grafana button in the admin sidebar, monitoring section, to access a variety of statistics on the health and performance of GitLab."
msgstr "" msgstr ""
msgid "Add a To Do"
msgstr ""
msgid "Add a bullet list" msgid "Add a bullet list"
msgstr "" msgstr ""
...@@ -866,9 +869,6 @@ msgstr "" ...@@ -866,9 +869,6 @@ msgstr ""
msgid "Add to review" msgid "Add to review"
msgstr "" msgstr ""
msgid "Add todo"
msgstr ""
msgid "Add user(s) to the group:" msgid "Add user(s) to the group:"
msgstr "" msgstr ""
...@@ -1108,9 +1108,6 @@ msgstr "" ...@@ -1108,9 +1108,6 @@ msgstr ""
msgid "All projects" msgid "All projects"
msgstr "" msgstr ""
msgid "All todos were marked as done."
msgstr ""
msgid "All users" msgid "All users"
msgstr "" msgstr ""
...@@ -5343,10 +5340,10 @@ msgstr "" ...@@ -5343,10 +5340,10 @@ msgstr ""
msgid "Error updating %{issuableType}" msgid "Error updating %{issuableType}"
msgstr "" msgstr ""
msgid "Error updating status for all todos." msgid "Error updating status for all to-do items."
msgstr "" msgstr ""
msgid "Error updating todo status." msgid "Error updating status of to-do item."
msgstr "" msgstr ""
msgid "Error uploading file" msgid "Error uploading file"
...@@ -5445,6 +5442,9 @@ msgstr "" ...@@ -5445,6 +5442,9 @@ msgstr ""
msgid "Everyone can contribute" msgid "Everyone can contribute"
msgstr "" msgstr ""
msgid "Everything on your to-do list is marked as done."
msgstr ""
msgid "Everything you need to create a GitLab Pages site using GitBook." msgid "Everything you need to create a GitLab Pages site using GitBook."
msgstr "" msgstr ""
...@@ -8320,6 +8320,9 @@ msgstr "" ...@@ -8320,6 +8320,9 @@ msgstr ""
msgid "March" msgid "March"
msgstr "" msgstr ""
msgid "Mark as done"
msgstr ""
msgid "Mark as resolved" msgid "Mark as resolved"
msgstr "" msgstr ""
...@@ -8332,7 +8335,7 @@ msgstr "" ...@@ -8332,7 +8335,7 @@ msgstr ""
msgid "Mark this issue as related to another issue" msgid "Mark this issue as related to another issue"
msgstr "" msgstr ""
msgid "Mark todo as done" msgid "Mark to do as done"
msgstr "" msgstr ""
msgid "Markdown" msgid "Markdown"
...@@ -8350,7 +8353,7 @@ msgstr "" ...@@ -8350,7 +8353,7 @@ msgstr ""
msgid "Marks this issue as related to %{issue_ref}." msgid "Marks this issue as related to %{issue_ref}."
msgstr "" msgstr ""
msgid "Marks todo as done." msgid "Marks to do as done."
msgstr "" msgstr ""
msgid "Match not found; try refining your search query." msgid "Match not found; try refining your search query."
...@@ -13841,13 +13844,13 @@ msgstr "" ...@@ -13841,13 +13844,13 @@ msgstr ""
msgid "There was an error %{message} todo." msgid "There was an error %{message} todo."
msgstr "" msgstr ""
msgid "There was an error adding a todo." msgid "There was an error adding a To Do."
msgstr "" msgstr ""
msgid "There was an error creating the issue" msgid "There was an error creating the issue"
msgstr "" msgstr ""
msgid "There was an error deleting the todo." msgid "There was an error deleting the To Do."
msgstr "" msgstr ""
msgid "There was an error fetching configuration for charts" msgid "There was an error fetching configuration for charts"
...@@ -14490,16 +14493,13 @@ msgstr "" ...@@ -14490,16 +14493,13 @@ msgstr ""
msgid "To widen your search, change or remove filters." msgid "To widen your search, change or remove filters."
msgstr "" msgstr ""
msgid "Today" msgid "To-Do List"
msgstr "" msgstr ""
msgid "Todo" msgid "To-do item successfully marked as done."
msgstr "" msgstr ""
msgid "Todo was successfully marked as done." msgid "Today"
msgstr ""
msgid "Todos"
msgstr "" msgstr ""
msgid "Toggle Sidebar" msgid "Toggle Sidebar"
...@@ -16208,7 +16208,7 @@ msgstr "" ...@@ -16208,7 +16208,7 @@ msgstr ""
msgid "Your SSH keys (%{count})" msgid "Your SSH keys (%{count})"
msgstr "" msgstr ""
msgid "Your Todos" msgid "Your To-Do List"
msgstr "" msgstr ""
msgid "Your U2F device did not send a valid JSON response." msgid "Your U2F device did not send a valid JSON response."
......
...@@ -22,7 +22,7 @@ describe 'Dashboard shortcuts', :js do ...@@ -22,7 +22,7 @@ describe 'Dashboard shortcuts', :js do
find('body').send_keys([:shift, 'T']) find('body').send_keys([:shift, 'T'])
check_page_title('Todos') check_page_title('To-Do List')
find('body').send_keys([:shift, 'P']) find('body').send_keys([:shift, 'P'])
......
...@@ -13,7 +13,7 @@ describe 'Dashboard Todos' do ...@@ -13,7 +13,7 @@ describe 'Dashboard Todos' do
end end
it 'shows "All done" message' do it 'shows "All done" message' do
expect(page).to have_content 'Todos let you see what you should do next' expect(page).to have_content 'Your To-Do List shows what to work on next'
end end
end end
...@@ -72,7 +72,7 @@ describe 'Dashboard Todos' do ...@@ -72,7 +72,7 @@ describe 'Dashboard Todos' do
end end
it 'updates todo count' do it 'updates todo count' do
expect(page).to have_content 'Todos 0' expect(page).to have_content 'To Do 0'
expect(page).to have_content 'Done 1' expect(page).to have_content 'Done 1'
end end
...@@ -101,7 +101,7 @@ describe 'Dashboard Todos' do ...@@ -101,7 +101,7 @@ describe 'Dashboard Todos' do
end end
it 'updates todo count' do it 'updates todo count' do
expect(page).to have_content 'Todos 1' expect(page).to have_content 'To Do 1'
expect(page).to have_content 'Done 0' expect(page).to have_content 'Done 0'
end end
end end
...@@ -211,7 +211,7 @@ describe 'Dashboard Todos' do ...@@ -211,7 +211,7 @@ describe 'Dashboard Todos' do
describe 'restoring the todo' do describe 'restoring the todo' do
before do before do
within first('.todo') do within first('.todo') do
click_link 'Add todo' click_link 'Add a To Do'
end end
end end
...@@ -220,7 +220,7 @@ describe 'Dashboard Todos' do ...@@ -220,7 +220,7 @@ describe 'Dashboard Todos' do
end end
it 'updates todo count' do it 'updates todo count' do
expect(page).to have_content 'Todos 1' expect(page).to have_content 'To Do 1'
expect(page).to have_content 'Done 0' expect(page).to have_content 'Done 0'
end end
end end
...@@ -276,7 +276,7 @@ describe 'Dashboard Todos' do ...@@ -276,7 +276,7 @@ describe 'Dashboard Todos' do
end end
it 'shows "All done" message!' do it 'shows "All done" message!' do
expect(page).to have_content 'Todos 0' expect(page).to have_content 'To Do 0'
expect(page).to have_content "You're all done!" expect(page).to have_content "You're all done!"
expect(page).not_to have_selector('.gl-pagination') expect(page).not_to have_selector('.gl-pagination')
end end
...@@ -303,7 +303,7 @@ describe 'Dashboard Todos' do ...@@ -303,7 +303,7 @@ describe 'Dashboard Todos' do
it 'updates todo count' do it 'updates todo count' do
mark_all_and_undo mark_all_and_undo
expect(page).to have_content 'Todos 2' expect(page).to have_content 'To Do 2'
expect(page).to have_content 'Done 0' expect(page).to have_content 'Done 0'
end end
......
...@@ -13,8 +13,8 @@ describe 'Manually create a todo item from issue', :js do ...@@ -13,8 +13,8 @@ describe 'Manually create a todo item from issue', :js do
it 'creates todo when clicking button' do it 'creates todo when clicking button' do
page.within '.issuable-sidebar' do page.within '.issuable-sidebar' do
click_button 'Add todo' click_button 'Add a To Do'
expect(page).to have_content 'Mark todo as done' expect(page).to have_content 'Mark as done'
end end
page.within '.header-content .todos-count' do page.within '.header-content .todos-count' do
...@@ -30,8 +30,8 @@ describe 'Manually create a todo item from issue', :js do ...@@ -30,8 +30,8 @@ describe 'Manually create a todo item from issue', :js do
it 'marks a todo as done' do it 'marks a todo as done' do
page.within '.issuable-sidebar' do page.within '.issuable-sidebar' do
click_button 'Add todo' click_button 'Add a To Do'
click_button 'Mark todo as done' click_button 'Mark as done'
end end
expect(page).to have_selector('.todos-count', visible: false) expect(page).to have_selector('.todos-count', visible: false)
......
...@@ -28,7 +28,7 @@ describe PreferencesHelper do ...@@ -28,7 +28,7 @@ describe PreferencesHelper do
["Your Projects' Activity", 'project_activity'], ["Your Projects' Activity", 'project_activity'],
["Starred Projects' Activity", 'starred_project_activity'], ["Starred Projects' Activity", 'starred_project_activity'],
["Your Groups", 'groups'], ["Your Groups", 'groups'],
["Your Todos", 'todos'], ["Your To-Do List", 'todos'],
["Assigned Issues", 'issues'], ["Assigned Issues", 'issues'],
["Assigned Merge Requests", 'merge_requests'] ["Assigned Merge Requests", 'merge_requests']
] ]
......
...@@ -58,7 +58,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => { ...@@ -58,7 +58,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => {
it('sets default tooltip title', () => { it('sets default tooltip title', () => {
expect( expect(
document.querySelector('.js-issuable-todo.sidebar-collapsed-icon').getAttribute('title'), document.querySelector('.js-issuable-todo.sidebar-collapsed-icon').getAttribute('title'),
).toBe('Add todo'); ).toBe('Add a To Do');
}); });
it('toggle todo state', done => { it('toggle todo state', done => {
...@@ -85,7 +85,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => { ...@@ -85,7 +85,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => {
setTimeout(() => { setTimeout(() => {
expect( expect(
document.querySelector('.issuable-sidebar-header .js-issuable-todo').textContent.trim(), document.querySelector('.issuable-sidebar-header .js-issuable-todo').textContent.trim(),
).toBe('Mark todo as done'); ).toBe('Mark as done');
done(); done();
}); });
...@@ -99,7 +99,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => { ...@@ -99,7 +99,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => {
document document
.querySelector('.js-issuable-todo.sidebar-collapsed-icon') .querySelector('.js-issuable-todo.sidebar-collapsed-icon')
.getAttribute('data-original-title'), .getAttribute('data-original-title'),
).toBe('Mark todo as done'); ).toBe('Mark as done');
done(); done();
}); });
...@@ -124,13 +124,13 @@ describe('Issuable right sidebar collapsed todo toggle', () => { ...@@ -124,13 +124,13 @@ describe('Issuable right sidebar collapsed todo toggle', () => {
expect( expect(
document.querySelector('.issuable-sidebar-header .js-issuable-todo').textContent.trim(), document.querySelector('.issuable-sidebar-header .js-issuable-todo').textContent.trim(),
).toBe('Add todo'); ).toBe('Add a To Do');
}) })
.then(done) .then(done)
.catch(done.fail); .catch(done.fail);
}); });
it('updates aria-label to mark todo as done', done => { it('updates aria-label to Mark as done', done => {
document.querySelector('.js-issuable-todo.sidebar-collapsed-icon').click(); document.querySelector('.js-issuable-todo.sidebar-collapsed-icon').click();
setTimeout(() => { setTimeout(() => {
...@@ -138,7 +138,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => { ...@@ -138,7 +138,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => {
document document
.querySelector('.js-issuable-todo.sidebar-collapsed-icon') .querySelector('.js-issuable-todo.sidebar-collapsed-icon')
.getAttribute('aria-label'), .getAttribute('aria-label'),
).toBe('Mark todo as done'); ).toBe('Mark as done');
done(); done();
}); });
...@@ -153,7 +153,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => { ...@@ -153,7 +153,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => {
document document
.querySelector('.js-issuable-todo.sidebar-collapsed-icon') .querySelector('.js-issuable-todo.sidebar-collapsed-icon')
.getAttribute('aria-label'), .getAttribute('aria-label'),
).toBe('Mark todo as done'); ).toBe('Mark as done');
document.querySelector('.js-issuable-todo.sidebar-collapsed-icon').click(); document.querySelector('.js-issuable-todo.sidebar-collapsed-icon').click();
}) })
...@@ -163,7 +163,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => { ...@@ -163,7 +163,7 @@ describe('Issuable right sidebar collapsed todo toggle', () => {
document document
.querySelector('.js-issuable-todo.sidebar-collapsed-icon') .querySelector('.js-issuable-todo.sidebar-collapsed-icon')
.getAttribute('aria-label'), .getAttribute('aria-label'),
).toBe('Add todo'); ).toBe('Add a To Do');
}) })
.then(done) .then(done)
.catch(done.fail); .catch(done.fail);
......
...@@ -53,14 +53,14 @@ describe('SidebarTodo', () => { ...@@ -53,14 +53,14 @@ describe('SidebarTodo', () => {
describe('buttonLabel', () => { describe('buttonLabel', () => {
it('returns todo button text for marking todo as done when `isTodo` prop is `true`', () => { it('returns todo button text for marking todo as done when `isTodo` prop is `true`', () => {
expect(vm.buttonLabel).toBe('Mark todo as done'); expect(vm.buttonLabel).toBe('Mark as done');
}); });
it('returns todo button text for add todo when `isTodo` prop is `false`', done => { it('returns todo button text for add todo when `isTodo` prop is `false`', done => {
vm.isTodo = false; vm.isTodo = false;
Vue.nextTick() Vue.nextTick()
.then(() => { .then(() => {
expect(vm.buttonLabel).toBe('Add todo'); expect(vm.buttonLabel).toBe('Add a To Do');
}) })
.then(done) .then(done)
.catch(done.fail); .catch(done.fail);
...@@ -131,14 +131,14 @@ describe('SidebarTodo', () => { ...@@ -131,14 +131,14 @@ describe('SidebarTodo', () => {
}); });
it('check button label computed property', () => { it('check button label computed property', () => {
expect(vm.buttonLabel).toEqual('Mark todo as done'); expect(vm.buttonLabel).toEqual('Mark as done');
}); });
it('renders button label element when `collapsed` prop is `false`', () => { it('renders button label element when `collapsed` prop is `false`', () => {
const buttonLabelEl = vm.$el.querySelector('span.issuable-todo-inner'); const buttonLabelEl = vm.$el.querySelector('span.issuable-todo-inner');
expect(buttonLabelEl).not.toBeNull(); expect(buttonLabelEl).not.toBeNull();
expect(buttonLabelEl.innerText.trim()).toBe('Mark todo as done'); expect(buttonLabelEl.innerText.trim()).toBe('Mark as done');
}); });
it('renders button icon when `collapsed` prop is `true`', done => { it('renders button icon when `collapsed` prop is `true`', done => {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment