You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

74 lines
2.1 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. <script lang="ts">
  2. import type Project from "../models/project";
  3. import type { TaskResult } from "../models/task";
  4. import type { ModalData } from "../stores/modal";
  5. import ChildEntry from "./ChildEntry.svelte";
  6. import DateSpan from "./DateSpan.svelte";
  7. import ItemLink from "./ItemLink.svelte";
  8. import Markdown from "./Markdown.svelte";
  9. import Option from "./Option.svelte";
  10. import OptionRow from "./OptionRow.svelte";
  11. import StatusColor from "./StatusColor.svelte";
  12. import TaskIcon from "./TaskIcon.svelte";
  13. export let task: TaskResult = null;
  14. export let project: Project = null;
  15. export let showAllOptions: boolean = false;
  16. let showLogs = false;
  17. let mdLogAdd: ModalData;
  18. let mdTaskEdit: ModalData;
  19. let mdTaskDelete: ModalData;
  20. function toggleShowLogs() {
  21. showLogs = !showLogs;
  22. }
  23. $: mdLogAdd = {name: "log.add", task: {...task, project}};
  24. $: mdTaskEdit = {name: "task.edit", task: {...task, project}};
  25. $: mdTaskDelete = {name: "task.delete", task: {...task, project}};
  26. </script>
  27. <StatusColor affects="task" entry={task}>
  28. <ChildEntry entry={task}>
  29. <div slot="icon">
  30. <TaskIcon task={task} />
  31. </div>
  32. <ItemLink item={task.item} />
  33. <OptionRow>
  34. {#if task.logs.length > 0}
  35. <Option on:click={toggleShowLogs}>{showLogs ? "Hide Logs" : "Show Logs"}</Option>
  36. {/if}
  37. <Option open={mdLogAdd}>Add Log</Option>
  38. {#if showAllOptions}
  39. <Option open={mdTaskEdit}>Edit</Option>
  40. <Option open={mdTaskDelete}>Delete</Option>
  41. {/if}
  42. </OptionRow>
  43. {#if showLogs && task.logs.length > 0}
  44. <div class="log-list">
  45. {#each task.logs as log (log.id)}
  46. <div class="log">
  47. <div class="log-time"><DateSpan time={log.loggedTime} /></div>
  48. <div class="log-description">
  49. <Markdown source={log.description} />
  50. </div>
  51. </div>
  52. {/each}
  53. </div>
  54. {/if}
  55. </ChildEntry>
  56. </StatusColor>
  57. <style>
  58. div.log-list {
  59. padding: 0.5em 0;
  60. }
  61. div.log {
  62. padding: 0.25em 1ch;
  63. }
  64. div.log-time {
  65. font-size: 0.75em;
  66. font-weight: 800;
  67. }
  68. </style>