1
0

new.twig 4.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. {% extends "layout.twig" %}
  2. {% set errorMessages = {
  3. 'name_required': 'Sprint name is required.',
  4. 'dates_invalid': 'Start and end dates must both be valid dates (YYYY-MM-DD).',
  5. 'dates_order': 'End date must not be before start date.',
  6. 'dates_too_long': 'Date range spans more than 26 weeks.',
  7. 'reserve_invalid': 'Reserve must be a number (0–100).',
  8. 'reserve_out_of_range': 'Reserve must be between 0 and 100 percent.',
  9. 'db_error': 'Could not save. Try again.',
  10. } %}
  11. {% block content %}
  12. <section class="max-w-xl">
  13. <h1 class="text-2xl font-semibold tracking-tight">New sprint</h1>
  14. <p class="text-slate-600 mt-1 text-sm dark:text-slate-400">
  15. Worker membership, weekly availability and tasks are configured on the
  16. sprint page after creation.
  17. </p>
  18. {% if error != '' and errorMessages[error] is defined %}
  19. <div class="mt-4 rounded-md border border-red-200 bg-red-50 px-4 py-3 text-sm text-red-800 dark:bg-red-900 dark:border-red-800 dark:text-red-200">
  20. {{ errorMessages[error] }}
  21. </div>
  22. {% endif %}
  23. <form method="post" action="/sprints" hx-boost="true" hx-target="body"
  24. class="mt-6 space-y-4 rounded-lg border bg-white p-5 dark:bg-slate-800 dark:border-slate-700">
  25. <input type="hidden" name="_csrf" value="{{ csrfToken }}">
  26. <label class="block">
  27. <span class="text-sm text-slate-700 dark:text-slate-300">Name</span>
  28. <input name="name" type="text" required
  29. value="{{ form.name }}"
  30. placeholder="e.g. Sprint 12"
  31. class="mt-1 block w-full rounded-md border-slate-300 border shadow-sm px-3 py-2 focus:outline-none focus:ring-2 focus:ring-slate-400 dark:bg-slate-800 dark:border-slate-600 dark:text-slate-100 dark:focus:ring-slate-500">
  32. </label>
  33. <div class="grid grid-cols-2 gap-3">
  34. <label class="block">
  35. <span class="text-sm text-slate-700 dark:text-slate-300">Start date</span>
  36. <input name="start_date" type="date" required
  37. value="{{ form.start_date }}"
  38. class="mt-1 block w-full rounded-md border-slate-300 border shadow-sm px-3 py-2 focus:outline-none focus:ring-2 focus:ring-slate-400 dark:bg-slate-800 dark:border-slate-600 dark:text-slate-100 dark:focus:ring-slate-500">
  39. </label>
  40. <label class="block">
  41. <span class="text-sm text-slate-700 dark:text-slate-300">End date</span>
  42. <input name="end_date" type="date" required
  43. value="{{ form.end_date }}"
  44. class="mt-1 block w-full rounded-md border-slate-300 border shadow-sm px-3 py-2 focus:outline-none focus:ring-2 focus:ring-slate-400 dark:bg-slate-800 dark:border-slate-600 dark:text-slate-100 dark:focus:ring-slate-500">
  45. </label>
  46. </div>
  47. <label class="block">
  48. <span class="text-sm text-slate-700 dark:text-slate-300">Reserve (%)</span>
  49. <input name="reserve_fraction" type="number" min="0" max="100" step="1" required
  50. value="{{ form.reserve_fraction }}"
  51. class="mt-1 block w-full rounded-md border-slate-300 border shadow-sm px-3 py-2 font-mono focus:outline-none focus:ring-2 focus:ring-slate-400 dark:bg-slate-800 dark:border-slate-600 dark:text-slate-100 dark:focus:ring-slate-500">
  52. <span class="text-xs text-slate-500 dark:text-slate-400">Reduction from raw capacity. The Excel uses 20%. Week rows derive from the date range and get 5 days/week by default; edit on the sprint page.</span>
  53. </label>
  54. <div class="flex gap-3 pt-2">
  55. <button type="submit"
  56. class="rounded-md bg-slate-900 text-white px-4 py-2 text-sm font-medium hover:bg-slate-800 dark:bg-slate-700 dark:hover:bg-slate-600">
  57. Create sprint
  58. </button>
  59. <a href="/" class="inline-flex items-center rounded-md border border-slate-300 bg-white text-slate-700 px-4 py-2 text-sm hover:bg-slate-100 dark:bg-slate-800 dark:border-slate-600 dark:text-slate-200 dark:hover:bg-slate-700">
  60. Cancel
  61. </a>
  62. </div>
  63. </form>
  64. </section>
  65. {% endblock %}