X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;ds=sidebyside;f=WEB-INF%2Ftemplates%2Fexpenses.tpl;h=8a3ae4c7806b7b6e4cb94b390ecb018ed77fdae7;hb=bca57fffcb2e12e5ebdb825adbf4732e9e0503cf;hp=3c42c6d9b2b85f5132c08252fdef03621b62fe71;hpb=9a23a8c0a51b7ec38a96f525484134f3cb85dc7e;p=timetracker.git
diff --git a/WEB-INF/templates/expenses.tpl b/WEB-INF/templates/expenses.tpl
index 3c42c6d9..8a3ae4c7 100644
--- a/WEB-INF/templates/expenses.tpl
+++ b/WEB-INF/templates/expenses.tpl
@@ -6,28 +6,36 @@
// project_names[325] = "Time Tracker"; // Project name.
// Prepare an array of project ids for clients.
-project_ids = new Array();
+var project_ids = new Array();
{foreach $client_list as $client}
project_ids[{$client.id}] = "{$client.projects}";
{/foreach}
// Prepare an array of project names.
-project_names = new Array();
+var project_names = new Array();
{foreach $project_list as $project}
project_names[{$project.id}] = "{$project.name|escape:'javascript'}";
{/foreach}
// We'll use this array to populate project dropdown when client is not selected.
var idx = 0;
-projects = new Array();
+var projects = new Array();
{foreach $project_list as $project}
projects[idx] = new Array("{$project.id}", "{$project.name|escape:'javascript'}");
idx++;
{/foreach}
// Mandatory top option for project dropdown.
-empty_label_project = '{$i18n.dropdown.select|escape:'javascript'}';
+var empty_label_project = "{$i18n.dropdown.select|escape:'javascript'}";
+
+// Prepare an array of predefined expenses.
+idx = 0;
+var defined_expenses = new Array();
+{foreach $predefined_expenses as $predefined_expense}
+ defined_expenses[idx] = new Array("{$predefined_expense.id}", "{$predefined_expense.name|escape:'javascript'}", "{$predefined_expense.cost}");
+ idx++;
+{/foreach}
// The fillProjectDropdown function populates the project combo box with
-// projects associated with a selected client (client id is passed here as id).
+// projects associated with a selected client (client id is passed here as id).
function fillProjectDropdown(id) {
var str_ids = project_ids[id];
var dropdown = document.getElementById("project");
@@ -42,7 +50,7 @@ function fillProjectDropdown(id) {
// Populate project dropdown.
if (!id) {
// If we are here, client is not selected.
- var len = projects.length;
+ var len = projects.length;
for (var i = 0; i < len; i++) {
dropdown.options[i+1] = new Option(projects[i][1], projects[i][0]);
if (dropdown.options[i+1].value == selected_item)
@@ -66,6 +74,42 @@ function get_date() {
var date = new Date();
return date.strftime("%Y-%m-%d");
}
+
+// The recalculateCost function recalculates cost based on the current selection
+// of predefined expense and quantity and also changes the comment accordingly.
+function recalculateCost() {
+ var quantity_control = document.getElementById("quantity");
+ // Set quantity to 1 if it is not set already.
+ if (!quantity_control.value) {
+ quantity_control.value = "1";
+ }
+
+ var comment_control = document.getElementById("item_name");
+ var cost_control = document.getElementById("cost");
+ var replaceDecimalMark = ("." != "{$user->decimal_mark}");
+
+ // Calculate cost.
+ var dropdown = document.getElementById("predefined_expense");
+ if (dropdown.selectedIndex == 0) {
+ quantity_control.value = "";
+ comment_control.value = "";
+ cost_control.value = "";
+ } else {
+ comment_control.value = defined_expenses[dropdown.selectedIndex - 1][1] + " - " + quantity_control.value;
+ var quantity = quantity_control.value;
+ if (isNaN(quantity))
+ cost_control.value = "";
+ else {
+ var expenseCost = defined_expenses[dropdown.selectedIndex - 1][2];
+ if (replaceDecimalMark)
+ expenseCost = expenseCost.replace("{$user->decimal_mark}", ".");
+ var newCost = (quantity_control.value * expenseCost).toFixed(2);
+ if (replaceDecimalMark)
+ newCost = newCost.replace(".", "{$user->decimal_mark}");
+ cost_control.value = newCost;
+ }
+ }
+}
{$forms.expensesForm.open}
@@ -79,9 +123,9 @@ function get_date() {
{$forms.expensesForm.onBehalfUser.control} |
{/if}
-{if in_array('cl', explode(',', $user->plugins))}
+{if $user->isPluginEnabled('cl')}
- {$i18n.label.client}{if in_array('cm', explode(',', $user->plugins))} (*){/if}: |
+ {$i18n.label.client}{if $user->isPluginEnabled('cm')} (*){/if}: |
{$forms.expensesForm.client.control} |
{/if}
@@ -90,14 +134,25 @@ function get_date() {
{$i18n.label.project} (*): |
{$forms.expensesForm.project.control} |
+{/if}
+{if $predefined_expenses}
+
+
+ {$i18n.label.expense}: |
+ {$forms.expensesForm.predefined_expense.control} |
+
+
+ {$i18n.label.quantity}: |
+ {$forms.expensesForm.quantity.control} |
+
{/if}
- {$i18n.label.item} (*): |
+ {$i18n.label.comment} (*): |
{$forms.expensesForm.item_name.control} |
{$i18n.label.cost} (*): |
- {$forms.expensesForm.cost.control} {$user->currency|escape:'html'} |
+ {$forms.expensesForm.cost.control} {$user->currency|escape} |
@@ -118,51 +173,40 @@ function get_date() {
- {if $expense_items}
+{if $expense_items}
-{if in_array('cl', explode(',', $user->plugins))}
+ {if $user->isPluginEnabled('cl')}
-{/if}
-{if ($smarty.const.MODE_PROJECTS == $user->tracking_mode || $smarty.const.MODE_PROJECTS_AND_TASKS == $user->tracking_mode)}
+ {/if}
+ {if ($smarty.const.MODE_PROJECTS == $user->tracking_mode || $smarty.const.MODE_PROJECTS_AND_TASKS == $user->tracking_mode)}
-{/if}
+ {/if}
- {foreach $expense_items as $item}
-
-{if in_array('cl', explode(',', $user->plugins))}
- {$item.client|escape:'html'} |
-{/if}
-{if ($smarty.const.MODE_PROJECTS == $user->tracking_mode || $smarty.const.MODE_PROJECTS_AND_TASKS == $user->tracking_mode)}
- {$item.project|escape:'html'} |
-{/if}
- {$item.item|escape:'html'} |
- {$item.cost} |
-
- {if $item.invoice_id}
-
- {else}
- {$i18n.label.edit}
- {/if}
- |
-
- {/foreach}
-
- {if $expense_items}
-
-
- {$i18n.label.day_total}: {$user->currency|escape:'html'} {$day_total} |
-
-
- {/if}
-
+ {foreach $expense_items as $item}
+ |
+ {if $user->isPluginEnabled('cl')}
+ {$item.client|escape} |
+ {/if}
+ {if ($smarty.const.MODE_PROJECTS == $user->tracking_mode || $smarty.const.MODE_PROJECTS_AND_TASKS == $user->tracking_mode)}
+ {$item.project|escape} |
{/if}
+ {$item.item|escape} |
+ {$item.cost} |
+ {if $item.invoice_id} {else}{$i18n.label.edit}{/if} |
+
+ {/foreach}
+
+
+
+ {$i18n.label.day_total}: {$user->currency|escape} {$day_total} |
+
+
+{/if}
{$forms.expensesForm.close}
-
-