service_item.html 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. {% extends "layout.html" %}
  2. {% block title %}{% if service_item.name.len() > 0 %}{{service_item.name}}{%else%}Add Service/Item{% endif %}{% endblock
  3. %}
  4. {% block description %}{{service_item.description}}{% endblock %}
  5. {% block head %}
  6. <style>
  7. </style>
  8. {% endblock %}
  9. {% block content %}
  10. <div class="container">
  11. <div class="row justified">
  12. <div class="backed col-sm-12 col-md-12 col-lg-12">
  13. <h1>
  14. {% if service_item.name.len() == 0 %}Create Service / Item{%else%}Update {{service_item.service_item_type.to_string()}}: {{service_item.name}}{% endif %}
  15. </h1>
  16. {% if service_item.name.len() != 0 %}<button id="delete" class="delete_button center">🗑️ Delete</button>{% endif %}
  17. <div class="row justified">
  18. <div class="content">
  19. <form id="add_service_item_form">
  20. <a href="https://app.akaunting.com/{{organization.external_accounting_id}}/common/items/{{service_item.value}}/edit">View Item</a>
  21. <label>Service/Product</label>
  22. <select name="service_item_type">
  23. {% for svctype in ServiceItemType::iter() %}
  24. <option value='{{svctype.to_string().replace(" ", "")}}' {% if svctype==service_item.service_item_type
  25. %}selected{% endif %}>
  26. {{svctype.to_string()}}</option>
  27. {% endfor %}
  28. </select>
  29. <div>
  30. <label for="name">Name</label>
  31. <input type="text" name="name" id="name" placeholder="Name" value="{{service_item.name}}" />
  32. </div>
  33. <div>
  34. <label for="description">Description</label>
  35. <textarea name="description" id="description" placeholder="Description"
  36. value="{{service_item.description}}">{{service_item.description}}</textarea>
  37. </div>
  38. <label>Billing Type</label>
  39. <select name="service_value_type">
  40. {% for svc_value_type in ServiceValueType::iter() %}
  41. <option value='{{svc_value_type.to_string().replace(" ", "")}}' {% if
  42. svc_value_type==service_item.service_value_type %}selected{% endif %}>
  43. {{svc_value_type.to_string()}}</option>
  44. {% endfor %}
  45. </select>
  46. <div class="content">
  47. <div class="row justified">
  48. <div class="col-sm-4 col-md-4 col-lg-4">
  49. <label>Select Currency</label>
  50. <select name="currency">
  51. <option value='USD' {% if "USD" == service_item.currency %}selected{% endif %}>USD</option>
  52. <option value='CAD' {% if "CAD" == service_item.currency%}selected{% endif %}>CAD</option>
  53. <option value='EUR' {% if "UEURSD" == service_item.currency %}selected{% endif %}>EUR</option>
  54. </select>
  55. </div>
  56. <div class="col-sm-8 col-md-8 col-lg-8">
  57. <label for="value">Value</label>
  58. <input type="number" id="value" min="0" step="any" name="value" placeholder="amount"
  59. value="{{service_item.value}}" />
  60. </div>
  61. </div>
  62. </div>
  63. <div>
  64. <input type="submit" class="add_button"
  65. value="{% if service_item.name.len() == 0 %}Create service item!{%else%}Update {{service_item.service_item_type.to_string()}}{% endif %}" />
  66. </div>
  67. </form>
  68. </div>
  69. </div>
  70. </div>
  71. </div>
  72. <script>
  73. window.addEventListener('load', function () {
  74. {% if service_item.key.to_string() != "00000000-0000-0000-0000-000000000000" %}
  75. send_delete("delete", "/service_item/{{service_item.key}}", (deleted, res) => {
  76. if (deleted) {
  77. window.location.href = `/`
  78. }
  79. })
  80. {% endif %}
  81. post_form("add_service_item_form", "/service_item", data => {
  82. const key = "{{service_item.key}}"
  83. data.key = key == "" ? "00000000-0000-0000-0000-000000000000" : key
  84. data.organization_key = "{{user.organization_key}}"
  85. data.external_accounting_id = data.external_accounting_id ||"{{service_item.external_accounting_id}}"
  86. data.owner_key = "{{user.key}}"
  87. data.service_item_type = (data.service_item_type || "Service");
  88. data.name = data.name || "";
  89. data.description = data.description || "";
  90. // TODO: this should be handled server side with the enum ??????
  91. data.service_value_type = data.service_value_type == "UponCompletion" ? "Full" : data.service_value_type;
  92. data.service_value_type = (data.service_value_type || "Hourly");
  93. data.currency = data.currency || "";
  94. data.value = data.value || 50.0;
  95. try {
  96. data.value = parseFloat(data.value);
  97. if (data.value == NaN) {
  98. data.value = 0.0
  99. }
  100. } catch (err) {
  101. console.error(err);
  102. data.value = 0.00
  103. }
  104. data.value = parseInt(data.value * 100)
  105. data.expenses = data.expenses || [];
  106. data.created = data.created || 0;
  107. data.updated = data.updated || 0;
  108. return data;
  109. }, (response_text) => {
  110. const object = JSON.parse(response_text);
  111. window.location.href = `/service_item/${object.key}`
  112. });
  113. })
  114. </script>
  115. {% endblock %}