Merge branch 'main' into feature/vue3-modals-with-router-4
# Conflicts: # src/router/index.ts # src/views/tasks/TaskDetailView.vue
This commit is contained in:
		| @ -34,7 +34,7 @@ | ||||
| 			> | ||||
| 				<div class="filename">{{ a.file.name }}</div> | ||||
| 				<div class="info"> | ||||
| 					<p class="collapses"> | ||||
| 					<p class="attachment-info-meta"> | ||||
| 						<i18n-t keypath="task.attachment.createdBy"> | ||||
| 							<span v-tooltip="formatDate(a.created)"> | ||||
| 								{{ formatDateSince(a.created) }} | ||||
| @ -289,21 +289,6 @@ export default { | ||||
|             content: '·'; | ||||
|             padding: 0 .25rem; | ||||
|           } | ||||
|  | ||||
|           @media screen and (max-width: $mobile) { | ||||
|             &.collapses { | ||||
|               flex-direction: column; | ||||
|  | ||||
|               > span:not(:last-child):after, | ||||
|               > a:not(:last-child):after { | ||||
|                 display: none; | ||||
|               } | ||||
|  | ||||
|               .user .username { | ||||
|                 display: none; | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
| @ -341,6 +326,10 @@ export default { | ||||
|         height: auto; | ||||
|         text-shadow: var(--shadow-md); | ||||
|         animation: bounce 2s infinite; | ||||
| 		 | ||||
| 		@media (prefers-reduced-motion: reduce) { | ||||
|           animation: none; | ||||
| 		} | ||||
|       } | ||||
|  | ||||
|       .hint { | ||||
| @ -357,6 +346,35 @@ export default { | ||||
|   } | ||||
| } | ||||
|  | ||||
| .attachment-info-meta { | ||||
| 	display: flex; | ||||
| 	align-items: center; | ||||
| 	 | ||||
| 	:deep(.user) { | ||||
| 		display: flex !important; | ||||
| 		align-items: center; | ||||
| 		margin: 0 .5rem; | ||||
| 	} | ||||
|  | ||||
| 	@media screen and (max-width: $mobile) { | ||||
| 		flex-direction: column; | ||||
| 		align-items: flex-start; | ||||
| 		 | ||||
| 		:deep(.user) { | ||||
| 			margin: .5rem 0; | ||||
| 		} | ||||
|  | ||||
| 		> span:not(:last-child):after, | ||||
| 		> a:not(:last-child):after { | ||||
| 			display: none; | ||||
| 		} | ||||
|  | ||||
| 		.user .username { | ||||
| 			display: none; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @keyframes bounce { | ||||
|   from, | ||||
|   20%, | ||||
|  | ||||
| @ -1,6 +1,8 @@ | ||||
| <template> | ||||
| 	<td v-tooltip="+date === 0 ? '' : formatDate(date)"> | ||||
| 		{{ +date === 0 ? '-' : formatDateSince(date) }} | ||||
| 		<time :datetime="date ? formatISO(date) : null"> | ||||
| 			{{ +date === 0 ? '-' : formatDateSince(date) }} | ||||
| 		</time> | ||||
| 	</td> | ||||
| </template> | ||||
|  | ||||
|  | ||||
| @ -28,9 +28,9 @@ | ||||
| 			<span class="icon"> | ||||
| 				<icon :icon="['far', 'calendar-alt']"/> | ||||
| 			</span> | ||||
| 			<span> | ||||
| 			<time :datetime="formatISO(task.dueDate)"> | ||||
| 				{{ formatDateSince(task.dueDate) }} | ||||
| 			</span> | ||||
| 			</time> | ||||
| 		</span> | ||||
| 		<h3>{{ task.title }}</h3> | ||||
| 		<progress | ||||
| @ -73,6 +73,8 @@ import Done from '@/components/misc/Done.vue' | ||||
| import Labels from '../../../components/tasks/partials/labels' | ||||
| import ChecklistSummary from './checklist-summary' | ||||
|  | ||||
| import {colorIsDark} from '@/helpers/color/colorIsDark' | ||||
|  | ||||
| export default { | ||||
| 	name: 'kanban-card', | ||||
| 	components: { | ||||
| @ -98,6 +100,7 @@ export default { | ||||
| 		}, | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		colorIsDark, | ||||
| 		async toggleTaskDone(task) { | ||||
| 			this.loadingInternal = true | ||||
| 			try { | ||||
|  | ||||
| @ -39,14 +39,17 @@ | ||||
| 				:user="a" | ||||
| 				v-for="(a, i) in task.assignees" | ||||
| 			/> | ||||
| 			<i | ||||
| 			<time | ||||
| 				:datetime="formatISO(task.dueDate)" | ||||
| 				:class="{'overdue': task.dueDate <= new Date() && !task.done}" | ||||
| 				class="is-italic" | ||||
| 				@click.prevent.stop="showDefer = !showDefer" | ||||
| 				v-if="+new Date(task.dueDate) > 0" | ||||
| 				v-tooltip="formatDate(task.dueDate)" | ||||
| 				:aria-expanded="showDefer ? 'true' : 'false'" | ||||
| 			> | ||||
| 				- {{ $t('task.detail.due', {at: formatDateSince(task.dueDate)}) }} | ||||
| 			</i> | ||||
| 			</time> | ||||
| 			<transition name="fade"> | ||||
| 				<defer-task v-if="+new Date(task.dueDate) > 0 && showDefer" v-model="task" ref="deferDueDate"/> | ||||
| 			</transition> | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 kolaente
					kolaente