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.

109 lines
2.7 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
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 Icon from "./Icon.svelte";
  8. import ItemLink from "./ItemLink.svelte";
  9. import Markdown from "./Markdown.svelte";
  10. import Option from "./Option.svelte";
  11. import OptionRow from "./OptionRow.svelte";
  12. export let task: TaskResult = null;
  13. export let project: Project = null;
  14. export let showAllOptions: boolean = false;
  15. let showLogs = false;
  16. let mdLogAdd: ModalData;
  17. let mdTaskEdit: ModalData;
  18. let mdTaskDelete: ModalData;
  19. function toggleShowLogs() {
  20. showLogs = !showLogs;
  21. }
  22. $: mdLogAdd = {name: "log.add", task: {...task, project}};
  23. $: mdTaskEdit = {name: "task.edit", task: {...task, project}};
  24. $: mdTaskDelete = {name: "task.delete", task: {...task, project}};
  25. </script>
  26. <ChildEntry entry={task}>
  27. <div slot="icon" class="icon" class:done={!task.active}>
  28. {#if !task.active}
  29. <span class="on"><Icon block name="check" /></span>
  30. <span class="off">
  31. {task.completedAmount}&nbsp;/&nbsp;{task.itemAmount}
  32. </span>
  33. {:else}
  34. {task.completedAmount}&nbsp;/&nbsp;{task.itemAmount}
  35. {/if}
  36. </div>
  37. <ItemLink item={task.item} />
  38. <OptionRow>
  39. {#if task.logs.length > 0}
  40. <Option on:click={toggleShowLogs}>{showLogs ? "Hide Logs" : "Show Logs"}</Option>
  41. {/if}
  42. <Option open={mdLogAdd}>Add Log</Option>
  43. {#if showAllOptions}
  44. <Option open={mdTaskEdit}>Edit</Option>
  45. <Option open={mdTaskDelete}>Delete</Option>
  46. {/if}
  47. </OptionRow>
  48. {#if showLogs && task.logs.length > 0}
  49. <div class="log-list">
  50. {#each task.logs as log (log.id)}
  51. <div class="log">
  52. <div class="log-time"><DateSpan time={log.loggedTime} /></div>
  53. <div class="log-description">
  54. <Markdown source={log.description} />
  55. </div>
  56. </div>
  57. {/each}
  58. </div>
  59. {/if}
  60. </ChildEntry>
  61. <style>
  62. div.icon {
  63. display: flex;
  64. flex-direction: column;
  65. font-size: 1em;
  66. padding: 0.2em .5ch;
  67. margin-right: 0.5em;
  68. background: #444;
  69. color: #CCC;
  70. }
  71. div.icon.done {
  72. padding-top: 0.285em;
  73. padding-bottom: 0.115em;
  74. background: #484;
  75. color: #78ff78;
  76. }
  77. div.icon.done span.off {
  78. display: none;
  79. }
  80. div.icon.done:hover {
  81. padding-top: 0.2em;
  82. padding-bottom: 0.2em;
  83. }
  84. div.icon.done:hover span.on {
  85. display: none;
  86. }
  87. div.icon.done:hover span.off {
  88. display: inline;
  89. }
  90. div.log-list {
  91. padding: 0.5em 0;
  92. }
  93. div.log {
  94. padding: 0.25em 1ch;
  95. }
  96. div.log-time {
  97. font-size: 0.75em;
  98. font-weight: 800;
  99. }
  100. </style>