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.

53 lines
1.5 KiB

3 years ago
  1. <script lang="ts">
  2. import stuffLogClient from "../clients/stufflog";
  3. import IconSelect from "../components/IconSelect.svelte";
  4. import Modal from "../components/Modal.svelte";
  5. import { iconNames } from "../external/icons";
  6. import modalStore from "../stores/modal";
  7. import projectStore, { fpProjectStore } from "../stores/project";
  8. let endTime = "";
  9. let name = "";
  10. let description = "";
  11. let icon = iconNames[0];
  12. let error = null;
  13. function onSubmit() {
  14. stuffLogClient.createProject({
  15. active: true,
  16. endTime: ( endTime == "" ) ? null : new Date(endTime),
  17. name, description, icon,
  18. }).then(() => {
  19. projectStore.markStale();
  20. if (endTime !== "") {
  21. fpProjectStore.markStale();
  22. }
  23. modalStore.close();
  24. }).catch(err => {
  25. error = err.message ? err.message : err.toString();
  26. })
  27. error = null;
  28. }
  29. function onClose() {
  30. modalStore.close();
  31. }
  32. </script>
  33. <Modal show title="Add Project" error={error} closable on:close={onClose}>
  34. <form on:submit|preventDefault={onSubmit}>
  35. <label for="name">Name</label>
  36. <input name="name" type="text" bind:value={name} />
  37. <label for="description">Description</label>
  38. <textarea name="description" bind:value={description} />
  39. <label for="itemId">Icon</label>
  40. <IconSelect bind:value={icon} />
  41. <label for="endTime">Deadline (Optional)</label>
  42. <input name="endTime" type="datetime-local" bind:value={endTime} />
  43. <hr />
  44. <button type="submit">Add Project</button>
  45. </form>
  46. </Modal>