Work in progress on templates plugin.
authorNik Okuntseff <support@anuko.com>
Fri, 8 Mar 2019 15:13:42 +0000 (15:13 +0000)
committerNik Okuntseff <support@anuko.com>
Fri, 8 Mar 2019 15:13:42 +0000 (15:13 +0000)
18 files changed:
WEB-INF/resources/ca.lang.php
WEB-INF/resources/cs.lang.php
WEB-INF/resources/da.lang.php
WEB-INF/resources/de.lang.php
WEB-INF/resources/en.lang.php
WEB-INF/resources/es.lang.php
WEB-INF/resources/et.lang.php
WEB-INF/resources/fa.lang.php
WEB-INF/resources/fi.lang.php
WEB-INF/resources/fr.lang.php
WEB-INF/resources/gr.lang.php
WEB-INF/resources/he.lang.php
WEB-INF/resources/hu.lang.php
WEB-INF/resources/it.lang.php
WEB-INF/templates/footer.tpl
WEB-INF/templates/template_add.tpl [new file with mode: 0644]
WEB-INF/templates/templates.tpl
template_add.php [new file with mode: 0644]

index 04de03b..07d4e81 100644 (file)
@@ -367,6 +367,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index a9389a3..27494ae 100644 (file)
@@ -378,6 +378,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 981982c..f4fd9c5 100644 (file)
@@ -345,6 +345,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index dbace50..dcd666a 100644 (file)
@@ -328,6 +328,9 @@ $i18n_key_words = array(
 'title.work_units' => 'Arbeitseinheiten',
 // TODO: translate the following.
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 660e844..7fb968f 100644 (file)
@@ -319,6 +319,9 @@ $i18n_key_words = array(
 'title.swap_roles' => 'Swapping Roles',
 'title.work_units' => 'Work Units',
 'title.templates' => 'Templates',
+'title.add_template' => 'Adding Template',
+'title.edit_template' => 'Editing Template',
+'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 6b331fe..b31ec28 100644 (file)
@@ -366,6 +366,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 7228446..c4c4ceb 100644 (file)
@@ -349,6 +349,9 @@ $i18n_key_words = array(
 'title.work_units' => 'Töö ühikud',
 // TODO: translate the following.
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 27fcf68..6632b7e 100644 (file)
@@ -353,6 +353,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index f8892dd..68d167f 100644 (file)
@@ -345,6 +345,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 791e7bc..807006f 100644 (file)
@@ -339,6 +339,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 8020144..d5dde29 100644 (file)
@@ -335,6 +335,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 568b78b..bd4f06b 100644 (file)
@@ -365,6 +365,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 98e9d5f..c35fb70 100644 (file)
@@ -366,6 +366,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 1a15690..bb28e97 100644 (file)
@@ -345,6 +345,9 @@ $i18n_key_words = array(
 // 'title.swap_roles' => 'Swapping Roles',
 // 'title.work_units' => 'Work Units',
 // 'title.templates' => 'Templates',
+// 'title.add_template' => 'Adding Template',
+// 'title.edit_template' => 'Editing Template',
+// 'title.delete_template' => 'Deleting Template',
 
 // Section for common strings inside combo boxes on forms. Strings shared between forms shall be placed here.
 // Strings that are used in a single form must go to the specific form section.
index 180c767..72f5079 100644 (file)
@@ -12,7 +12,7 @@
       <br>
       <table cellspacing="0" cellpadding="4" width="100%" border="0">
         <tr>
-          <td align="center">&nbsp;Anuko Time Tracker 1.18.55.4839 | Copyright &copy; <a href="https://www.anuko.com/lp/tt_3.htm" target="_blank">Anuko</a> |
+          <td align="center">&nbsp;Anuko Time Tracker 1.18.55.4840 | Copyright &copy; <a href="https://www.anuko.com/lp/tt_3.htm" target="_blank">Anuko</a> |
             <a href="https://www.anuko.com/lp/tt_4.htm" target="_blank">{$i18n.footer.credits}</a> |
             <a href="https://www.anuko.com/lp/tt_5.htm" target="_blank">{$i18n.footer.license}</a> |
             <a href="https://www.anuko.com/lp/tt_7.htm" target="_blank">{$i18n.footer.improve}</a>
diff --git a/WEB-INF/templates/template_add.tpl b/WEB-INF/templates/template_add.tpl
new file mode 100644 (file)
index 0000000..fd2983a
--- /dev/null
@@ -0,0 +1,26 @@
+{$forms.predefinedExpenseForm.open}
+<table cellspacing="4" cellpadding="7" border="0">
+  <tr>
+    <td>
+      <table cellspacing="1" cellpadding="2" border="0">
+        <tr>
+          <td align="right">{$i18n.label.thing_name} (*):</td>
+          <td>{$forms.predefinedExpenseForm.name.control}</td>
+        </tr>
+        <tr>
+          <td align="right">{$i18n.label.cost} (*):</td>
+          <td>{$forms.predefinedExpenseForm.cost.control} {$user->getCurrency()|escape}</td>
+        </tr>
+        <tr>
+          <td height="40"></td>
+          <td>{$i18n.label.required_fields}</td>
+        </tr>
+        <tr><td>&nbsp;</td></tr>
+        <tr>
+          <td colspan="2" align="center" height="50">{$forms.predefinedExpenseForm.btn_add.control}</td>
+        </tr>
+      </table>
+    </td>
+  </tr>
+</table>
+{$forms.predefinedExpenseForm.close}
index a1ea349..177f32c 100644 (file)
@@ -5,13 +5,15 @@
       <table cellspacing="1" cellpadding="3" border="0" width="100%">
         <tr>
           <td class="tableHeader">{$i18n.label.thing_name}</td>
+          <td class="tableHeader">{$i18n.label.description}</td>
           <td class="tableHeader">{$i18n.label.edit}</td>
           <td class="tableHeader">{$i18n.label.delete}</td>
         </tr>
   {if $templates}
     {foreach $templates as $template}
         <tr bgcolor="{cycle values="#f5f5f5,#ffffff"}">
-          <td>{$template_expense['name']|escape}</td>
+          <td>{$template['name']|escape}</td>
+          <td>{$template['description']|escape}</td>
           <td><a href="template_edit.php?id={$template['id']}">{$i18n.label.edit}</a></td>
           <td><a href="template_delete.php?id={$template['id']}">{$i18n.label.delete}</a></td>
         </tr>
diff --git a/template_add.php b/template_add.php
new file mode 100644 (file)
index 0000000..606ea9f
--- /dev/null
@@ -0,0 +1,72 @@
+<?php
+// +----------------------------------------------------------------------+
+// | Anuko Time Tracker
+// +----------------------------------------------------------------------+
+// | Copyright (c) Anuko International Ltd. (https://www.anuko.com)
+// +----------------------------------------------------------------------+
+// | LIBERAL FREEWARE LICENSE: This source code document may be used
+// | by anyone for any purpose, and freely redistributed alone or in
+// | combination with other software, provided that the license is obeyed.
+// |
+// | There are only two ways to violate the license:
+// |
+// | 1. To redistribute this code in source form, with the copyright
+// |    notice or license removed or altered. (Distributing in compiled
+// |    forms without embedded copyright notices is permitted).
+// |
+// | 2. To redistribute modified versions of this code in *any* form
+// |    that bears insufficient indications that the modifications are
+// |    not the work of the original author(s).
+// |
+// | This license applies to this document only, not any other software
+// | that it may be combined with.
+// |
+// +----------------------------------------------------------------------+
+// | Contributors:
+// | https://www.anuko.com/time_tracker/credits.htm
+// +----------------------------------------------------------------------+
+
+require_once('initialize.php');
+import('form.Form');
+// import('ttTemplateHelper');
+
+// Access checks.
+if (!ttAccessAllowed('manage_advanced_settings')) {
+  header('Location: access_denied.php');
+  exit();
+}
+if (!$user->isPluginEnabled('tp')) {
+  header('Location: feature_disabled.php');
+  exit();
+}
+// End of access checks.
+
+if ($request->isPost()) {
+  $cl_name = trim($request->getParameter('name'));
+  $cl_cost = trim($request->getParameter('cost'));
+}
+
+$form = new Form('predefinedExpenseForm');
+$form->addInput(array('type'=>'text','maxlength'=>'100','name'=>'name','style'=>'width: 250px;','value'=>$cl_name));
+$form->addInput(array('type'=>'text','maxlength'=>'40','name'=>'cost','style'=>'width: 100px;','value'=>$cl_cost));
+$form->addInput(array('type'=>'submit','name'=>'btn_add','value'=>$i18n->get('button.add')));
+
+if ($request->isPost()) {
+  // Validate user input.
+  if (!ttValidString($cl_name)) $err->add($i18n->get('error.field'), $i18n->get('label.thing_name'));
+  if (!ttValidFloat($cl_cost)) $err->add($i18n->get('error.field'), $i18n->get('label.cost'));
+  if ($err->no()) {
+    if (ttPredefinedExpenseHelper::insert(array(
+        'name' => $cl_name,
+        'cost' => $cl_cost))) {
+        header('Location: predefined_expenses.php');
+        exit();
+      } else
+        $err->add($i18n->get('error.db'));
+  }
+} // isPost
+
+$smarty->assign('forms', array($form->getName()=>$form->toArray()));
+$smarty->assign('title', $i18n->get('title.add_template'));
+$smarty->assign('content_page_name', 'predefined_expense_add.tpl');
+$smarty->display('index.tpl');