Compare commits
33 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b2f83c51e4 | ||
|
|
585036b209 | ||
|
|
91c6867e2f | ||
|
|
912ff56260 | ||
|
|
1bd4014cb9 | ||
|
|
d226a18912 | ||
|
|
1e9e6f31a2 | ||
|
|
698c5d3daa | ||
|
|
271a39b3d4 | ||
|
|
217664e636 | ||
|
|
6e4d32933b | ||
|
|
a10fbba14a | ||
|
|
9e243073df | ||
|
|
1757421d9f | ||
|
|
37299ac1a8 | ||
|
|
f614e0ebf0 | ||
|
|
66ced28bad | ||
|
|
22a371eef9 | ||
|
|
143961cf3f | ||
|
|
aae74a8cc9 | ||
|
|
3c89cb277c | ||
|
|
48619a086c | ||
|
|
ace8020028 | ||
|
|
acf281371b | ||
|
|
39820b84e0 | ||
|
|
5656910eab | ||
|
|
0594d84ed1 | ||
|
|
fbd77cedf7 | ||
|
|
045e85f3ad | ||
|
|
f6d5202ad5 | ||
|
|
31bb455d6f | ||
|
|
301ea64832 | ||
|
|
6fd9ba20c8 |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -2,3 +2,4 @@
|
|||||||
/.buildpath
|
/.buildpath
|
||||||
/.project
|
/.project
|
||||||
/.idea
|
/.idea
|
||||||
|
build
|
||||||
|
|||||||
74
build.xml
74
build.xml
@@ -8,14 +8,15 @@
|
|||||||
<property name="env.appname" value="icehrm"/>
|
<property name="env.appname" value="icehrm"/>
|
||||||
<property name="env.Version" value="dev"/>
|
<property name="env.Version" value="dev"/>
|
||||||
<property name="installpath" value="/var/www/apps.gamonoid.com/icehrm-open-core"/>
|
<property name="installpath" value="/var/www/apps.gamonoid.com/icehrm-open-core"/>
|
||||||
|
<property name="installLocalpath" value="/Applications/XAMPP/xamppfiles/htdocs/icehrm-open-core"/>
|
||||||
|
|
||||||
|
|
||||||
<target name="build"
|
<target name="build"
|
||||||
depends="prepare,lint,phpunit,copyapp,release,install"
|
depends="prepare,lint,copyapp,release,install"
|
||||||
description=""/>
|
description=""/>
|
||||||
|
|
||||||
<target name="buildlocal"
|
<target name="buildlocal"
|
||||||
depends="prepare,copyapp"
|
depends="prepare,copyapp,installLocal"
|
||||||
description=""/>
|
description=""/>
|
||||||
|
|
||||||
<target name="clean"
|
<target name="clean"
|
||||||
@@ -37,6 +38,7 @@
|
|||||||
depends="clean"
|
depends="clean"
|
||||||
description="Prepare for build">
|
description="Prepare for build">
|
||||||
<mkdir dir="${basedir}/build/api"/>
|
<mkdir dir="${basedir}/build/api"/>
|
||||||
|
<mkdir dir="${basedir}/build/api"/>
|
||||||
<mkdir dir="${basedir}/build/coverage"/>
|
<mkdir dir="${basedir}/build/coverage"/>
|
||||||
<mkdir dir="${basedir}/build/logs"/>
|
<mkdir dir="${basedir}/build/logs"/>
|
||||||
<mkdir dir="${basedir}/build/pdepend"/>
|
<mkdir dir="${basedir}/build/pdepend"/>
|
||||||
@@ -47,29 +49,6 @@
|
|||||||
<mkdir dir="${basedir}/build/release/data/${env.appname}_${env.Version}"/>
|
<mkdir dir="${basedir}/build/release/data/${env.appname}_${env.Version}"/>
|
||||||
<mkdir dir="${basedir}/src/lib"/>
|
<mkdir dir="${basedir}/src/lib"/>
|
||||||
|
|
||||||
<copy todir="${basedir}/src/lib" overwrite="true">
|
|
||||||
<fileset dir="${basedir}/lib">
|
|
||||||
<include name="**/*"/>
|
|
||||||
</fileset>
|
|
||||||
</copy>
|
|
||||||
|
|
||||||
<copy todir="${basedir}/src" overwrite="true">
|
|
||||||
<fileset dir="${basedir}/core-ext">
|
|
||||||
<include name="**/*"/>
|
|
||||||
</fileset>
|
|
||||||
</copy>
|
|
||||||
|
|
||||||
<copy todir="${basedir}/src">
|
|
||||||
<fileset dir="${basedir}/ext">
|
|
||||||
<include name="**/*"/>
|
|
||||||
</fileset>
|
|
||||||
</copy>
|
|
||||||
|
|
||||||
<copy todir="${basedir}/src">
|
|
||||||
<fileset dir="${basedir}/tp">
|
|
||||||
<include name="**/*"/>
|
|
||||||
</fileset>
|
|
||||||
</copy>
|
|
||||||
|
|
||||||
<property name="prepare.done" value="true"/>
|
<property name="prepare.done" value="true"/>
|
||||||
</target>
|
</target>
|
||||||
@@ -80,6 +59,7 @@
|
|||||||
|
|
||||||
<fileset dir="${basedir}/src">
|
<fileset dir="${basedir}/src">
|
||||||
<include name="**/*.php" />
|
<include name="**/*.php" />
|
||||||
|
<exclude name="composer/**"/>
|
||||||
<modified />
|
<modified />
|
||||||
</fileset>
|
</fileset>
|
||||||
|
|
||||||
@@ -204,7 +184,6 @@
|
|||||||
|
|
||||||
|
|
||||||
<target name="copyapp"
|
<target name="copyapp"
|
||||||
depends=""
|
|
||||||
description="Copy generated files to QA app">
|
description="Copy generated files to QA app">
|
||||||
|
|
||||||
<delete includeemptydirs="true">
|
<delete includeemptydirs="true">
|
||||||
@@ -213,12 +192,30 @@
|
|||||||
</fileset>
|
</fileset>
|
||||||
</delete>
|
</delete>
|
||||||
|
|
||||||
<copy todir="${destination}">
|
<copy todir="${destination}" overwrite="true">
|
||||||
<fileset dir="${origin}">
|
<fileset dir="${origin}">
|
||||||
<include name="**/*"/>
|
<include name="**/*"/>
|
||||||
</fileset>
|
</fileset>
|
||||||
</copy>
|
</copy>
|
||||||
|
|
||||||
|
<copy todir="${destination}/lib" overwrite="true">
|
||||||
|
<fileset dir="${basedir}/lib">
|
||||||
|
<include name="**/*"/>
|
||||||
|
</fileset>
|
||||||
|
</copy>
|
||||||
|
|
||||||
|
<copy todir="${destination}" overwrite="true">
|
||||||
|
<fileset dir="${basedir}/core-ext">
|
||||||
|
<include name="**/*"/>
|
||||||
|
</fileset>
|
||||||
|
</copy>
|
||||||
|
|
||||||
|
<copy todir="${destination}" overwrite="true">
|
||||||
|
<fileset dir="${basedir}/ext">
|
||||||
|
<include name="**/*"/>
|
||||||
|
</fileset>
|
||||||
|
</copy>
|
||||||
|
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<target name="install"
|
<target name="install"
|
||||||
@@ -233,8 +230,8 @@
|
|||||||
|
|
||||||
<mkdir dir="${installpath}"/>
|
<mkdir dir="${installpath}"/>
|
||||||
|
|
||||||
<copy todir="${installpath}">
|
<copy todir="${installpath}" overwrite="true">
|
||||||
<fileset dir="${origin}">
|
<fileset dir="${destination}">
|
||||||
<include name="**/*"/>
|
<include name="**/*"/>
|
||||||
</fileset>
|
</fileset>
|
||||||
</copy>
|
</copy>
|
||||||
@@ -246,6 +243,25 @@
|
|||||||
</delete>
|
</delete>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
|
<target name="installLocal"
|
||||||
|
depends="copyapp"
|
||||||
|
description="">
|
||||||
|
|
||||||
|
<delete includeemptydirs="true" failonerror="false">
|
||||||
|
<fileset dir="${installLocalpath}">
|
||||||
|
<include name="**/*"/>
|
||||||
|
</fileset>
|
||||||
|
</delete>
|
||||||
|
|
||||||
|
<mkdir dir="${installLocalpath}"/>
|
||||||
|
|
||||||
|
<copy todir="${installLocalpath}">
|
||||||
|
<fileset dir="${destination}">
|
||||||
|
<include name="**/*"/>
|
||||||
|
</fileset>
|
||||||
|
</copy>
|
||||||
|
</target>
|
||||||
|
|
||||||
<target name="release"
|
<target name="release"
|
||||||
depends="copyapp"
|
depends="copyapp"
|
||||||
description="Create a release">
|
description="Create a release">
|
||||||
|
|||||||
82
core-ext/classes/LDAPManager.php
Normal file
82
core-ext/classes/LDAPManager.php
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class LDAPManager {
|
||||||
|
|
||||||
|
private static $me = null;
|
||||||
|
|
||||||
|
private function __construct(){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static function getInstance(){
|
||||||
|
if(empty(self::$me)){
|
||||||
|
self::$me = new LDAPManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
return self::$me;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function checkLDAPLogin($user, $password){
|
||||||
|
$ldap_host = SettingsManager::getInstance()->getSetting("LDAP: Server");
|
||||||
|
$ldap_port = SettingsManager::getInstance()->getSetting("LDAP: Port");
|
||||||
|
$ldap_dn = SettingsManager::getInstance()->getSetting("LDAP: Root DN");
|
||||||
|
|
||||||
|
$managerDN = SettingsManager::getInstance()->getSetting("LDAP: Manager DN");
|
||||||
|
$managerPassword = SettingsManager::getInstance()->getSetting("LDAP: Manager Password");
|
||||||
|
|
||||||
|
// connect to active directory
|
||||||
|
if(empty($ldap_port)){
|
||||||
|
$ldap_port = 389;
|
||||||
|
}
|
||||||
|
|
||||||
|
$ldap = ldap_connect($ldap_host, intval($ldap_port));
|
||||||
|
|
||||||
|
if(!$ldap){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Could not connect to LDAP Server");
|
||||||
|
}
|
||||||
|
|
||||||
|
LogManager::getInstance()->debug("LDAP Connect Result:".print_r($ldap,true));
|
||||||
|
|
||||||
|
if(SettingsManager::getInstance()->getSetting("LDAP: Version 3") == "1"){
|
||||||
|
ldap_set_option($ldap, LDAP_OPT_PROTOCOL_VERSION, 3);
|
||||||
|
}
|
||||||
|
ldap_set_option($ldap, LDAP_OPT_REFERRALS, 0);
|
||||||
|
|
||||||
|
// verify user and password
|
||||||
|
$bind = @ldap_bind($ldap, $managerDN, $managerPassword);
|
||||||
|
|
||||||
|
LogManager::getInstance()->debug("LDAP Manager Bind:".print_r($bind,true));
|
||||||
|
|
||||||
|
if($bind) {
|
||||||
|
|
||||||
|
$userFilterStr = SettingsManager::getInstance()->getSetting("LDAP: User Filter");
|
||||||
|
|
||||||
|
$filter = str_replace("{}", $user, $userFilterStr); //"(uid=" . $user . ")";
|
||||||
|
$result = ldap_search($ldap, $ldap_dn, $filter);
|
||||||
|
LogManager::getInstance()->debug("LDAP Search Result:".print_r($result,true));
|
||||||
|
if(!$result){
|
||||||
|
exit("Unable to search LDAP server");
|
||||||
|
}
|
||||||
|
$entries = ldap_get_entries($ldap, $result);
|
||||||
|
LogManager::getInstance()->debug("LDAP Search Entries:".print_r($entries,true));
|
||||||
|
|
||||||
|
if(empty($entries) || !isset($entries[0]) || !isset($entries[0]['dn'])){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Invalid user");
|
||||||
|
}
|
||||||
|
|
||||||
|
$bind = @ldap_bind($ldap,$entries[0]['dn'], $password);
|
||||||
|
ldap_unbind($ldap);
|
||||||
|
|
||||||
|
if($bind){
|
||||||
|
return new IceResponse(IceResponse::SUCCESS, $entries[0]);
|
||||||
|
}else{
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Invalid user");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} else {
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Invalid manager user");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1 +1,3 @@
|
|||||||
<?php
|
<?php
|
||||||
|
//Nothing here
|
||||||
|
?>
|
||||||
@@ -9,9 +9,9 @@ define('HOME_LINK_ADMIN', CLIENT_BASE_URL."?g=admin&n=dashboard&m=admin_Admin");
|
|||||||
define('HOME_LINK_OTHERS', CLIENT_BASE_URL."?g=modules&n=dashboard&m=module_Personal_Information");
|
define('HOME_LINK_OTHERS', CLIENT_BASE_URL."?g=modules&n=dashboard&m=module_Personal_Information");
|
||||||
|
|
||||||
//Version
|
//Version
|
||||||
define('VERSION', '15.2.OS');
|
define('VERSION', '18.0.OS');
|
||||||
define('CACHE_VALUE', '15.2.OS');
|
define('CACHE_VALUE', '18.0.OS');
|
||||||
define('VERSION_DATE', '12/03/2016');
|
define('VERSION_DATE', '04/08/2016');
|
||||||
|
|
||||||
if(!defined('CONTACT_EMAIL')){define('CONTACT_EMAIL','icehrm@gamonoid.com');}
|
if(!defined('CONTACT_EMAIL')){define('CONTACT_EMAIL','icehrm@gamonoid.com');}
|
||||||
if(!defined('KEY_PREFIX')){define('KEY_PREFIX','IceHrm');}
|
if(!defined('KEY_PREFIX')){define('KEY_PREFIX','IceHrm');}
|
||||||
@@ -19,3 +19,10 @@ if(!defined('APP_SEC')){define('APP_SEC','dbcs234d2s111');}
|
|||||||
|
|
||||||
define('UI_SHOW_SWITCH_PROFILE', true);
|
define('UI_SHOW_SWITCH_PROFILE', true);
|
||||||
define('CRON_LOG', '/var/log/nginx/icehrmcron.log');
|
define('CRON_LOG', '/var/log/nginx/icehrmcron.log');
|
||||||
|
|
||||||
|
define('MEMCACHE_HOST', '127.0.0.1');
|
||||||
|
define('MEMCACHE_PORT', '11211');
|
||||||
|
|
||||||
|
if(!defined('WK_HTML_PATH')){
|
||||||
|
define('WK_HTML_PATH', '/usr/bin/wkhtmltopdf');
|
||||||
|
}
|
||||||
|
|||||||
27
core-ext/doc/ldap-config.txt
Normal file
27
core-ext/doc/ldap-config.txt
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
Before using please install php5-ldap module
|
||||||
|
sudo apt-get install php5-ldap
|
||||||
|
|
||||||
|
For using php ldap on windows please refer
|
||||||
|
http://stackoverflow.com/questions/16864306/fatal-error-call-to-undefined-function-ldap-connect
|
||||||
|
|
||||||
|
|
||||||
|
The user "admin" will always login with local db username and password (even LDAP is enabled)
|
||||||
|
|
||||||
|
Use following config to test LDAP connection with following test LDAP server
|
||||||
|
http://www.forumsys.com/tutorials/integration-how-to/ldap/online-ldap-test-server/
|
||||||
|
|
||||||
|
Change configs as follows under System->Settings
|
||||||
|
|
||||||
|
LDAP: Enabled = Yes
|
||||||
|
LDAP: Server = ldap.forumsys.com
|
||||||
|
LDAP: Port = 389
|
||||||
|
LDAP: Root DN = dc=example,dc=com
|
||||||
|
LDAP: Manager DN = cn=read-only-admin,dc=example,dc=com
|
||||||
|
LDAP: Manager Password = password
|
||||||
|
LDAP: Version 3 = Yes
|
||||||
|
LDAP: User Filter = uid={}
|
||||||
|
|
||||||
|
Then create a user with username "riemann" under System->Users
|
||||||
|
|
||||||
|
Logout and try login with riemann/password
|
||||||
|
|
||||||
2
core-ext/login.com.inc.php
Normal file
2
core-ext/login.com.inc.php
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
<?php
|
||||||
|
//Nothing here
|
||||||
@@ -3,17 +3,65 @@ define('CLIENT_PATH',dirname(__FILE__));
|
|||||||
include ("config.base.php");
|
include ("config.base.php");
|
||||||
include ("include.common.php");
|
include ("include.common.php");
|
||||||
include("server.includes.inc.php");
|
include("server.includes.inc.php");
|
||||||
|
|
||||||
|
error_log(print_r($_REQUEST,true));
|
||||||
|
|
||||||
if(empty($user)){
|
if(empty($user)){
|
||||||
|
|
||||||
|
if(!isset($_REQUEST['f']) && isset($_COOKIE['icehrmLF']) && @$_REQUEST['login'] != 'no' && !isset($_REQUEST['username'])){
|
||||||
|
$tempUser = new User();
|
||||||
|
$tempUser->Load("login_hash = ?",array($_COOKIE['icehrmLF']));
|
||||||
|
|
||||||
|
if(!empty($tempUser->id) &&
|
||||||
|
sha1($tempUser->email."_".$tempUser->password) == $_COOKIE['icehrmLF']){
|
||||||
|
|
||||||
|
$_REQUEST['username'] = $tempUser->username;
|
||||||
|
$_REQUEST['password'] = $tempUser->password;
|
||||||
|
$_REQUEST['hashedPwd'] = $tempUser->password;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(!empty($_REQUEST['username']) && !empty($_REQUEST['password'])){
|
if(!empty($_REQUEST['username']) && !empty($_REQUEST['password'])){
|
||||||
|
|
||||||
$suser = null;
|
$suser = null;
|
||||||
$ssoUserLoaded = false;
|
$ssoUserLoaded = false;
|
||||||
|
|
||||||
if(empty($suser)){
|
if($_REQUEST['username'] != "admin") {
|
||||||
|
LogManager::getInstance()->debug("LDAP: Enabled :" . SettingsManager::getInstance()->getSetting("LDAP: Enabled"));
|
||||||
|
if (SettingsManager::getInstance()->getSetting("LDAP: Enabled") == "1") {
|
||||||
|
$ldapResp = LDAPManager::getInstance()->checkLDAPLogin($_REQUEST['username'], $_REQUEST['password']);
|
||||||
|
LogManager::getInstance()->debug("LDAP Response :" . print_r($ldapResp, true));
|
||||||
|
LogManager::getInstance()->debug("LDAP Response Status :" . $ldapResp->getStatus());
|
||||||
|
if ($ldapResp->getStatus() == IceResponse::ERROR) {
|
||||||
|
header("Location:" . CLIENT_BASE_URL . "login.php?f=1");
|
||||||
|
exit();
|
||||||
|
} else {
|
||||||
$suser = new User();
|
$suser = new User();
|
||||||
$suser->Load("(username = ? or email = ?) and password = ?",array($_REQUEST['username'],$_REQUEST['username'],md5($_REQUEST['password'])));
|
$suser->Load("username = ?", array($_REQUEST['username']));
|
||||||
|
LogManager::getInstance()->debug("LDAP Response :[".$_REQUEST['username']."]" . print_r($suser, true));
|
||||||
|
if (empty($suser)) {
|
||||||
|
header("Location:" . CLIENT_BASE_URL . "login.php?f=1");
|
||||||
|
exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if($suser->password == md5($_REQUEST['password']) || $ssoUserLoaded){
|
$ssoUserLoaded = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(!isset($_REQUEST['hashedPwd'])){
|
||||||
|
$_REQUEST['hashedPwd'] = md5($_REQUEST['password']);
|
||||||
|
}
|
||||||
|
|
||||||
|
include 'login.com.inc.php';
|
||||||
|
|
||||||
|
if(empty($suser)){
|
||||||
|
$suser = new User();
|
||||||
|
$suser->Load("(username = ? or email = ?) and password = ?",array($_REQUEST['username'],$_REQUEST['username'],$_REQUEST['hashedPwd']));
|
||||||
|
}
|
||||||
|
|
||||||
|
if($suser->password == $_REQUEST['hashedPwd'] || $ssoUserLoaded){
|
||||||
$user = $suser;
|
$user = $suser;
|
||||||
SessionUtils::saveSessionObject('user', $user);
|
SessionUtils::saveSessionObject('user', $user);
|
||||||
$suser->last_login = date("Y-m-d H:i:s");
|
$suser->last_login = date("Y-m-d H:i:s");
|
||||||
@@ -24,12 +72,29 @@ if(empty($user)){
|
|||||||
BaseService::getInstance()->audit(IceConstants::AUDIT_AUTHENTICATION, "User Login");
|
BaseService::getInstance()->audit(IceConstants::AUDIT_AUTHENTICATION, "User Login");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(!$ssoUserLoaded && isset($_REQUEST['remember'])){
|
||||||
|
//Add cookie
|
||||||
|
$suser->login_hash = sha1($suser->email."_".$suser->password);
|
||||||
|
$suser->Save();
|
||||||
|
|
||||||
|
setcookie('icehrmLF',$suser->login_hash);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!isset($_REQUEST['remember'])){
|
||||||
|
setcookie('icehrmLF');
|
||||||
|
}
|
||||||
|
|
||||||
$redirectUrl = SessionUtils::getSessionObject('loginRedirect');
|
$redirectUrl = SessionUtils::getSessionObject('loginRedirect');
|
||||||
if(!empty($redirectUrl)){
|
if(!empty($redirectUrl)){
|
||||||
header("Location:".$redirectUrl);
|
header("Location:".$redirectUrl);
|
||||||
}else{
|
}else{
|
||||||
if($user->user_level == "Admin"){
|
if($user->user_level == "Admin"){
|
||||||
|
if(SessionUtils::getSessionObject('account_locked') == "1"){
|
||||||
|
header("Location:".CLIENT_BASE_URL."?g=admin&n=billing&m=admin_System");
|
||||||
|
}else{
|
||||||
header("Location:".HOME_LINK_ADMIN);
|
header("Location:".HOME_LINK_ADMIN);
|
||||||
|
}
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
if(empty($user->default_module)){
|
if(empty($user->default_module)){
|
||||||
header("Location:".HOME_LINK_OTHERS);
|
header("Location:".HOME_LINK_OTHERS);
|
||||||
@@ -39,12 +104,13 @@ if(empty($user)){
|
|||||||
if($defaultModule->mod_group == "user"){
|
if($defaultModule->mod_group == "user"){
|
||||||
$defaultModule->mod_group = "modules";
|
$defaultModule->mod_group = "modules";
|
||||||
}
|
}
|
||||||
$homeLink = CLIENT_BASE_URL."?g=".$defaultModule->mod_group."&n=".$defaultModule->name.
|
$homeLink = CLIENT_BASE_URL."?g=".$defaultModule->mod_group."&&n=".$defaultModule->name.
|
||||||
"&m=".$defaultModule->mod_group."_".str_replace(" ","_",$defaultModule->menu);
|
"&m=".$defaultModule->mod_group."_".str_replace(" ","_",$defaultModule->menu);
|
||||||
header("Location:".$homeLink);
|
header("Location:".$homeLink);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
header("Location:".CLIENT_BASE_URL."login.php?f=1");
|
header("Location:".CLIENT_BASE_URL."login.php?f=1");
|
||||||
}
|
}
|
||||||
@@ -70,23 +136,21 @@ if(empty($user)){
|
|||||||
}
|
}
|
||||||
|
|
||||||
$tuser = SessionUtils::getSessionObject('user');
|
$tuser = SessionUtils::getSessionObject('user');
|
||||||
//check user
|
|
||||||
|
|
||||||
$logoFileUrl = UIManager::getInstance()->getCompanyLogoUrl();
|
$logoFileUrl = UIManager::getInstance()->getCompanyLogoUrl();
|
||||||
|
|
||||||
?><!DOCTYPE html>
|
?><!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
<title><?=APP_NAME?> Login v<?=VERSION?> © http://icehrm.com</title>
|
<title><?=APP_NAME?> Login</title>
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<meta name="description" content="A Powerful But Simple Way to Manage Your Company and People. http://icehrm.com">
|
<meta name="description" content="">
|
||||||
<meta name="author" content="http://gamonoid.com">
|
<meta name="author" content="">
|
||||||
|
|
||||||
<!-- Le styles -->
|
<!-- Le styles -->
|
||||||
<link href="<?=BASE_URL?>bootstrap/css/bootstrap.css" rel="stylesheet">
|
<link href="<?=BASE_URL?>bootstrap/css/bootstrap.css" rel="stylesheet">
|
||||||
|
|
||||||
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.1/jquery.js"></script>
|
<script type="text/javascript" src="<?=BASE_URL?>js/jquery-1.8.1.js"></script>
|
||||||
<script src="<?=BASE_URL?>bootstrap/js/bootstrap.js"></script>
|
<script src="<?=BASE_URL?>bootstrap/js/bootstrap.js"></script>
|
||||||
<script src="<?=BASE_URL?>js/jquery.placeholder.js"></script>
|
<script src="<?=BASE_URL?>js/jquery.placeholder.js"></script>
|
||||||
<script src="<?=BASE_URL?>js/jquery.dataTables.js"></script>
|
<script src="<?=BASE_URL?>js/jquery.dataTables.js"></script>
|
||||||
@@ -98,7 +162,7 @@ $logoFileUrl = UIManager::getInstance()->getCompanyLogoUrl();
|
|||||||
|
|
||||||
<!-- Le HTML5 shim, for IE6-8 support of HTML5 elements -->
|
<!-- Le HTML5 shim, for IE6-8 support of HTML5 elements -->
|
||||||
<!--[if lt IE 9]>
|
<!--[if lt IE 9]>
|
||||||
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
|
<script src="<?=BASE_URL?>js/html5.js"></script>
|
||||||
<![endif]-->
|
<![endif]-->
|
||||||
|
|
||||||
<style type="text/css">
|
<style type="text/css">
|
||||||
@@ -155,23 +219,7 @@ $logoFileUrl = UIManager::getInstance()->getCompanyLogoUrl();
|
|||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<div itemscope itemtype="http://schema.org/WebApplication" style="display: none;">
|
|
||||||
<span itemprop="name">IceHrm Pro</span> -
|
|
||||||
|
|
||||||
REQUIRES <span itemprop="operatingSystem">Windows, OSX, Linux</span>
|
|
||||||
<link itemprop="applicationCategory" href="http://icehrm.com"/>
|
|
||||||
|
|
||||||
RATING:
|
|
||||||
<div itemprop="aggregateRating" itemscope itemtype="http://schema.org/AggregateRating">
|
|
||||||
<span itemprop="ratingValue">4.5</span> (
|
|
||||||
<span itemprop="ratingCount">12</span> ratings )
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div itemprop="offers" itemscope itemtype="http://schema.org/Offer">
|
|
||||||
Price: $<span itemprop="price">199.99</span>
|
|
||||||
<meta itemprop="priceCurrency" content="USD" />
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<script>
|
<script>
|
||||||
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
|
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
|
||||||
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
|
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
|
||||||
@@ -253,6 +301,9 @@ $logoFileUrl = UIManager::getInstance()->getCompanyLogoUrl();
|
|||||||
}
|
}
|
||||||
|
|
||||||
function submitLogin(){
|
function submitLogin(){
|
||||||
|
try{
|
||||||
|
localStorage.clear();
|
||||||
|
}catch(e){}
|
||||||
$("#loginForm").submit();
|
$("#loginForm").submit();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -292,6 +343,11 @@ $logoFileUrl = UIManager::getInstance()->getCompanyLogoUrl();
|
|||||||
<input class="span2" type="password" id="password" name="password" placeholder="Password">
|
<input class="span2" type="password" id="password" name="password" placeholder="Password">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="clearfix">
|
||||||
|
<div class="checkbox">
|
||||||
|
<label><input id="remember" name="remember" type="checkbox" value="remember" checked>Remember me</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<?php if(isset($_REQUEST['f'])){?>
|
<?php if(isset($_REQUEST['f'])){?>
|
||||||
<div class="clearfix alert alert-error" style="font-size:11px;width:147px;margin-bottom: 5px;">
|
<div class="clearfix alert alert-error" style="font-size:11px;width:147px;margin-bottom: 5px;">
|
||||||
Login failed
|
Login failed
|
||||||
@@ -309,11 +365,10 @@ $logoFileUrl = UIManager::getInstance()->getCompanyLogoUrl();
|
|||||||
</fieldset>
|
</fieldset>
|
||||||
<div class="clearfix">
|
<div class="clearfix">
|
||||||
<a href="" onclick="showForgotPassword();return false;" style="float:left;margin-top: 10px;">Forgot password</a>
|
<a href="" onclick="showForgotPassword();return false;" style="float:left;margin-top: 10px;">Forgot password</a>
|
||||||
|
<!--
|
||||||
<a href="<?=TWITTER_URL?>" target="_blank" style="float:right;"><img src="<?=BASE_URL?>images/32x32-Circle-53-TW.png"/></a>
|
<a href="<?=TWITTER_URL?>" target="_blank" style="float:right;"><img src="<?=BASE_URL?>images/32x32-Circle-53-TW.png"/></a>
|
||||||
<a href="<?=FB_URL?>" target="_blank" style="float:right;margin-right: 7px;"><img src="<?=BASE_URL?>images/32x32-Circle-54-FB.png"/></a>
|
<a href="<?=FB_URL?>" target="_blank" style="float:right;margin-right: 7px;"><img src="<?=BASE_URL?>images/32x32-Circle-54-FB.png"/></a>
|
||||||
</div>
|
-->
|
||||||
<div class="clearfix">
|
|
||||||
<span style="font-size:9px;">© <a href="http://icehrm.com" target="_blank">IceHrm - v<?=VERSION?></a> Developed by <a href="http://gamonoid.com" target="_blank">Gamonoid (Pvt) Ltd.</a></span>
|
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
<form id="requestPasswordChangeForm" style="display:none;" action="">
|
<form id="requestPasswordChangeForm" style="display:none;" action="">
|
||||||
|
|||||||
@@ -1,6 +1,19 @@
|
|||||||
<?php
|
<?php
|
||||||
class ICEHRM_Record extends ADOdb_Active_Record{
|
class ICEHRM_Record extends ADOdb_Active_Record{
|
||||||
|
|
||||||
|
var $keysToIgnore = array(
|
||||||
|
"_table",
|
||||||
|
"_dbat",
|
||||||
|
"_tableat",
|
||||||
|
"_where",
|
||||||
|
"_saved",
|
||||||
|
"_lasterr",
|
||||||
|
"_original",
|
||||||
|
"foreignName",
|
||||||
|
"a",
|
||||||
|
"t"
|
||||||
|
);
|
||||||
|
|
||||||
public function getAdminAccess(){
|
public function getAdminAccess(){
|
||||||
return array("get","element","save","delete");
|
return array("get","element","save","delete");
|
||||||
}
|
}
|
||||||
@@ -61,6 +74,10 @@ class ICEHRM_Record extends ADOdb_Active_Record{
|
|||||||
return $obj;
|
return $obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function postProcessGetElement($obj){
|
||||||
|
return $obj;
|
||||||
|
}
|
||||||
|
|
||||||
public function getDefaultAccessLevel(){
|
public function getDefaultAccessLevel(){
|
||||||
return array("get","element","save","delete");
|
return array("get","element","save","delete");
|
||||||
}
|
}
|
||||||
@@ -73,4 +90,49 @@ class ICEHRM_Record extends ADOdb_Active_Record{
|
|||||||
public function allowIndirectMapping(){
|
public function allowIndirectMapping(){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getDisplayName() {
|
||||||
|
return get_called_class();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getObjectKeys(){
|
||||||
|
$keys = array();
|
||||||
|
|
||||||
|
foreach($this as $k=>$v){
|
||||||
|
if(in_array($k,$this->keysToIgnore )){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(is_array($v) || is_object($v)){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$keys[$k] = $k;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $keys;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getCustomFields($obj){
|
||||||
|
$keys = array();
|
||||||
|
$objKeys = $this->getObjectKeys();
|
||||||
|
foreach($obj as $k=>$v){
|
||||||
|
if(isset($objKeys[$k])){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(is_array($v) || is_object($v)){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(in_array($k,$this->keysToIgnore )){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$keys[$k] = $k;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $keys;
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -118,8 +118,8 @@
|
|||||||
<p id="verifyModelBody">
|
<p id="verifyModelBody">
|
||||||
<b>Step 1:</b><br/>
|
<b>Step 1:</b><br/>
|
||||||
Please get your Instance Key from here:<br/>
|
Please get your Instance Key from here:<br/>
|
||||||
<a target="_blank" href="http://icehrm.com/generateInstanceKey.php?id=<?=$baseService->getInstanceId()?>">
|
<a target="_blank" href="https://icehrm.com/generateInstanceKey.php?id=<?=$baseService->getInstanceId()?>">
|
||||||
http://icehrm.com/generateInstanceKey.php?id=<?=$baseService->getInstanceId()?>
|
https://icehrm.com/generateInstanceKey.php?id=<?=$baseService->getInstanceId()?>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<br/><b>Step 2:</b><br/>
|
<br/><b>Step 2:</b><br/>
|
||||||
@@ -157,10 +157,10 @@
|
|||||||
<div class="modal-content">
|
<div class="modal-content">
|
||||||
<div class="modal-header">
|
<div class="modal-header">
|
||||||
<button type="button" class="close" data-dismiss="modal" aria-hidden="true"><li class="fa fa-times"/></button>
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true"><li class="fa fa-times"/></button>
|
||||||
<h3 id="myModalLabel">Switch Employee</h3>
|
<h3 id="myModalLabel"><?=LanguageManager::tran('Switch Employee')?></h3>
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-body">
|
<div class="modal-body">
|
||||||
<p>Select the employee to Edit</p>
|
<p><?=LanguageManager::tran('Select The Employee to Switch Into')?></p>
|
||||||
<div style="border: solid 1px #EEE;">
|
<div style="border: solid 1px #EEE;">
|
||||||
<select id="switch_emp" style="width:100%;">
|
<select id="switch_emp" style="width:100%;">
|
||||||
<!--
|
<!--
|
||||||
@@ -176,11 +176,47 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-footer">
|
<div class="modal-footer">
|
||||||
<button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>
|
<button class="btn" data-dismiss="modal" aria-hidden="true"><?=LanguageManager::tran('Close')?></button>
|
||||||
<button class="btn btn-primary" onclick="modJs.setAdminProfile($('#switch_emp').val());return false;">Switch</button>
|
<button class="btn btn-primary" onclick="modJs.setAdminProfile($('#switch_emp').val());return false;"><?=LanguageManager::tran('Switch')?></button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- Modal -->
|
<!-- Modal -->
|
||||||
<?php }?>
|
<?php }?>
|
||||||
|
|
||||||
|
|
||||||
|
<?php if(isset($itemNameLower)){?>
|
||||||
|
<div class="modal" id="<?=$itemNameLower?>StatusModel" tabindex="-1" role="dialog" aria-labelledby="messageModelLabel" aria-hidden="true">
|
||||||
|
<div class="modal-dialog">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true"><li class="fa fa-times"/></button>
|
||||||
|
<h3 style="font-size: 17px;">Change <?=$itemName?> Status</h3>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<form id="expenseStatusForm">
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label" for="expense_status"><?=$itemName?> Status</label>
|
||||||
|
<div class="controls">
|
||||||
|
<select type="text" id="<?=$itemNameLower?>_status" class="form-control" name="<?=$itemNameLower?>_status" value="">
|
||||||
|
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label" for="expense_status">Status Change Note</label>
|
||||||
|
<div class="controls">
|
||||||
|
<textarea id="<?=$itemNameLower?>_reason" class="form-control" name="<?=$itemNameLower?>_reason" maxlength="500"></textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button class="btn btn-primary" onclick="modJs.changeStatus();">Change <?=$itemName?> Status</button>
|
||||||
|
<button class="btn" onclick="modJs.closeDialog();">Not Now</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<?php } ?>
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
@@ -1,5 +1,19 @@
|
|||||||
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
|
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
|
||||||
|
|
||||||
|
DELIMITER $$
|
||||||
|
CREATE FUNCTION generate_fname () RETURNS varchar(255)
|
||||||
|
BEGIN
|
||||||
|
RETURN ELT(FLOOR(1 + (RAND() * (100-1))), "James","Mary","John","Patricia","Robert","Linda","Michael","Barbara","William","Elizabeth","David","Jennifer","Richard","Maria","Charles","Susan","Joseph","Margaret","Thomas","Dorothy","Christopher","Lisa","Daniel","Nancy","Paul","Karen","Mark","Betty","Donald","Helen","George","Sandra","Kenneth","Donna","Steven","Carol","Edward","Ruth","Brian","Sharon","Ronald","Michelle","Anthony","Laura","Kevin","Sarah","Jason","Kimberly","Matthew","Deborah","Gary","Jessica","Timothy","Shirley","Jose","Cynthia","Larry","Angela","Jeffrey","Melissa","Frank","Brenda","Scott","Amy","Eric","Anna","Stephen","Rebecca","Andrew","Virginia","Raymond","Kathleen","Gregory","Pamela","Joshua","Martha","Jerry","Debra","Dennis","Amanda","Walter","Stephanie","Patrick","Carolyn","Peter","Christine","Harold","Marie","Douglas","Janet","Henry","Catherine","Carl","Frances","Arthur","Ann","Ryan","Joyce","Roger","Diane");
|
||||||
|
END$$
|
||||||
|
|
||||||
|
DELIMITER ;
|
||||||
|
|
||||||
|
DELIMITER $$
|
||||||
|
CREATE FUNCTION generate_lname () RETURNS varchar(255)
|
||||||
|
BEGIN
|
||||||
|
RETURN ELT(FLOOR(1 + (RAND() * (100-1))), "Smith","Johnson","Williams","Jones","Brown","Davis","Miller","Wilson","Moore","Taylor","Anderson","Thomas","Jackson","White","Harris","Martin","Thompson","Garcia","Martinez","Robinson","Clark","Rodriguez","Lewis","Lee","Walker","Hall","Allen","Young","Hernandez","King","Wright","Lopez","Hill","Scott","Green","Adams","Baker","Gonzalez","Nelson","Carter","Mitchell","Perez","Roberts","Turner","Phillips","Campbell","Parker","Evans","Edwards","Collins","Stewart","Sanchez","Morris","Rogers","Reed","Cook","Morgan","Bell","Murphy","Bailey","Rivera","Cooper","Richardson","Cox","Howard","Ward","Torres","Peterson","Gray","Ramirez","James","Watson","Brooks","Kelly","Sanders","Price","Bennett","Wood","Barnes","Ross","Henderson","Coleman","Jenkins","Perry","Powell","Long","Patterson","Hughes","Flores","Washington","Butler","Simmons","Foster","Gonzales","Bryant","Alexander","Russell","Griffin","Diaz","Hayes");
|
||||||
|
END$$
|
||||||
|
DELIMITER ;
|
||||||
|
|
||||||
INSERT INTO `CompanyStructures` (`id`, `title`, `description`, `address`, `type`, `country`, `parent`) VALUES
|
INSERT INTO `CompanyStructures` (`id`, `title`, `description`, `address`, `type`, `country`, `parent`) VALUES
|
||||||
(4, 'Development Center', 'Development Center', 'PO Box 001002\nSample Road, Sample Town', 'Regional Office', 'SG', 1),
|
(4, 'Development Center', 'Development Center', 'PO Box 001002\nSample Road, Sample Town', 'Regional Office', 'SG', 1),
|
||||||
@@ -10,12 +24,28 @@ INSERT INTO `CompanyStructures` (`id`, `title`, `description`, `address`, `type`
|
|||||||
(9, 'Administration & HR', 'Administration and Human Resource', '', 'Department', 'SG', 4);
|
(9, 'Administration & HR', 'Administration and Human Resource', '', 'Department', 'SG', 4);
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `Employees` (`id`, `employee_id`, `first_name`, `middle_name`, `last_name`, `nationality`, `birthday`, `gender`, `marital_status`, `ssn_num`, `nic_num`, `other_id`, `driving_license`, `driving_license_exp_date`, `employment_status`, `job_title`, `pay_grade`, `work_station_id`, `address1`, `address2`, `city`, `country`, `province`, `postal_code`, `home_phone`, `mobile_phone`, `work_phone`, `work_email`, `private_email`, `joined_date`, `confirmation_date`, `supervisor`, `department`, `custom1`, `custom2`, `custom3`, `custom4`, `custom5`, `custom6`, `custom7`, `custom8`, `custom9`, `custom10`,`indirect_supervisors`) VALUES
|
||||||
|
(2, 'EMP002', 'Lala', 'Nadila ', 'Lamees', 175, '1984-03-12 18:30:00', 'Female', 'Single', '', '4594567WE3', '4595567WE3', '349-066-YUO', '2012-03-01', 1, 8, 2, 'W001', 'Green War Rd, 00123', '', 'Istanbul', 'TR', NULL, '909066', '+960112345', '+960112345', '+960112345', 'icehrm+manager@web-stalk.com', 'icehrm+manager@web-stalk.com', '2011-03-07 18:30:00', '2012-02-14 18:30:00', 1, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,NULL),
|
||||||
|
(3, 'EMP003', 'Sofia', '', 'O''Sullivan', 4, '1975-08-28 18:30:00', 'Female', 'Married', '', '768-20-4394', '768-20-4394', '', NULL, 3, 10, 2, '', '2792 Trails End Road', 'Fort Lauderdale', 'Fort Lauderdale', 'US', 12, '33308', '954-388-3340', '954-388-3340', '954-388-3340', 'icehrm+user1@web-stalk.com', 'icehrm+user1@web-stalk.com', '2010-02-08 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,'[\"1\"]'),
|
||||||
|
(4, 'EMP004', 'Taylor', '', 'Holmes', 10, '1979-07-15 18:30:00', 'Male', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,NULL);
|
||||||
|
|
||||||
INSERT INTO `Employees` (`id`, `employee_id`, `first_name`, `middle_name`, `last_name`, `nationality`, `birthday`, `gender`, `marital_status`, `ssn_num`, `nic_num`, `other_id`, `driving_license`, `driving_license_exp_date`, `employment_status`, `job_title`, `pay_grade`, `work_station_id`, `address1`, `address2`, `city`, `country`, `province`, `postal_code`, `home_phone`, `mobile_phone`, `work_phone`, `work_email`, `private_email`, `joined_date`, `confirmation_date`, `supervisor`, `department`, `custom1`, `custom2`, `custom3`, `custom4`, `custom5`, `custom6`, `custom7`, `custom8`, `custom9`, `custom10`) VALUES
|
INSERT INTO `Employees` (`id`, `employee_id`, `first_name`, `middle_name`, `last_name`, `nationality`, `birthday`, `gender`, `marital_status`, `ssn_num`, `nic_num`, `other_id`, `driving_license`, `driving_license_exp_date`, `employment_status`, `job_title`, `pay_grade`, `work_station_id`, `address1`, `address2`, `city`, `country`, `province`, `postal_code`, `home_phone`, `mobile_phone`, `work_phone`, `work_email`, `private_email`, `joined_date`, `confirmation_date`, `supervisor`, `department`, `custom1`, `custom2`, `custom3`, `custom4`, `custom5`, `custom6`, `custom7`, `custom8`, `custom9`, `custom10`) VALUES
|
||||||
(2, 'EMP002', 'Lala', 'Nadila ', 'Lamees', 175, '1984-03-12 18:30:00', 'Female', 'Single', '', '4594567WE3', '4595567WE3', '349-066-YUO', '2012-03-01', 1, 8, 2, 'W001', 'Green War Rd, 00123', '', 'Istanbul', 'TR', NULL, '909066', '+960112345', '+960112345', '+960112345', 'icehrm+manager@web-stalk.com', 'icehrm+manager@web-stalk.com', '2011-03-07 18:30:00', '2012-02-14 18:30:00', 1, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
(5, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Male', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
(3, 'EMP003', 'Sofia', '', 'O''Sullivan', 4, '1975-08-28 18:30:00', 'Female', 'Married', '', '768-20-4394', '768-20-4394', '', NULL, 3, 10, 2, '', '2792 Trails End Road', 'Fort Lauderdale', 'Fort Lauderdale', 'US', 12, '33308', '954-388-3340', '954-388-3340', '954-388-3340', 'icehrm+user1@web-stalk.com', 'icehrm+user1@web-stalk.com', '2010-02-08 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
(6, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Male', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
(4, 'EMP004', 'Taylor', '', 'Holmes', 10, '1979-07-15 18:30:00', 'Male', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
|
(7, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Male', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
|
(8, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Male', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
|
(9, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Male', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
|
(10, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Female', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
|
(11, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Female', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
|
(12, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Female', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
|
(13, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Female', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
|
(14, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Female', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL),
|
||||||
|
(15, CONCAT('EMP', RAND()), generate_fname(), '', generate_fname(), 10, '1979-07-15 18:30:00', 'Female', 'Single', '158-06-2292', '158-06-2292', '', '', NULL, 1, 5, 2, '', '1164', 'Walnut Avenue', 'Rochelle Park', 'US', 35, '7662', '201-474-8048', '201-474-8048', '201-474-8048', 'icehrm+user2@web-stalk.com', 'icehrm+user2@web-stalk.com', '2006-07-12 18:30:00', '0000-00-00 00:00:00', 2, 2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
|
||||||
|
|
||||||
|
|
||||||
|
UPDATE `Employees` set supervisor = 2, indirect_supervisors = '[3,4]', approver1 = 5, approver2 = 6, approver3 = 7 where id = 1;
|
||||||
|
UPDATE `Employees` set supervisor = 1, indirect_supervisors = '[3,4]', approver1 = 5, approver2 = 6 where id = 2;
|
||||||
|
UPDATE `Employees` set supervisor = 2, indirect_supervisors = '[1,4]', approver1 = 5 where id = 3;
|
||||||
|
|
||||||
INSERT INTO `EmergencyContacts` (`id`, `employee`, `name`, `relationship`, `home_phone`, `work_phone`, `mobile_phone`) VALUES
|
INSERT INTO `EmergencyContacts` (`id`, `employee`, `name`, `relationship`, `home_phone`, `work_phone`, `mobile_phone`) VALUES
|
||||||
(1, 1, 'Emma Owns', 'Mother', '+874463422', '+874463422', '+874463422'),
|
(1, 1, 'Emma Owns', 'Mother', '+874463422', '+874463422', '+874463422'),
|
||||||
@@ -36,9 +66,6 @@ INSERT INTO `EmployeeDependents` (`id`, `employee`, `name`, `relationship`, `dob
|
|||||||
(2, 1, 'Mica Singroo', 'Other', '2000-06-13', '');
|
(2, 1, 'Mica Singroo', 'Other', '2000-06-13', '');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
INSERT INTO `EmployeeEducations` (`id`, `education_id`, `employee`, `institute`, `date_start`, `date_end`) VALUES
|
INSERT INTO `EmployeeEducations` (`id`, `education_id`, `employee`, `institute`, `date_start`, `date_end`) VALUES
|
||||||
(1, 1, 1, 'National University of Turky', '2004-02-03', '2006-06-13'),
|
(1, 1, 1, 'National University of Turky', '2004-02-03', '2006-06-13'),
|
||||||
(2, 1, 2, 'MIT', '1995-02-21', '1999-10-12');
|
(2, 1, 2, 'MIT', '1995-02-21', '1999-10-12');
|
||||||
@@ -56,12 +83,38 @@ INSERT INTO `EmployeeProjects` (`id`, `employee`, `project`, `date_start`, `date
|
|||||||
(5, 2, 3, '2013-02-24', '0000-00-00', 'Current', '');
|
(5, 2, 3, '2013-02-24', '0000-00-00', 'Current', '');
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `EmployeeSalary` (`employee`, `component`,`amount`, `details`) VALUES
|
||||||
|
(1, 1,'50000.00', ''),
|
||||||
|
(1, 2,'20000.00', ''),
|
||||||
|
(1, 3,'30000.00', ''),
|
||||||
|
(1, 4,'2000.00', ''),
|
||||||
|
|
||||||
INSERT INTO `EmployeeSalary` (`id`, `employee`, `component`, `pay_frequency`, `currency`, `amount`, `details`) VALUES
|
(2, 1,'90500.00', ''),
|
||||||
(1, 1, 1, 'Monthly', 131, '2700.00', ''),
|
(2, 2,'40000.00', ''),
|
||||||
(2, 2, 2, 'Monthly', 151, '12000.00', ''),
|
(2, 3,'50000.00', ''),
|
||||||
(3, 2, 3, 'Monthly', 131, '5000.00', '');
|
|
||||||
|
|
||||||
|
(3, 1,'131409.00', ''),
|
||||||
|
(3, 2,'143471.00', ''),
|
||||||
|
(3, 3,'50000.00', ''),
|
||||||
|
(3, 4,'30000.00', ''),
|
||||||
|
|
||||||
|
(4, 5,'1432.00', ''),
|
||||||
|
(4, 6,'2100.00', ''),
|
||||||
|
|
||||||
|
(5, 5,'1200.00', ''),
|
||||||
|
(5, 6,'1500.00', ''),
|
||||||
|
(5, 7,'2000.00', ''),
|
||||||
|
|
||||||
|
(5, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(6, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(7, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(8, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(9, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(10, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(11, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(12, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(13, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), ''),
|
||||||
|
(14, 1,round(rand() * 100000 + rand() * 20000 - rand() * 20000, 2), '');
|
||||||
|
|
||||||
INSERT INTO `EmployeeSkills` (`id`, `skill_id`, `employee`, `details`) VALUES
|
INSERT INTO `EmployeeSkills` (`id`, `skill_id`, `employee`, `details`) VALUES
|
||||||
(1, 9, 1, 'Creating web sites'),
|
(1, 9, 1, 'Creating web sites'),
|
||||||
@@ -69,10 +122,43 @@ INSERT INTO `EmployeeSkills` (`id`, `skill_id`, `employee`, `details`) VALUES
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
INSERT INTO `Users` (`id`, `username`, `email`, `password`, `employee`, `user_level`, `last_login`, `last_update`, `created`) VALUES
|
|
||||||
(2, 'manager', 'icehrm+manager@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 2, 'Manager', '2013-01-03 02:47:37', '2013-01-03 02:47:37', '2013-01-03 02:47:37'),
|
INSERT INTO `LeaveRules` (`id`, `leave_type`, `job_title`, `employment_status`, `employee`, `supervisor_leave_assign`, `employee_can_apply`, `apply_beyond_current`, `leave_accrue`, `carried_forward`, `default_per_year`) VALUES
|
||||||
(3, 'user1', 'icehrm+user1@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 3, 'Employee', '2013-01-03 02:48:32', '2013-01-03 02:48:32', '2013-01-03 02:48:32'),
|
(1, 1, 11, NULL, NULL, 'No', 'Yes', 'Yes', 'No', 'No', 25),
|
||||||
(4, 'user2', 'icehrm+user2@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 4, 'Employee', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55');
|
(2, 2, NULL, NULL, 2, 'No', 'Yes', 'Yes', 'No', 'No', 10);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `Users` (`id`, `username`, `email`, `password`, `employee`,`default_module`, `user_level`,`user_roles`, `last_login`, `last_update`, `created`) VALUES
|
||||||
|
(2, 'manager', 'icehrm+manager@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 2,NULL, 'Manager','', '2013-01-03 02:47:37', '2013-01-03 02:47:37', '2013-01-03 02:47:37'),
|
||||||
|
(3, 'user1', 'icehrm+user1@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 3,NULL, 'Employee','', '2013-01-03 02:48:32', '2013-01-03 02:48:32', '2013-01-03 02:48:32'),
|
||||||
|
(4, 'user2', 'icehrm+user2@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 4,NULL, 'Employee','', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55'),
|
||||||
|
(5, 'user3', 'icehrm+user3@web-stalk.com', '4048bb914a704a0728549a26b92d8550', NULL,NULL, 'Other','["1"]', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55'),
|
||||||
|
(6, 'user4', 'icehrm+user4@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 5,NULL, 'Manager','', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55'),
|
||||||
|
(7, 'user5', 'icehrm+user5@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 6,NULL, 'Employee','', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55'),
|
||||||
|
(8, 'user6', 'icehrm+user6@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 7,NULL, 'Employee','', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55'),
|
||||||
|
(9, 'user7', 'icehrm+user7@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 8,NULL, 'Employee','', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55'),
|
||||||
|
(10, 'user8', 'icehrm+user8@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 9,NULL, 'Employee','', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55'),
|
||||||
|
(11, 'user9', 'icehrm+user9@web-stalk.com', '4048bb914a704a0728549a26b92d8550', 10,NULL, 'Employee','', '2013-01-03 02:58:55', '2013-01-03 02:58:55', '2013-01-03 02:58:55');
|
||||||
|
|
||||||
|
INSERT INTO `Job` VALUES
|
||||||
|
(1,'Software Engineer','More than 375,000 users world-wide rely on our software for their daily business as it makes creating graphical presentations so much easier, faster and more enjoyable. Among our customers are many renowned consulting companies and large international corporations.','More than 375,000 users world-wide rely on our software for their daily business as it makes creating graphical presentations so much easier, faster and more enjoyable. Among our customers are many renowned consulting companies and large international corporations.\n\nWe follow our own strategy and do not have to make compromises with regard to code quality and beauty, because think-cell is profitable and has no outside investors. We are flourishing without program managers, meetings, and marketing-driven deadlines. Our code quality is extraordinarily high because we only release software when it is ready. We are willing to do the leg work of developing sophisticated algorithms and refining our user interface, which makes working with think-cell’s software so satisfying.','Challenging C++ coding with high personal responsibility\nWork with a competent and creative team in a modern loft office in Berlin\nFamily-friendly working hours, no deadlines\nAbove-average salary (we offer our developers EUR 120,000 annually after one year of employment)\nFree supply of drinks, fruits, sweets and snacks\nFlat hierarchies and plenty of room for your ideas\nA full-time company nanny who is available for free when children are sick, or when you just feel like spending an evening out','[\"Health plan\",\"Paid vacations\"]',226,2,NULL,'JC001',1,NULL,7,14,9,151,'Yes',3500,5500,'job, engineer','Active','0000-00-00 00:00:00',NULL,'Text Only',1),
|
||||||
|
(2,'QA Senior Test Automation Engineer','As a QA Senior Test Automation Engineer at Rocket you will help us launch the most successful startup companies around the world.','As a QA Senior Test Automation Engineer at Rocket you will help us launch the most successful startup companies around the world.','Responsibilities:\n\nAutomated testing of web and mobile applications\nDevelop automated scenarios/scripts using Cucumber (for web applications) and Calabash (for mobile applications)\nOptimize existing test cases to get more stability and efficiency\nRun automated functional tests as well as performance and load tests\nAnalyze automated test results and report bugs to responsible employees\nSupport the test automation team during the whole development process (starting from the analysis of requirements up to the integration of automated test cases into the CI system (Jenkins)\n\n\nRequirements:\n\nSeveral years of experience as a Test Automation Engineer ( 5+ years )\nExperience with automated solutions such as Cucumber/Calabash, Gherkin, Selenium or similar tools/frameworks\nExperience with Ruby, Python, PHP, JAVA or similar programming languages\nExperience with source code controls like SVN, GIT, CVS\nFamiliarity with Continuous Integration and Delivery\nExperience in Agile Methodologies like Scrum and Kanban or extreme programming\nFluency in speaking & writing English skills\nISTQB certification\n Technology stack we use:\n\nTools: GitHub, Jira, Confluence, Bamboo, Jenkins, Testlink\nScrum, Kanban\nCucumber, Calabash, Capybara, JMeter','[\"Life insurance\"]',80,3,NULL,'JC002',3,NULL,5,14,6,151,'Yes',4000,4500,'','Active','0000-00-00 00:00:00',NULL,'Text Only',1),
|
||||||
|
(3,'Online Editor','Online Editors required for a reputed news agency','Online Editors required for a reputed news agency','','[]',129,NULL,NULL,'J0003',1,NULL,7,23,9,103,'No',0,0,'','Active','0001-01-01 00:00:00','attachment_BI5XQCYFxZO12W1447383181684','Image and Full Text',1);
|
||||||
|
|
||||||
|
INSERT INTO `Candidates` VALUES
|
||||||
|
(1,'Jhon','Doe',4,NULL,'Male',NULL,NULL,NULL,'New York','US',NULL,NULL,'icehrm+jhon@web-stalk.com','+1 455565656',NULL,'Software Engineer','cv_rYwHphV7xD5dOe1444302569136',NULL,NULL,NULL,'','','','','','',NULL,NULL,NULL,NULL,NULL,NULL,'2015-10-08 16:59:20','2015-10-08 16:59:20',0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,'663fd20d1859344585f678a0f87b23522b8f9fce8c67c5290a609ce342b81442',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);
|
||||||
|
|
||||||
|
INSERT INTO `Files` VALUES
|
||||||
|
(6,'attachment_BI5XQCYFxZO12W1447383181684','attachment_BI5XQCYFxZO12W1447383181684.png',1,'Job');
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `EmployeeDocuments` (`id`,`employee`, `document`, `date_added`, `valid_until`, `status`, `details`, `attachment`, `expire_notification_last`) VALUES
|
||||||
|
(1, 1, 1, CURDATE(), DATE_ADD(CURDATE(), INTERVAL 30 DAY), 'Active', '', NULL, -1),
|
||||||
|
(2, 1, 2, CURDATE(), DATE_ADD(CURDATE(), INTERVAL 7 DAY), 'Active', '', NULL, -1),
|
||||||
|
(3, 1, 3, CURDATE(), DATE_ADD(CURDATE(), INTERVAL 1 DAY), 'Active', '', NULL, -1);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
INSERT INTO `Attendance` (`employee`,`in_time`,`out_time`,`note`) VALUES
|
INSERT INTO `Attendance` (`employee`,`in_time`,`out_time`,`note`) VALUES
|
||||||
(1, FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 30 DAY))) + FLOOR(28800 + (RAND() * 3600)),'%Y-%m-%d %T'), FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 30 DAY))) + FLOOR(57600 + (RAND() * 21600)),'%Y-%m-%d %T'), ''),
|
(1, FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 30 DAY))) + FLOOR(28800 + (RAND() * 3600)),'%Y-%m-%d %T'), FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 30 DAY))) + FLOOR(57600 + (RAND() * 21600)),'%Y-%m-%d %T'), ''),
|
||||||
@@ -115,8 +201,98 @@ INSERT INTO `Attendance` (`employee`,`in_time`,`out_time`,`note`) VALUES
|
|||||||
(3, FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 23 DAY))) + FLOOR(28800 + (RAND() * 3600)),'%Y-%m-%d %T'), FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 23 DAY))) + FLOOR(57600 + (RAND() * 21600)),'%Y-%m-%d %T'), ''),
|
(3, FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 23 DAY))) + FLOOR(28800 + (RAND() * 3600)),'%Y-%m-%d %T'), FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 23 DAY))) + FLOOR(57600 + (RAND() * 21600)),'%Y-%m-%d %T'), ''),
|
||||||
(3, FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 22 DAY))) + FLOOR(28800 + (RAND() * 3600)),'%Y-%m-%d %T'), FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 22 DAY))) + FLOOR(57600 + (RAND() * 21600)),'%Y-%m-%d %T'), '');
|
(3, FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 22 DAY))) + FLOOR(28800 + (RAND() * 3600)),'%Y-%m-%d %T'), FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 22 DAY))) + FLOOR(57600 + (RAND() * 21600)),'%Y-%m-%d %T'), '');
|
||||||
|
|
||||||
|
INSERT INTO `PayslipTemplates` (`id`, `name`, `data`, `status`, `created`, `updated`) VALUES
|
||||||
|
(1, 'Basic', '[{"type":"Company Logo","payrollColumn":"NULL","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"#000000","status":"Show","id":"data_1"},{"type":"Company Name","payrollColumn":"NULL","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_2"},{"type":"Separators","payrollColumn":"NULL","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_8"},{"type":"Payroll Column","payrollColumn":"5","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_3"},{"type":"Payroll Column","payrollColumn":"6","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_4"},{"type":"Payroll Column","payrollColumn":"17","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_5"},{"type":"Separators","payrollColumn":"NULL","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_9"},{"type":"Payroll Column","payrollColumn":"18","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_6"},{"type":"Separators","payrollColumn":"NULL","label":"","text":"","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_10"},{"type":"Text","payrollColumn":"NULL","label":"","text":"Big Company Ltd. is a limited company registered in England and Wales. Registered number: 1234567. Registered office: 123 Some Street, Somewhere, Someshire.","fontSize":"Normal","fontStyle":"Normal","fontColor":"","status":"Show","id":"data_7"}]', NULL, '2016-06-30 03:37:12', '2016-06-30 03:37:12');
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `Payroll` VALUES
|
||||||
|
(1,'2016-03',4,1,1,'[\"5\",\"8\",\"9\",\"10\",\"6\",\"7\",\"4\",\"3\",\"2\",\"1\",\"11\",\"12\",\"13\",\"14\",\"15\",\"16\"]','2016-03-01','2016-03-31','Draft', 1),
|
||||||
|
(2,'2016-03-Weekly',2,1,2,'[\"1\",\"2\",\"3\"]','2016-03-01','2016-03-31','Draft', 1);
|
||||||
|
|
||||||
|
INSERT INTO `PayrollColumns` VALUES
|
||||||
|
(5,'Basic Salary',NULL,'[\"1\"]','[]','[]','[]',5,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(6,'Fixed Allowance',NULL,'[\"2\"]','[]','[]','[]',6,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(7,'Gross Pay',NULL,'[]','[]','[\"5\",\"6\"]','[]',7,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(8,'EPF Employee Contribution',NULL,'[]','[\"1\"]','[]','[]',8,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(9,'EPF Employer Contribution',NULL,'[]','[\"2\"]','[]','[]',9,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(10,'ETF Employee Contribution',NULL,'[]','[\"3\"]','[]','[]',10,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(11,'Total EPF 20%',NULL,'[]','[]','[\"8\",\"9\"]','[]',11,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(12,'Total for PAYE',NULL,'[]','[]','[\"7\"]','[]',12,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(13,'PAYE Tax',NULL,'[]','[\"4\"]','[]','[]',13,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(14,'Stamp Duty',NULL,'[]','[\"5\"]','[]','[]',14,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(15,'Total Deductions',NULL,'[]','[]','[\"8\",\"13\",\"14\"]','[]',15,'No','Yes','0.00',NULL,NULL),
|
||||||
|
(16,'Salary to Bank',NULL,'[]','[]','[\"7\"]','[\"15\"]',16,'No','Yes','0.00',NULL,NULL);
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `DeductionGroup` VALUES
|
||||||
|
(1,'Sri Lanka Payroll Calculation',''),
|
||||||
|
(2,'Singapore Payroll Calculation','');
|
||||||
|
|
||||||
|
INSERT INTO `Deductions` VALUES
|
||||||
|
(1,'EPF Employee Contribution','[]','[]',7,'[{\"lowerCondition\":\"No Lower Limit\",\"lowerLimit\":\"0\",\"upperCondition\":\"No Upper Limit\",\"upperLimit\":\"0\",\"amount\":\"X*0.08\",\"id\":\"rangeAmounts_1\"}]',1),
|
||||||
|
(2,'EPF Employer Contribution','[]','[]',7,'[{\"lowerCondition\":\"No Lower Limit\",\"lowerLimit\":\"0\",\"upperCondition\":\"No Upper Limit\",\"upperLimit\":\"0\",\"amount\":\"X*0.12\",\"id\":\"rangeAmounts_1\"}]',1),
|
||||||
|
(3,'ETF Employee Contribution','[]','[]',7,'[{\"lowerCondition\":\"No Lower Limit\",\"lowerLimit\":\"0\",\"upperCondition\":\"No Upper Limit\",\"upperLimit\":\"0\",\"amount\":\"X*0.03\",\"id\":\"rangeAmounts_1\"}]',1),
|
||||||
|
(4,'PAYE Tax','[]','[]',12,'[{\"lowerCondition\":\"No Lower Limit\",\"lowerLimit\":\"0\",\"upperCondition\":\"lte\",\"upperLimit\":\"62500\",\"amount\":\"0\",\"id\":\"rangeAmounts_1\"},{\"lowerCondition\":\"gt\",\"lowerLimit\":\"62500\",\"upperCondition\":\"lte\",\"upperLimit\":\"104167\",\"amount\":\"X*0.04 - 2500\",\"id\":\"rangeAmounts_2\"},{\"lowerCondition\":\"gt\",\"lowerLimit\":\"104167\",\"upperCondition\":\"lte\",\"upperLimit\":\"145833\",\"amount\":\"X*0.08 - 6667\",\"id\":\"rangeAmounts_3\"},{\"lowerCondition\":\"gt\",\"lowerLimit\":\"145833\",\"upperCondition\":\"lte\",\"upperLimit\":\"187500\",\"amount\":\"X*0.12-12500\",\"id\":\"rangeAmounts_4\"},{\"lowerCondition\":\"gt\",\"lowerLimit\":\"187500\",\"upperCondition\":\"No Upper Limit\",\"upperLimit\":\"0\",\"amount\":\"X*0.16 - 20000\",\"id\":\"rangeAmounts_5\"}]',1),
|
||||||
|
(5,'Stamp Duty','[]','[]',12,'[{\"lowerCondition\":\"No Lower Limit\",\"lowerLimit\":\"0\",\"upperCondition\":\"lte\",\"upperLimit\":\"25000\",\"amount\":\"0\",\"id\":\"rangeAmounts_1\"},{\"lowerCondition\":\"gt\",\"lowerLimit\":\"25000\",\"upperCondition\":\"No Upper Limit\",\"upperLimit\":\"0\",\"amount\":\"25\",\"id\":\"rangeAmounts_2\"}]',1);
|
||||||
|
|
||||||
|
INSERT INTO `PayrollEmployees` VALUES
|
||||||
|
(1,1,4,151,'[]','[]',1),
|
||||||
|
(2,2,4,151,'[]','[]',1),
|
||||||
|
(3,3,4,151,'[]','[]',1),
|
||||||
|
(4,4,2,151,'[]','[]',1),
|
||||||
|
(5,5,2,151,'[]','[]',1),
|
||||||
|
(6,6,4,151,'[]','[]',1),
|
||||||
|
(7,7,4,151,'[]','[]',1),
|
||||||
|
(8,8,4,151,'[]','[]',1),
|
||||||
|
(9,9,4,151,'[]','[]',1),
|
||||||
|
(10,10,4,151,'[]','[]',1);
|
||||||
|
|
||||||
|
INSERT INTO `EmployeeLeaves` VALUES
|
||||||
|
(1,1,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 3 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 3 DAY))),'%Y-%m-%d'),'Test Reason 1','Pending',''),
|
||||||
|
(2,1,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 4 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 4 DAY))),'%Y-%m-%d'),'Test Reason 2','Approved',''),
|
||||||
|
(3,2,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 3 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 3 DAY))),'%Y-%m-%d'),'Test Reason 3','Approved',''),
|
||||||
|
|
||||||
|
(4,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 8 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 8 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(5,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 9 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 9 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(6,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 10 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 10 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(7,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 11 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 11 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(8,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 12 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 12 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(9,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 13 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 13 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(10,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 14 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 14 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(11,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 15 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 15 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(12,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 16 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 16 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(13,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 17 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 17 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(14,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 18 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 18 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(15,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 19 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 19 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(16,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 20 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 20 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(17,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 21 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 21 DAY))),'%Y-%m-%d'),'Test Reason 4','Pending',''),
|
||||||
|
(18,3,1,4,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 22 DAY))),'%Y-%m-%d'),FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 22 DAY))),'%Y-%m-%d'),'Test Reason 22','Pending','');
|
||||||
|
|
||||||
|
INSERT INTO `EmployeeLeaveDays` VALUES
|
||||||
|
(1,1,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 3 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(2,1,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 4 DAY))),'%Y-%m-%d'),'Half Day - Morning'),
|
||||||
|
(3,2,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 3 DAY))),'%Y-%m-%d'),'Half Day - Morning'),
|
||||||
|
|
||||||
|
(4,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 8 DAY))),'%Y-%m-%d'),'3 Hours - Morning'),
|
||||||
|
(5,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 9 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(6,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 10 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(7,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 11 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(8,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 12 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(9,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 13 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(10,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 14 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(11,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 15 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(12,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 16 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(13,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 17 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(14,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 18 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(15,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 19 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(16,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 20 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(17,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 21 DAY))),'%Y-%m-%d'),'Full Day'),
|
||||||
|
(18,3,FROM_UNIXTIME((UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL 22 DAY))),'%Y-%m-%d'),'Full Day');
|
||||||
|
|
||||||
|
INSERT INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('Instance : ID', '0847429146712c108e23c435e8f93b4d', '',''),
|
||||||
|
('Instance: Key', 'UQHEYBx9H1eNR66nhNCNCz1WCDDhkjtx1OuJbO3ZQMt+8tfSGvuOH/YEHntRajY=', '','');
|
||||||
|
|
||||||
|
|
||||||
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
|
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
|
||||||
|
|
||||||
@@ -125,11 +301,3 @@ INSERT INTO `Attendance` (`employee`,`in_time`,`out_time`,`note`) VALUES
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ create table `CompanyStructures` (
|
|||||||
`country` varchar(2) not null default '0',
|
`country` varchar(2) not null default '0',
|
||||||
`parent` bigint(20) NULL,
|
`parent` bigint(20) NULL,
|
||||||
`timezone` varchar(100) not null default 'Europe/London',
|
`timezone` varchar(100) not null default 'Europe/London',
|
||||||
|
`heads` varchar(255) NULL default NULL,
|
||||||
CONSTRAINT `Fk_CompanyStructures_Own` FOREIGN KEY (`parent`) REFERENCES `CompanyStructures` (`id`),
|
CONSTRAINT `Fk_CompanyStructures_Own` FOREIGN KEY (`parent`) REFERENCES `CompanyStructures` (`id`),
|
||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
@@ -93,12 +94,25 @@ create table `Languages` (
|
|||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `SupportedLanguages` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) default null,
|
||||||
|
`description` varchar(100) default null,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
create table `Nationality` (
|
create table `Nationality` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`name` varchar(100) default null,
|
`name` varchar(100) default null,
|
||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
CREATE TABLE `PayFrequency` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(200) NOT NULL,
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB default charset=utf8;
|
||||||
|
|
||||||
create table `Employees` (
|
create table `Employees` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`employee_id` varchar(50) default null,
|
`employee_id` varchar(50) default null,
|
||||||
@@ -106,7 +120,7 @@ create table `Employees` (
|
|||||||
`middle_name` varchar(100) default null,
|
`middle_name` varchar(100) default null,
|
||||||
`last_name` varchar(100) default null,
|
`last_name` varchar(100) default null,
|
||||||
`nationality` bigint(20) default null,
|
`nationality` bigint(20) default null,
|
||||||
`birthday` DATETIME default '0000-00-00 00:00:00',
|
`birthday` date default '0000-00-00',
|
||||||
`gender` enum('Male','Female') default NULL,
|
`gender` enum('Male','Female') default NULL,
|
||||||
`marital_status` enum('Married','Single','Divorced','Widowed','Other') default NULL,
|
`marital_status` enum('Married','Single','Divorced','Widowed','Other') default NULL,
|
||||||
`ssn_num` varchar(100) default NULL,
|
`ssn_num` varchar(100) default NULL,
|
||||||
@@ -129,9 +143,10 @@ create table `Employees` (
|
|||||||
`work_phone` varchar(50) default null,
|
`work_phone` varchar(50) default null,
|
||||||
`work_email` varchar(100) default null,
|
`work_email` varchar(100) default null,
|
||||||
`private_email` varchar(100) default null,
|
`private_email` varchar(100) default null,
|
||||||
`joined_date` DATETIME default '0000-00-00 00:00:00',
|
`joined_date` date default '0000-00-00',
|
||||||
`confirmation_date` DATETIME default '0000-00-00 00:00:00',
|
`confirmation_date` date default '0000-00-00',
|
||||||
`supervisor` bigint(20) default null,
|
`supervisor` bigint(20) default null,
|
||||||
|
`indirect_supervisors` varchar(250) default null,
|
||||||
`department` bigint(20) default null,
|
`department` bigint(20) default null,
|
||||||
`custom1` varchar(250) default null,
|
`custom1` varchar(250) default null,
|
||||||
`custom2` varchar(250) default null,
|
`custom2` varchar(250) default null,
|
||||||
@@ -143,11 +158,14 @@ create table `Employees` (
|
|||||||
`custom8` varchar(250) default null,
|
`custom8` varchar(250) default null,
|
||||||
`custom9` varchar(250) default null,
|
`custom9` varchar(250) default null,
|
||||||
`custom10` varchar(250) default null,
|
`custom10` varchar(250) default null,
|
||||||
`termination_date` DATETIME default '0000-00-00 00:00:00',
|
`termination_date` date default '0000-00-00',
|
||||||
`notes` text default null,
|
`notes` text default null,
|
||||||
`status` enum('Active','Terminated') default 'Active',
|
`status` enum('Active','Terminated') default 'Active',
|
||||||
`ethnicity` bigint(20) default null,
|
`ethnicity` bigint(20) default null,
|
||||||
`immigration_status` bigint(20) default null,
|
`immigration_status` bigint(20) default null,
|
||||||
|
`approver1` bigint(20) default null,
|
||||||
|
`approver2` bigint(20) default null,
|
||||||
|
`approver3` bigint(20) default null,
|
||||||
CONSTRAINT `Fk_Employee_Nationality` FOREIGN KEY (`nationality`) REFERENCES `Nationality` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
CONSTRAINT `Fk_Employee_Nationality` FOREIGN KEY (`nationality`) REFERENCES `Nationality` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
CONSTRAINT `Fk_Employee_JobTitle` FOREIGN KEY (`job_title`) REFERENCES `JobTitles` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
CONSTRAINT `Fk_Employee_JobTitle` FOREIGN KEY (`job_title`) REFERENCES `JobTitles` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
CONSTRAINT `Fk_Employee_EmploymentStatus` FOREIGN KEY (`employment_status`) REFERENCES `EmploymentStatus` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
CONSTRAINT `Fk_Employee_EmploymentStatus` FOREIGN KEY (`employment_status`) REFERENCES `EmploymentStatus` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
@@ -161,6 +179,7 @@ create table `Employees` (
|
|||||||
|
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
create table `ArchivedEmployees` (
|
create table `ArchivedEmployees` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`ref_id` bigint(20) NOT NULL,
|
`ref_id` bigint(20) NOT NULL,
|
||||||
@@ -202,12 +221,18 @@ create table `Users` (
|
|||||||
`last_login` timestamp default '0000-00-00 00:00:00',
|
`last_login` timestamp default '0000-00-00 00:00:00',
|
||||||
`last_update` timestamp default '0000-00-00 00:00:00',
|
`last_update` timestamp default '0000-00-00 00:00:00',
|
||||||
`created` timestamp default '0000-00-00 00:00:00',
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
`login_hash` varchar(64) default null,
|
||||||
|
`lang` bigint(20) default null,
|
||||||
CONSTRAINT `Fk_User_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
CONSTRAINT `Fk_User_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_User_SupportedLanguages` FOREIGN KEY (`lang`) REFERENCES `SupportedLanguages` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
primary key (`id`),
|
primary key (`id`),
|
||||||
unique key `username` (`username`)
|
unique key `username` (`username`),
|
||||||
|
INDEX login_hash_index (`login_hash`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
create table `EmployeeSkills` (
|
create table `EmployeeSkills` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`skill_id` bigint(20) NULL,
|
`skill_id` bigint(20) NULL,
|
||||||
@@ -284,6 +309,134 @@ create table `EmployeeDependents` (
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
create table `LeaveTypes` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`supervisor_leave_assign` enum('Yes','No') default 'Yes',
|
||||||
|
`employee_can_apply` enum('Yes','No') default 'Yes',
|
||||||
|
`apply_beyond_current` enum('Yes','No') default 'Yes',
|
||||||
|
`leave_accrue` enum('No','Yes') default 'No',
|
||||||
|
`carried_forward` enum('No','Yes') default 'No',
|
||||||
|
`default_per_year` decimal(10,3) NOT NULL,
|
||||||
|
`carried_forward_percentage` int(11) NULL default 0,
|
||||||
|
`carried_forward_leave_availability` int(11) NULL default 365,
|
||||||
|
`propotionate_on_joined_date` enum('No','Yes') default 'No',
|
||||||
|
`send_notification_emails` enum('Yes','No') default 'Yes',
|
||||||
|
`leave_group` bigint(20) NULL,
|
||||||
|
`leave_color` varchar(10) NULL,
|
||||||
|
`max_carried_forward_amount` int(11) NULL default 0,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key (`name`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `LeaveRules` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`leave_type` bigint(20) NOT NULL,
|
||||||
|
`job_title` bigint(20) NULL,
|
||||||
|
`employment_status` bigint(20) NULL,
|
||||||
|
`employee` bigint(20) NULL,
|
||||||
|
`supervisor_leave_assign` enum('Yes','No') default 'Yes',
|
||||||
|
`employee_can_apply` enum('Yes','No') default 'Yes',
|
||||||
|
`apply_beyond_current` enum('Yes','No') default 'Yes',
|
||||||
|
`leave_accrue` enum('No','Yes') default 'No',
|
||||||
|
`carried_forward` enum('No','Yes') default 'No',
|
||||||
|
`default_per_year` decimal(10,3) NOT NULL,
|
||||||
|
`carried_forward_percentage` int(11) NULL default 0,
|
||||||
|
`carried_forward_leave_availability` int(11) NULL default 365,
|
||||||
|
`propotionate_on_joined_date` enum('No','Yes') default 'No',
|
||||||
|
`leave_group` bigint(20) NULL,
|
||||||
|
`max_carried_forward_amount` int(11) NULL default 0,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `LeaveGroups` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`details` text default null,
|
||||||
|
`created` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `LeaveGroupEmployees` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`leave_group` bigint(20) NOT NULL,
|
||||||
|
`created` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
CONSTRAINT `Fk_LeaveGroupEmployees_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_LeaveGroupEmployees_LeaveGroups` FOREIGN KEY (`leave_group`) REFERENCES `LeaveGroups` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key `LeaveGroupEmployees_employee` (`employee`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `LeavePeriods` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`date_start` date default '0000-00-00',
|
||||||
|
`date_end` date default '0000-00-00',
|
||||||
|
`status` enum('Active','Inactive') default 'Inactive',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `WorkDays` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`status` enum('Full Day','Half Day','Non-working Day') default 'Full Day',
|
||||||
|
`country` bigint(20) DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key `workdays_name_country` (`name`,`country`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `HoliDays` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`dateh` date default '0000-00-00',
|
||||||
|
`status` enum('Full Day','Half Day') default 'Full Day',
|
||||||
|
`country` bigint(20) DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key `holidays_dateh_country` (`dateh`,`country`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EmployeeLeaves` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`leave_type` bigint(20) NOT NULL,
|
||||||
|
`leave_period` bigint(20) NOT NULL,
|
||||||
|
`date_start` date default '0000-00-00',
|
||||||
|
`date_end` date default '0000-00-00',
|
||||||
|
`details` text default null,
|
||||||
|
`status` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled','Processing') default 'Pending',
|
||||||
|
`attachment` varchar(100) NULL,
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaves_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaves_LeaveTypes` FOREIGN KEY (`leave_type`) REFERENCES `LeaveTypes` (`id`),
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaves_LeavePeriods` FOREIGN KEY (`leave_period`) REFERENCES `LeavePeriods` (`id`),
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EmployeeLeaveLog` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee_leave` bigint(20) NOT NULL,
|
||||||
|
`user_id` bigint(20) NULL,
|
||||||
|
`data` varchar(500) NOT NULL,
|
||||||
|
`status_from` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled','Processing') default 'Pending',
|
||||||
|
`status_to` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled','Processing') default 'Pending',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaveLog_EmployeeLeaves` FOREIGN KEY (`employee_leave`) REFERENCES `EmployeeLeaves` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaveLog_Users` FOREIGN KEY (`user_id`) REFERENCES `Users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EmployeeLeaveDays` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee_leave` bigint(20) NOT NULL,
|
||||||
|
`leave_date` date default '0000-00-00',
|
||||||
|
`leave_type` enum('Full Day','Half Day - Morning','Half Day - Afternoon','1 Hour - Morning','2 Hours - Morning','3 Hours - Morning','1 Hour - Afternoon','2 Hours - Afternoon','3 Hours - Afternoon') NOT NULL,
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaveDays_EmployeeLeaves` FOREIGN KEY (`employee_leave`) REFERENCES `EmployeeLeaves` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
create table `Files` (
|
create table `Files` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`name` varchar(100) NOT NULL,
|
`name` varchar(100) NOT NULL,
|
||||||
@@ -314,7 +467,7 @@ create table `Projects` (
|
|||||||
`client` bigint(20) NULL,
|
`client` bigint(20) NULL,
|
||||||
`details` text default null,
|
`details` text default null,
|
||||||
`created` timestamp default '0000-00-00 00:00:00',
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
`status` enum('Active','Inactive') default 'Active',
|
`status` enum('Active','On Hold','Completed', 'Dropped') default 'Active',
|
||||||
CONSTRAINT `Fk_Projects_Client` FOREIGN KEY (`client`) REFERENCES `Clients` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
CONSTRAINT `Fk_Projects_Client` FOREIGN KEY (`client`) REFERENCES `Clients` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
@@ -365,8 +518,52 @@ create table `EmployeeTimeEntry` (
|
|||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Documents` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`details` text default null,
|
||||||
|
`expire_notification` enum('Yes','No') default 'Yes',
|
||||||
|
`expire_notification_month` enum('Yes','No') default 'Yes',
|
||||||
|
`expire_notification_week` enum('Yes','No') default 'Yes',
|
||||||
|
`expire_notification_day` enum('Yes','No') default 'Yes',
|
||||||
|
`sign` enum('Yes','No') default 'Yes',
|
||||||
|
`sign_label` VARCHAR(500) default null,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `EmployeeDocuments` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`document` bigint(20) NULL,
|
||||||
|
`date_added` date NOT NULL,
|
||||||
|
`valid_until` date NOT NULL,
|
||||||
|
`status` enum('Active','Inactive','Draft') default 'Active',
|
||||||
|
`details` text default null,
|
||||||
|
`attachment` varchar(100) NULL,
|
||||||
|
`signature` text default null,
|
||||||
|
`expire_notification_last` int(4) NULL,
|
||||||
|
CONSTRAINT `Fk_EmployeeDocuments_Documents` FOREIGN KEY (`document`) REFERENCES `Documents` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeDocuments_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`),
|
||||||
|
KEY `KEY_EmployeeDocuments_valid_until` (`valid_until`),
|
||||||
|
KEY `KEY_EmployeeDocuments_valid_until_status` (`valid_until`,`status`,`expire_notification_last`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `CompanyDocuments` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`details` text default null,
|
||||||
|
`valid_until` date NOT NULL,
|
||||||
|
`status` enum('Active','Inactive','Draft') default 'Active',
|
||||||
|
`notify_employees` enum('Yes','No') default 'Yes',
|
||||||
|
`attachment` varchar(100) NULL,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
create table `CompanyLoans` (
|
create table `CompanyLoans` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`name` varchar(100) NOT NULL,
|
`name` varchar(100) NOT NULL,
|
||||||
@@ -428,6 +625,7 @@ create table `Reports` (
|
|||||||
`paramOrder` varchar(500) NOT NULL,
|
`paramOrder` varchar(500) NOT NULL,
|
||||||
`type` enum('Query','Class') default 'Query',
|
`type` enum('Query','Class') default 'Query',
|
||||||
`report_group` varchar(500) NULL,
|
`report_group` varchar(500) NULL,
|
||||||
|
`output` varchar(15) NOT NULL default 'CSV',
|
||||||
primary key (`id`),
|
primary key (`id`),
|
||||||
UNIQUE KEY `Reports_Name` (`name`)
|
UNIQUE KEY `Reports_Name` (`name`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
@@ -496,6 +694,56 @@ create table `Notifications` (
|
|||||||
KEY `toUser_status_time` (`toUser`,`status`,`time`)
|
KEY `toUser_status_time` (`toUser`,`status`,`time`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Courses` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`code` varchar(300) NOT NULL,
|
||||||
|
`name` varchar(300) NOT NULL,
|
||||||
|
`description` text default null,
|
||||||
|
`coordinator` bigint(20) NULL,
|
||||||
|
`trainer` varchar(300) NULL,
|
||||||
|
`trainer_info` text default null,
|
||||||
|
`paymentType` enum('Company Sponsored','Paid by Employee') default 'Company Sponsored',
|
||||||
|
`currency` varchar(3) null,
|
||||||
|
`cost` decimal(12,2) DEFAULT 0.00,
|
||||||
|
`status` enum('Active','Inactive') default 'Active',
|
||||||
|
`created` datetime default '0000-00-00 00:00:00',
|
||||||
|
`updated` datetime default '0000-00-00 00:00:00',
|
||||||
|
CONSTRAINT `Fk_Courses_Employees` FOREIGN KEY (`coordinator`) REFERENCES `Employees` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `TrainingSessions` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(300) NOT NULL,
|
||||||
|
`course` bigint(20) NOT NULL,
|
||||||
|
`description` text default null,
|
||||||
|
`scheduled` datetime default '0000-00-00 00:00:00',
|
||||||
|
`dueDate` datetime default '0000-00-00 00:00:00',
|
||||||
|
`deliveryMethod` enum('Classroom','Self Study','Online') default 'Classroom',
|
||||||
|
`deliveryLocation` varchar(500) NULL,
|
||||||
|
`status` enum('Pending','Approved','Completed','Cancelled') default 'Pending',
|
||||||
|
`attendanceType` enum('Sign Up','Assign') default 'Sign Up',
|
||||||
|
`attachment` varchar(300) NULL,
|
||||||
|
`created` datetime default '0000-00-00 00:00:00',
|
||||||
|
`updated` datetime default '0000-00-00 00:00:00',
|
||||||
|
`requireProof` enum('Yes','No') default 'Yes',
|
||||||
|
CONSTRAINT `Fk_TrainingSessions_Courses` FOREIGN KEY (`course`) REFERENCES `Courses` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `EmployeeTrainingSessions` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`trainingSession` bigint(20) NULL,
|
||||||
|
`feedBack` varchar(1500) NULL,
|
||||||
|
`status` enum('Scheduled','Attended','Not-Attended','Completed') default 'Scheduled',
|
||||||
|
`proof` varchar(300) NULL,
|
||||||
|
CONSTRAINT `Fk_EmployeeTrainingSessions_TrainingSessions` FOREIGN KEY (`trainingSession`) REFERENCES `TrainingSessions` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeTrainingSessions_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
create table `ImmigrationDocuments` (
|
create table `ImmigrationDocuments` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
@@ -546,7 +794,7 @@ create table `EmployeeTravelRecords` (
|
|||||||
`attachment3` varchar(100) NULL,
|
`attachment3` varchar(100) NULL,
|
||||||
`created` timestamp NULL default '0000-00-00 00:00:00',
|
`created` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
`status` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled') default 'Pending',
|
`status` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled','Processing') default 'Pending',
|
||||||
CONSTRAINT `Fk_EmployeeTravelRecords_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
CONSTRAINT `Fk_EmployeeTravelRecords_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
@@ -584,7 +832,14 @@ create table `CustomFields` (
|
|||||||
`display` enum('Form','Table and Form','Hidden') default 'Form',
|
`display` enum('Form','Table and Form','Hidden') default 'Form',
|
||||||
`created` DATETIME default '0000-00-00 00:00:00',
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
`updated` DATETIME default '0000-00-00 00:00:00',
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
primary key (`id`)
|
`field_type` varchar(20) NULL,
|
||||||
|
`field_label` varchar(50) NULL,
|
||||||
|
`field_validation` varchar(50) NULL,
|
||||||
|
`field_options` varchar(500) NULL,
|
||||||
|
`display_order` int(11) default 0,
|
||||||
|
`display_section` varchar(50) NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key `CustomFields_name` (`type`,`name`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
@@ -648,67 +903,285 @@ create table `EmployeeSalary` (
|
|||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `DeductionGroup` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`description` varchar(100) NOT NULL,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
create table `Deductions` (
|
create table `Deductions` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`name` varchar(100) NOT NULL,
|
`name` varchar(100) NOT NULL,
|
||||||
`contributor` enum('Employee','Employer') default NULL,
|
`componentType` varchar(250) NULL,
|
||||||
`type` enum('Fixed','Percentage') default NULL,
|
`component` varchar(250) NULL,
|
||||||
`percentage_type` enum('On Component','On Component Type') default NULL,
|
`payrollColumn` int(11) DEFAULT NULL,
|
||||||
`componentType` bigint(20) NULL,
|
|
||||||
`component` bigint(20) NULL,
|
|
||||||
`rangeAmounts` text default null,
|
`rangeAmounts` text default null,
|
||||||
`country` bigint(20) NULL,
|
`deduction_group` bigint(20) NULL,
|
||||||
CONSTRAINT `Fk_Deductions_Country` FOREIGN KEY (`country`) REFERENCES `Country` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
CONSTRAINT `Fk_Deductions_DeductionGroup` FOREIGN KEY (`deduction_group`) REFERENCES `DeductionGroup` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
create table `Tax` (
|
|
||||||
|
|
||||||
|
|
||||||
|
create table `PayrollEmployees` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`name` varchar(100) NOT NULL,
|
`employee` bigint(20) NOT NULL,
|
||||||
`contributor` enum('Employee','Employer') default NULL,
|
`pay_frequency` int(11) default null,
|
||||||
`type` enum('Fixed','Percentage') default NULL,
|
`currency` bigint(20) NULL,
|
||||||
`percentage_type` enum('On Component','On Component Type') default NULL,
|
`deduction_exemptions` varchar(250) default null,
|
||||||
`componentType` bigint(20) NULL,
|
`deduction_allowed` varchar(250) default null,
|
||||||
`component` bigint(20) NULL,
|
`deduction_group` bigint(20) NULL,
|
||||||
`rangeAmounts` text default null,
|
CONSTRAINT `Fk_PayrollEmployee_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
`country` bigint(20) NULL,
|
CONSTRAINT `Fk_PayrollEmployees_DeductionGroup` FOREIGN KEY (`deduction_group`) REFERENCES `DeductionGroup` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
CONSTRAINT `Fk_Tax_Country` FOREIGN KEY (`country`) REFERENCES `Country` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
primary key (`id`),
|
||||||
primary key (`id`)
|
unique key `PayrollEmployees_employee` (`employee`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
create table `TaxRules` (
|
CREATE TABLE `PayrollColumnTemplates` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`apply` enum('Yes','No') default 'Yes',
|
`name` varchar(50) DEFAULT NULL,
|
||||||
`application_type` enum('All','Condition - OR','Condition - AND') default 'All',
|
`columns` varchar(500) DEFAULT NULL,
|
||||||
`tax` bigint(20) NOT NULL,
|
PRIMARY KEY (`id`)
|
||||||
`job_title` bigint(20) NULL,
|
) ENGINE=InnoDB default charset=utf8;
|
||||||
`ethnicity` bigint(20) NULL,
|
|
||||||
`nationality` bigint(20) NULL,
|
|
||||||
`immigration_status` bigint(20) NULL,
|
|
||||||
`pay_grade` bigint(20) NULL,
|
|
||||||
`country` bigint(20) NULL,
|
|
||||||
CONSTRAINT `Fk_TaxRules_Tax` FOREIGN KEY (`tax`) REFERENCES `Tax` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
|
||||||
CONSTRAINT `Fk_TaxRules_Country` FOREIGN KEY (`country`) REFERENCES `Country` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
|
||||||
primary key (`id`)
|
|
||||||
) engine=innodb default charset=utf8;
|
|
||||||
|
|
||||||
create table `DeductionRules` (
|
create table `Payroll` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`apply` enum('Yes','No') default 'Yes',
|
`name` varchar(200) NULL,
|
||||||
`application_type` enum('All','Condition - OR','Condition - AND') default 'All',
|
`pay_period` bigint(20) NOT NULL,
|
||||||
`deduction` bigint(20) NOT NULL,
|
`department` bigint(20) NOT NULL,
|
||||||
`job_title` bigint(20) NULL,
|
`column_template` bigint(20) NULL,
|
||||||
`ethnicity` bigint(20) NULL,
|
`columns` varchar(500) DEFAULT NULL,
|
||||||
`nationality` bigint(20) NULL,
|
`date_start` DATE NULL default '0000-00-00',
|
||||||
`immigration_status` bigint(20) NULL,
|
`date_end` DATE NULL default '0000-00-00',
|
||||||
`pay_grade` bigint(20) NULL,
|
`status` enum('Draft','Completed','Processing') default 'Draft',
|
||||||
`country` bigint(20) NULL,
|
`payslipTemplate` bigint(20) NULL,
|
||||||
CONSTRAINT `Fk_DeductionRules_Deductions` FOREIGN KEY (`deduction`) REFERENCES `Deductions` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
|
||||||
CONSTRAINT `Fk_DeductionRules_Country` FOREIGN KEY (`country`) REFERENCES `Country` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
|
||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE `PayrollData` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`payroll` bigint(20) NOT NULL,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`payroll_item` int(11) NOT NULL,
|
||||||
|
`amount` varchar(25) DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
UNIQUE KEY `PayrollDataUniqueKey` (`payroll`,`employee`,`payroll_item`),
|
||||||
|
CONSTRAINT `Fk_PayrollData_Payroll` FOREIGN KEY (`payroll`) REFERENCES `Payroll` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) ENGINE=InnoDB default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE `PayrollColumns` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(50) DEFAULT NULL,
|
||||||
|
`calculation_hook` varchar(200) DEFAULT NULL,
|
||||||
|
`salary_components` varchar(500) DEFAULT NULL,
|
||||||
|
`deductions` varchar(500) DEFAULT NULL,
|
||||||
|
`add_columns` varchar(500) DEFAULT NULL,
|
||||||
|
`sub_columns` varchar(500) DEFAULT NULL,
|
||||||
|
`colorder` int(11) DEFAULT NULL,
|
||||||
|
`editable` enum('Yes','No') default 'Yes',
|
||||||
|
`enabled` enum('Yes','No') default 'Yes',
|
||||||
|
`default_value` varchar(25) DEFAULT NULL,
|
||||||
|
`calculation_columns` varchar(500) DEFAULT NULL,
|
||||||
|
`calculation_function` varchar(100) DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
create table `EmployementType` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Industry` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `ExperienceLevel` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `JobFunction` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EducationLevel` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Benifits` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Tags` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Job` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`title` varchar(200) NOT NULL,
|
||||||
|
`shortDescription` text DEFAULT NULL,
|
||||||
|
`description` text DEFAULT NULL,
|
||||||
|
`requirements` text DEFAULT NULL,
|
||||||
|
`benefits` text DEFAULT NULL,
|
||||||
|
`country` bigint(20) DEFAULT NULL,
|
||||||
|
`company` bigint(20) DEFAULT NULL,
|
||||||
|
`department` VARCHAR(100) NULL,
|
||||||
|
`code` VARCHAR(20) NULL,
|
||||||
|
`employementType` bigint(20) DEFAULT NULL,
|
||||||
|
`industry` bigint(20) DEFAULT NULL,
|
||||||
|
`experienceLevel` bigint(20) DEFAULT NULL,
|
||||||
|
`jobFunction` bigint(20) DEFAULT NULL,
|
||||||
|
`educationLevel` bigint(20) DEFAULT NULL,
|
||||||
|
`currency` bigint(20) DEFAULT NULL,
|
||||||
|
`showSalary` enum('Yes','No') default NULL,
|
||||||
|
`salaryMin` bigint(20) DEFAULT NULL,
|
||||||
|
`salaryMax` bigint(20) DEFAULT NULL,
|
||||||
|
`keywords` text DEFAULT NULL,
|
||||||
|
`status` enum('Active','On hold','Closed') default NULL,
|
||||||
|
`closingDate` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`attachment` varchar(100) NULL,
|
||||||
|
`display` varchar(200) NOT NULL,
|
||||||
|
`postedBy` bigint(20) DEFAULT NULL,
|
||||||
|
INDEX `Job_status` (`status`),
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `Candidates` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`first_name` varchar(100) default '' not null,
|
||||||
|
`last_name` varchar(100) default '' not null,
|
||||||
|
`nationality` bigint(20) default null,
|
||||||
|
`birthday` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`gender` enum('Male','Female') default NULL,
|
||||||
|
`marital_status` enum('Married','Single','Divorced','Widowed','Other') default NULL,
|
||||||
|
`address1` varchar(100) default '',
|
||||||
|
`address2` varchar(100) default '',
|
||||||
|
`city` varchar(150) default '',
|
||||||
|
`country` char(2) default null,
|
||||||
|
`province` bigint(20) default null,
|
||||||
|
`postal_code` varchar(20) default null,
|
||||||
|
`email` varchar(200) default null,
|
||||||
|
`home_phone` varchar(50) default null,
|
||||||
|
`mobile_phone` varchar(50) default null,
|
||||||
|
`cv_title` varchar(200) default '' not null,
|
||||||
|
`cv` varchar(150) NULL,
|
||||||
|
`cvtext` text NULL,
|
||||||
|
`industry` text DEFAULT NULL,
|
||||||
|
`profileImage` varchar(150) NULL,
|
||||||
|
`head_line` text DEFAULT NULL,
|
||||||
|
`objective` text DEFAULT NULL,
|
||||||
|
`work_history` text DEFAULT NULL,
|
||||||
|
`education` text DEFAULT NULL,
|
||||||
|
`skills` text DEFAULT NULL,
|
||||||
|
`referees` text DEFAULT NULL,
|
||||||
|
`linkedInUrl` varchar(500) DEFAULT NULL,
|
||||||
|
`linkedInData` text DEFAULT NULL,
|
||||||
|
`totalYearsOfExperience` int(11) default null,
|
||||||
|
`totalMonthsOfExperience` int(11) default null,
|
||||||
|
`htmlCVData` longtext DEFAULT NULL,
|
||||||
|
`generatedCVFile` varchar(150) DEFAULT NULL,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`expectedSalary` int(11) default null,
|
||||||
|
`preferedPositions` text default null,
|
||||||
|
`preferedJobtype` varchar(60) default null,
|
||||||
|
`preferedCountries` text default null,
|
||||||
|
`tags` text default null,
|
||||||
|
`notes` text default null,
|
||||||
|
`calls` text default null,
|
||||||
|
`age` int(11) default null,
|
||||||
|
`hash` varchar(100) DEFAULT NULL,
|
||||||
|
`linkedInProfileLink` varchar(250) DEFAULT NULL,
|
||||||
|
`linkedInProfileId` varchar(50) DEFAULT NULL,
|
||||||
|
`facebookProfileLink` varchar(250) DEFAULT NULL,
|
||||||
|
`facebookProfileId` varchar(50) DEFAULT NULL,
|
||||||
|
`twitterProfileLink` varchar(250) DEFAULT NULL,
|
||||||
|
`twitterProfileId` varchar(50) DEFAULT NULL,
|
||||||
|
`googleProfileLink` varchar(250) DEFAULT NULL,
|
||||||
|
`googleProfileId` varchar(50) DEFAULT NULL,
|
||||||
|
primary key (`id`)
|
||||||
|
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `Applications` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`job` bigint(20) NOT NULL,
|
||||||
|
`candidate` bigint(20) DEFAULT NULL,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`referredByEmail` varchar(200) DEFAULT NULL,
|
||||||
|
`notes` text DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key (`job`,`candidate`),
|
||||||
|
CONSTRAINT `Fk_Applications_Job` FOREIGN KEY (`job`) REFERENCES `Job` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_Applications_Candidates` FOREIGN KEY (`candidate`) REFERENCES `Candidates` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Interviews` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`job` bigint(20) NOT NULL,
|
||||||
|
`candidate` bigint(20) DEFAULT NULL,
|
||||||
|
`level` varchar(100) DEFAULT NULL,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`scheduled` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`location` varchar(500) DEFAULT NULL,
|
||||||
|
`mapId` bigint(20) NULL,
|
||||||
|
`status` varchar(100) default null,
|
||||||
|
`notes` text DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
CONSTRAINT `Fk_Interviews_Job` FOREIGN KEY (`job`) REFERENCES `Job` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_Interviews_Candidates` FOREIGN KEY (`candidate`) REFERENCES `Candidates` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `Calls` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`job` bigint(20) NOT NULL,
|
||||||
|
`candidate` bigint(20) DEFAULT NULL,
|
||||||
|
`phone` varchar(20) default null,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`status` varchar(100) default null,
|
||||||
|
`notes` text DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
CONSTRAINT `Fk_Calls_Job` FOREIGN KEY (`job`) REFERENCES `Job` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_Calls_Candidates` FOREIGN KEY (`candidate`) REFERENCES `Candidates` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `LeaveStartingBalance` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`leave_type` bigint(20) NOT NULL,
|
||||||
|
`employee` bigint(20) NULL,
|
||||||
|
`leave_period` bigint(20) NOT NULL,
|
||||||
|
`amount` decimal(10,3) NOT NULL,
|
||||||
|
`note` text DEFAULT NULL,
|
||||||
|
`created` datetime default '0000-00-00 00:00:00',
|
||||||
|
`updated` datetime default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
create table `Crons` (
|
create table `Crons` (
|
||||||
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
`name` varchar(100) NOT NULL,
|
`name` varchar(100) NOT NULL,
|
||||||
@@ -774,7 +1247,7 @@ create table `EmployeeExpenses` (
|
|||||||
`attachment3` varchar(100) NULL,
|
`attachment3` varchar(100) NULL,
|
||||||
`created` timestamp NULL default '0000-00-00 00:00:00',
|
`created` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
`status` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled') default 'Pending',
|
`status` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled','Processing') default 'Pending',
|
||||||
CONSTRAINT `Fk_EmployeeExpenses_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
CONSTRAINT `Fk_EmployeeExpenses_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
CONSTRAINT `Fk_EmployeeExpenses_pm` FOREIGN KEY (`payment_method`) REFERENCES `ExpensesPaymentMethods` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
CONSTRAINT `Fk_EmployeeExpenses_pm` FOREIGN KEY (`payment_method`) REFERENCES `ExpensesPaymentMethods` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
CONSTRAINT `Fk_EmployeeExpenses_category` FOREIGN KEY (`category`) REFERENCES `ExpensesCategories` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
CONSTRAINT `Fk_EmployeeExpenses_category` FOREIGN KEY (`category`) REFERENCES `ExpensesCategories` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
@@ -788,3 +1261,164 @@ create table `Timezones` (
|
|||||||
`details` varchar(255) not null default '',
|
`details` varchar(255) not null default '',
|
||||||
primary key (`id`)
|
primary key (`id`)
|
||||||
) engine=innodb default charset=utf8;
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EmployeeDataHistory` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`type` varchar(100) not null,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`field` varchar(100) not null,
|
||||||
|
`old_value` varchar(500) default null,
|
||||||
|
`new_value` varchar(500) default null,
|
||||||
|
`description` varchar(800) default null,
|
||||||
|
`user` bigint(20) NULL,
|
||||||
|
`updated` timestamp default '0000-00-00 00:00:00',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
CONSTRAINT `Fk_EmployeeDataHistory_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeDataHistory_Users` FOREIGN KEY (`user`) REFERENCES `Users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `EmployeeAttendanceSheets` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`date_start` date NOT NULL,
|
||||||
|
`date_end` date NOT NULL,
|
||||||
|
`status` enum('Approved','Pending','Rejected','Submitted') default 'Pending',
|
||||||
|
CONSTRAINT `Fk_EmployeeAttendanceSheets_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
UNIQUE KEY `EmployeeAttendanceSheetsKey` (`employee`,`date_start`,`date_end`),
|
||||||
|
KEY `EmployeeAttendanceSheets_date_end` (`date_end`),
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `CustomFieldValues` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`type` varchar(20) not null,
|
||||||
|
`name` varchar(60) not null,
|
||||||
|
`object_id` varchar(60) not null,
|
||||||
|
`value` text default NULL,
|
||||||
|
`updated` timestamp default '0000-00-00 00:00:00',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`),
|
||||||
|
UNIQUE key `CustomFields_type_name_object_id` (`type`,`name`,`object_id`),
|
||||||
|
INDEX `CustomFields_type_object_id` (`type`,`object_id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `DataImport` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(60) not null,
|
||||||
|
`dataType` varchar(60) not null,
|
||||||
|
`details` text default NULL,
|
||||||
|
`columns` text default NULL,
|
||||||
|
`updated` timestamp default '0000-00-00 00:00:00',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `DataImportFiles` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(60) not null,
|
||||||
|
`data_import_definition` varchar(200) not null,
|
||||||
|
`status` varchar(15) null,
|
||||||
|
`file` varchar(100) null,
|
||||||
|
`details` text default NULL,
|
||||||
|
`updated` timestamp default '0000-00-00 00:00:00',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `UserReports` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`details` text default null,
|
||||||
|
`parameters` text default null,
|
||||||
|
`query` text default null,
|
||||||
|
`paramOrder` varchar(500) NOT NULL,
|
||||||
|
`type` enum('Query','Class') default 'Query',
|
||||||
|
`report_group` varchar(500) NULL,
|
||||||
|
`output` varchar(15) NOT NULL default 'CSV',
|
||||||
|
primary key (`id`),
|
||||||
|
UNIQUE KEY `UserReports_Name` (`name`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `ReportFiles` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NULL,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`attachment` varchar(100) NOT NULL,
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
unique key `ReportFiles_attachment` (`attachment`),
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `PayslipTemplates` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`data` longtext NULL,
|
||||||
|
`status` enum('Show','Hide') default 'Show',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
`updated` timestamp default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EmployeeApprovals` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`type` varchar(100) NOT NULL,
|
||||||
|
`element` bigint(20) NOT NULL,
|
||||||
|
`approver` bigint(20) NULL,
|
||||||
|
`level` int(11) default 0,
|
||||||
|
`status` int(11) default 0,
|
||||||
|
`active` int(11) default 0,
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
`updated` timestamp default '0000-00-00 00:00:00',
|
||||||
|
UNIQUE key `EmployeeApprovals_type_element_level` (`type`,`element`,`level`),
|
||||||
|
INDEX `EmployeeApprovals_type_element_status_level` (`type`,`element`,`status`,`level`),
|
||||||
|
INDEX `EmployeeApprovals_type_element` (`type`,`element`),
|
||||||
|
INDEX `EmployeeApprovals_type` (`type`),
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `StatusChangeLogs` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`type` varchar(100) NOT NULL,
|
||||||
|
`element` bigint(20) NOT NULL,
|
||||||
|
`user_id` bigint(20) NULL,
|
||||||
|
`data` varchar(500) NOT NULL,
|
||||||
|
`status_from` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled','Processing') default 'Pending',
|
||||||
|
`status_to` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled','Processing') default 'Pending',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
INDEX `EmployeeApprovals_type_element` (`type`,`element`),
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `OvertimeCategories` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(500) NOT NULL,
|
||||||
|
`created` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `EmployeeOvertime` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`start_time` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`end_time` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`category` bigint(20) NOT NULL,
|
||||||
|
`project` bigint(20) NULL,
|
||||||
|
`notes` text NULL,
|
||||||
|
`created` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`status` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled','Processing') default 'Pending',
|
||||||
|
CONSTRAINT `Fk_EmployeeOvertime_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeOvertime_Category` FOREIGN KEY (`category`) REFERENCES `OvertimeCategories` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|||||||
839
core-ext/scripts/upgrade_v15.2.OS_to_v16.0.OS.sql
Normal file
839
core-ext/scripts/upgrade_v15.2.OS_to_v16.0.OS.sql
Normal file
@@ -0,0 +1,839 @@
|
|||||||
|
REPLACE INTO `Reports` (`name`, `details`, `parameters`, `query`, `paramOrder`, `type`,`report_group`) VALUES
|
||||||
|
('Employee Details Report', 'This report list all employee details and you can filter employees by department, employment status or job title', '[\r\n[ "department", {"label":"Department","type":"select2","remote-source":["CompanyStructure","id","title"],"allow-null":true}],\r\n[ "employment_status", {"label":"Employment Status","type":"select2","remote-source":["EmploymentStatus","id","name"],"allow-null":true}],\r\n[ "job_title", {"label":"Job Title","type":"select2","remote-source":["JobTitle","id","name"],"allow-null":true}]\r\n]', 'Select id, employee_id as ''Employee ID'',\r\nconcat(`first_name`,'' '',`middle_name`,'' '', `last_name`) as ''Name'',\r\n(SELECT name from Nationality where id = nationality) as ''Nationality'',\r\nbirthday as ''Birthday'',\r\ngender as ''Gender'',\r\nmarital_status as ''Marital Status'',\r\nssn_num as ''SSN Number'',\r\nnic_num as ''NIC Number'',\r\nother_id as ''Other IDs'',\r\ndriving_license as ''Driving License Number'',\r\n(SELECT name from EmploymentStatus where id = employment_status) as ''Employment Status'',\r\n(SELECT name from JobTitles where id = job_title) as ''Job Title'',\r\n(SELECT name from PayGrades where id = pay_grade) as ''Pay Grade'',\r\nwork_station_id as ''Work Station ID'',\r\naddress1 as ''Address 1'',\r\naddress2 as ''Address 2'',\r\ncity as ''City'',\r\n(SELECT name from Country where code = country) as ''Country'',\r\n(SELECT name from Province where id = province) as ''Province'',\r\npostal_code as ''Postal Code'',\r\nhome_phone as ''Home Phone'',\r\nmobile_phone as ''Mobile Phone'',\r\nwork_phone as ''Work Phone'',\r\nwork_email as ''Work Email'',\r\nprivate_email as ''Private Email'',\r\njoined_date as ''Joined Date'',\r\nconfirmation_date as ''Confirmation Date'',\r\n(SELECT title from CompanyStructures where id = department) as ''Department'',\r\n(SELECT concat(`first_name`,'' '',`middle_name`,'' '', `last_name`,'' [Employee ID:'',`employee_id`,'']'') from Employees e1 where e1.id = e.supervisor) as ''Supervisor'' \r\nFROM Employees e _where_', '["department","employment_status","job_title"]', 'Query', 'Employee Information'),
|
||||||
|
('Employee Time Entry Report', 'This report list all employee time entries by employee, date range and project', '[\r\n[ "employee", {"label":"Employee","type":"select2multi","allow-null":true,"null-label":"All Employees","remote-source":["Employee","id","first_name+last_name"]}],\r\n[ "project", {"label":"Project","type":"select","allow-null":true,"remote-source":["Project","id","name"]}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}]\r\n]', 'EmployeeTimesheetReport', '["employee","date_start","date_end","status"]', 'Class','Time Management'),
|
||||||
|
('Employee Attendance Report', 'This report list all employee attendance entries by employee and date range', '[\r\n[ "employee", {"label":"Employee","type":"select2multi","allow-null":true,"null-label":"All Employees","remote-source":["Employee","id","first_name+last_name"]}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}]\r\n]', 'EmployeeAttendanceReport', '["employee","date_start","date_end"]', 'Class','Time Management'),
|
||||||
|
('Employee Time Tracking Report', 'This report list employee working hours and attendance details for each day for a given period ', '[\r\n[ "employee", {"label":"Employee","type":"select2","allow-null":false,"remote-source":["Employee","id","first_name+last_name"]}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}]\r\n]', 'EmployeeTimeTrackReport', '["employee","date_start","date_end"]', 'Class','Time Management');
|
||||||
|
|
||||||
|
REPLACE INTO `Reports` (`name`, `details`, `parameters`, `query`, `paramOrder`, `type`,`report_group`) VALUES
|
||||||
|
('Active Employee Report', 'This report list employees who are currently active based on joined date and termination date ',
|
||||||
|
'[\r\n[ "department", {"label":"Department","type":"select2","remote-source":["CompanyStructure","id","title"],"allow-null":true}]\r\n]',
|
||||||
|
'ActiveEmployeeReport',
|
||||||
|
'["department"]', 'Class','Employee Information');
|
||||||
|
|
||||||
|
REPLACE INTO `Reports` (`name`, `details`, `parameters`, `query`, `paramOrder`, `type`, `report_group`) VALUES
|
||||||
|
('New Hires Employee Report', 'This report list employees who are joined between given two dates ',
|
||||||
|
'[[ "department", {"label":"Department","type":"select2","remote-source":["CompanyStructure","id","title"],"allow-null":true}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}]\r\n]',
|
||||||
|
'NewHiresEmployeeReport',
|
||||||
|
'["department","date_start","date_end"]', 'Class','Employee Information');
|
||||||
|
|
||||||
|
REPLACE INTO `Reports` (`name`, `details`, `parameters`, `query`, `paramOrder`, `type`, `report_group`) VALUES
|
||||||
|
('Terminated Employee Report', 'This report list employees who are terminated between given two dates ',
|
||||||
|
'[[ "department", {"label":"Department","type":"select2","remote-source":["CompanyStructure","id","title"],"allow-null":true}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}]\r\n]',
|
||||||
|
'TerminatedEmployeeReport',
|
||||||
|
'["department","date_start","date_end"]', 'Class','Employee Information');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `Reports` (`name`, `details`, `parameters`, `query`, `paramOrder`, `type`,`report_group`) VALUES
|
||||||
|
('Employee Time Sheet Report', 'This report list all employee time sheets by employee and date range', '[\r\n[ "employee", {"label":"Employee","type":"select2multi","allow-null":true,"null-label":"All Employees","remote-source":["Employee","id","first_name+last_name"]}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}],\r\n[ "status", {"label":"Status","allow-null":true,"null-label":"All Status","type":"select","source":[["Approved","Approved"],["Pending","Pending"],["Rejected","Rejected"]]}]\r\n]', 'EmployeeTimeSheetData', '["employee","date_start","date_end","status"]', 'Class','Time Management');
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('LDAP: Enabled', '0', '','["value", {"label":"Value","type":"select","source":[["0","No"],["1","Yes"]]}]'),
|
||||||
|
('LDAP: Server', '', 'LDAP Server IP or DNS',''),
|
||||||
|
('LDAP: Port', '389', 'LDAP Server Port',''),
|
||||||
|
('LDAP: Root DN', '', 'e.g: dc=mycompany,dc=net',''),
|
||||||
|
('LDAP: Manager DN', '', 'e.g: cn=admin,dc=mycompany,dc=net',''),
|
||||||
|
('LDAP: Manager Password', '', 'Password of the manager user',''),
|
||||||
|
('LDAP: Version 3', '1', 'Are you using LDAP v3','["value", {"label":"Value","type":"select","source":[["1","Yes"],["0","No"]]}]'),
|
||||||
|
('LDAP: User Filter', '', 'e.g: uid={}, we will replace {} with actual username provided by the user at the time of login','');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* v15.0.PRO to v16.0.PRO */
|
||||||
|
|
||||||
|
ALTER TABLE `Users` ADD COLUMN `login_hash` varchar(64) default null;
|
||||||
|
ALTER TABLE `Users` ADD INDEX login_hash_index (`login_hash`);
|
||||||
|
|
||||||
|
INSERT INTO `ImmigrationStatus` VALUES
|
||||||
|
(1,'Citizen'),
|
||||||
|
(2,'Permanent Resident'),
|
||||||
|
(3,'Work Permit Holder'),
|
||||||
|
(4,'Dependant Pass Holder');
|
||||||
|
|
||||||
|
INSERT INTO `Ethnicity` VALUES
|
||||||
|
(1,'White American'),
|
||||||
|
(2,'Black or African American'),
|
||||||
|
(3,'Native American'),
|
||||||
|
(4,'Alaska Native'),
|
||||||
|
(5,'Asian American'),
|
||||||
|
(6,'Native Hawaiian'),
|
||||||
|
(7,'Pacific Islander');
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('Attendance: Overtime Calculation Class', 'BasicOvertimeCalculator', 'Set the method used to calculate overtime','["value", {"label":"Value","type":"select","source":[["BasicOvertimeCalculator","BasicOvertimeCalculator"],["CaliforniaOvertimeCalculator","CaliforniaOvertimeCalculator"]]}]');
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('Attendance: Work Week Start Day', '0', 'Set the starting day of the work week','["value", {"label":"Value","type":"select","source":[["0","Sunday"],["1","Monday"],["2","Tuesday"],["3","Wednesday"],["4","Thursday"],["5","Friday"],["6","Saturday"]]}]');
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('System: Reset Module Names', '1', 'Select this to reset module names in Database','["value", {"label":"Value","type":"select","source":[["1","Yes"],["0","No"]]}]');
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('Attendance: Overtime Start Hour', '8', 'Overtime calculation will start after an employee work this number of hours per day, 0 to indicate no overtime', ''),
|
||||||
|
('Attendance: Double time Start Hour', '12', 'Double time calculation will start after an employee work this number of hours per day, 0 to indicate no double time', ''),
|
||||||
|
('Api: REST Api Enabled', '1', '','["value", {"label":"Value","type":"select","source":[["0","No"],["1","Yes"]]}]'),
|
||||||
|
('Api: REST Api Token', 'Click on edit icon', '','["value", {"label":"Value","type":"placeholder"}]');
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('System: Allowed Countries', '0', 'Only these countries will be allowed in select boxes','["value", {"label":"Value","type":"select2multi","remote-source":["Country","id","name"]}]');
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('System: Allowed Currencies', '0', 'Only these currencies will be allowed in select boxes','["value", {"label":"Value","type":"select2multi","remote-source":["CurrencyType","id","code+name"]}]');
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('System: Allowed Nationality', '', 'Only these nationalities will be allowed in select boxes','["value", {"label":"Value","type":"select2multi","remote-source":["Nationality","id","name"]}]');
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `Reports` (`name`, `details`, `parameters`, `query`, `paramOrder`, `type`,`report_group`) VALUES
|
||||||
|
('Overtime Report', 'This report list all employee attendance entries by employee with overtime calculations', '[\r\n[ "employee", {"label":"Employee","type":"select2multi","allow-null":true,"null-label":"All Employees","remote-source":["Employee","id","first_name+last_name"]}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}]\r\n]', 'OvertimeReport', '["employee","date_start","date_end"]', 'Class','Time Management');
|
||||||
|
|
||||||
|
REPLACE INTO `Reports` (`name`, `details`, `parameters`, `query`, `paramOrder`, `type`,`report_group`) VALUES
|
||||||
|
('Overtime Summary Report', 'This report list all employee attendance entries by employee with overtime calculation summary', '[\r\n[ "employee", {"label":"Employee","type":"select2multi","allow-null":true,"null-label":"All Employees","remote-source":["Employee","id","first_name+last_name"]}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}]\r\n]', 'OvertimeSummaryReport', '["employee","date_start","date_end"]', 'Class','Time Management');
|
||||||
|
|
||||||
|
create table `EmployeeDataHistory` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`type` varchar(100) not null,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`field` varchar(100) not null,
|
||||||
|
`old_value` varchar(500) default null,
|
||||||
|
`new_value` varchar(500) default null,
|
||||||
|
`description` varchar(800) default null,
|
||||||
|
`user` bigint(20) NULL,
|
||||||
|
`updated` timestamp default '0000-00-00 00:00:00',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
CONSTRAINT `Fk_EmployeeDataHistory_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeDataHistory_Users` FOREIGN KEY (`user`) REFERENCES `Users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
Alter table `Employees` modify column `joined_date` date default '0000-00-00';
|
||||||
|
Alter table `Employees` modify column `confirmation_date` date default '0000-00-00';
|
||||||
|
Alter table `Employees` modify column `termination_date` date default '0000-00-00';
|
||||||
|
Alter table `Employees` modify column `birthday` date default '0000-00-00';
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `FieldNameMappings` (`type`, `name`, `textOrig`, `textMapped`, `display`) VALUES
|
||||||
|
('Employee', 'indirect_supervisors', 'Indirect Supervisors', 'Indirect Supervisors', 'Form');
|
||||||
|
|
||||||
|
Update Crons set time = (FLOOR( 1 + RAND( ) *58 )), type = 'Hourly' where name = 'Document Expire Alert';
|
||||||
|
|
||||||
|
CREATE TABLE `PayFrequency` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(200) NOT NULL,
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB default charset=utf8;
|
||||||
|
|
||||||
|
INSERT INTO `PayFrequency` VALUES
|
||||||
|
(1,'Bi Weekly'),
|
||||||
|
(2,'Weekly'),
|
||||||
|
(3,'Semi Monthly'),
|
||||||
|
(4,'Monthly'),
|
||||||
|
(5,'Yearly');
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE `PayrollColumnTemplates` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(50) DEFAULT NULL,
|
||||||
|
`columns` varchar(500) DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB default charset=utf8;
|
||||||
|
|
||||||
|
create table `Payroll` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(200) NULL,
|
||||||
|
`pay_period` bigint(20) NOT NULL,
|
||||||
|
`department` bigint(20) NOT NULL,
|
||||||
|
`column_template` bigint(20) NOT NULL,
|
||||||
|
`columns` varchar(500) DEFAULT NULL,
|
||||||
|
`date_start` DATE NULL default '0000-00-00',
|
||||||
|
`date_end` DATE NULL default '0000-00-00',
|
||||||
|
`status` enum('Draft','Completed','Processing') default 'Draft',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE `PayrollData` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`payroll` bigint(20) NOT NULL,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`payroll_item` int(11) NOT NULL,
|
||||||
|
`amount` varchar(25) DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`id`),
|
||||||
|
UNIQUE KEY `PayrollDataUniqueKey` (`payroll`,`employee`,`payroll_item`),
|
||||||
|
CONSTRAINT `Fk_PayrollData_Payroll` FOREIGN KEY (`payroll`) REFERENCES `Payroll` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) ENGINE=InnoDB default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE `PayrollColumns` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(50) DEFAULT NULL,
|
||||||
|
`calculation_hook` varchar(200) DEFAULT NULL,
|
||||||
|
`salary_components` varchar(500) DEFAULT NULL,
|
||||||
|
`deductions` varchar(500) DEFAULT NULL,
|
||||||
|
`add_columns` varchar(500) DEFAULT NULL,
|
||||||
|
`sub_columns` varchar(500) DEFAULT NULL,
|
||||||
|
`colorder` int(11) DEFAULT NULL,
|
||||||
|
`editable` enum('Yes','No') default 'Yes',
|
||||||
|
`enabled` enum('Yes','No') default 'Yes',
|
||||||
|
`default_value` varchar(25) DEFAULT NULL,
|
||||||
|
`calculation_columns` varchar(500) DEFAULT NULL,
|
||||||
|
`calculation_function` varchar(100) DEFAULT NULL,
|
||||||
|
PRIMARY KEY (`id`)
|
||||||
|
) ENGINE=InnoDB default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `PayrollColumns` (`id`,`name`,`calculation_hook`,`salary_components`,`deductions`,`add_columns`,`sub_columns`,`editable`) VALUES
|
||||||
|
(1,'Total Hours','AttendanceUtil_getTimeWorkedHours','','','','','No'),
|
||||||
|
(2,'Regular Hours','AttendanceUtil_getRegularWorkedHours','','','','','No'),
|
||||||
|
(3,'Overtime Hours','AttendanceUtil_getOverTimeWorkedHours','','','','','No'),
|
||||||
|
(4,'Leave Hours','LeaveUtil_getLeaveHours','','','','','No');
|
||||||
|
|
||||||
|
create table `PayrollEmployees` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`pay_frequency` int(11) default null,
|
||||||
|
`currency` bigint(20) NULL,
|
||||||
|
`deduction_exemptions` varchar(250) default null,
|
||||||
|
`deduction_allowed` varchar(250) default null,
|
||||||
|
CONSTRAINT `Fk_PayrollEmployee_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key `PayrollEmployees_employee` (`employee`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `DeductionGroup` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`description` varchar(100) NOT NULL,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
drop table `DeductionRules`;
|
||||||
|
drop table `Deductions`;
|
||||||
|
|
||||||
|
create table `Deductions` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`componentType` varchar(250) NULL,
|
||||||
|
`component` varchar(250) NULL,
|
||||||
|
`payrollColumn` int(11) DEFAULT NULL,
|
||||||
|
`rangeAmounts` text default null,
|
||||||
|
`deduction_group` bigint(20) NULL,
|
||||||
|
CONSTRAINT `Fk_Deductions_DeductionGroup` FOREIGN KEY (`deduction_group`) REFERENCES `DeductionGroup` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Update Reports set parameters = '[\r\n[ "department", {"label":"Department (Company)","type":"select2","remote-source":["CompanyStructure","id","title"],"allow-null":true}],\r\n[ "employee", {"label":"Employee","type":"select2multi","allow-null":true,"null-label":"All Employees","remote-source":["Employee","id","first_name+last_name"]}],\r\n[ "date_start", {"label":"Start Date","type":"date"}],\r\n[ "date_end", {"label":"End Date","type":"date"}],\r\n[ "status", {"label":"Leave Status","type":"select","source":[["NULL","All Statuses"],["Approved","Approved"],["Pending","Pending"],["Rejected","Rejected"],["Cancellation Requested","Cancellation Requested"],["Cancelled","Cancelled"]]}]\r\n]' where name = "Employee Leaves Report";
|
||||||
|
|
||||||
|
|
||||||
|
Delete from `Settings` where name = 'System: Default Country';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
create table `LeaveTypes` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`supervisor_leave_assign` enum('Yes','No') default 'Yes',
|
||||||
|
`employee_can_apply` enum('Yes','No') default 'Yes',
|
||||||
|
`apply_beyond_current` enum('Yes','No') default 'Yes',
|
||||||
|
`leave_accrue` enum('No','Yes') default 'No',
|
||||||
|
`carried_forward` enum('No','Yes') default 'No',
|
||||||
|
`default_per_year` decimal(10,3) NOT NULL,
|
||||||
|
`carried_forward_percentage` int(11) NULL default 0,
|
||||||
|
`carried_forward_leave_availability` int(11) NULL default 365,
|
||||||
|
`propotionate_on_joined_date` enum('No','Yes') default 'No',
|
||||||
|
`send_notification_emails` enum('Yes','No') default 'Yes',
|
||||||
|
`leave_group` bigint(20) NULL,
|
||||||
|
`leave_color` varchar(10) NULL,
|
||||||
|
`max_carried_forward_amount` int(11) NULL default 0,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key (`name`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `LeaveRules` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`leave_type` bigint(20) NOT NULL,
|
||||||
|
`job_title` bigint(20) NULL,
|
||||||
|
`employment_status` bigint(20) NULL,
|
||||||
|
`employee` bigint(20) NULL,
|
||||||
|
`supervisor_leave_assign` enum('Yes','No') default 'Yes',
|
||||||
|
`employee_can_apply` enum('Yes','No') default 'Yes',
|
||||||
|
`apply_beyond_current` enum('Yes','No') default 'Yes',
|
||||||
|
`leave_accrue` enum('No','Yes') default 'No',
|
||||||
|
`carried_forward` enum('No','Yes') default 'No',
|
||||||
|
`default_per_year` decimal(10,3) NOT NULL,
|
||||||
|
`carried_forward_percentage` int(11) NULL default 0,
|
||||||
|
`carried_forward_leave_availability` int(11) NULL default 365,
|
||||||
|
`propotionate_on_joined_date` enum('No','Yes') default 'No',
|
||||||
|
`leave_group` bigint(20) NULL,
|
||||||
|
`max_carried_forward_amount` int(11) NULL default 0,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `LeaveGroups` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`details` text default null,
|
||||||
|
`created` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `LeaveGroupEmployees` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`leave_group` bigint(20) NOT NULL,
|
||||||
|
`created` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
`updated` timestamp NULL default '0000-00-00 00:00:00',
|
||||||
|
CONSTRAINT `Fk_LeaveGroupEmployees_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_LeaveGroupEmployees_LeaveGroups` FOREIGN KEY (`leave_group`) REFERENCES `LeaveGroups` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key `LeaveGroupEmployees_employee` (`employee`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `LeavePeriods` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`date_start` date default '0000-00-00',
|
||||||
|
`date_end` date default '0000-00-00',
|
||||||
|
`status` enum('Active','Inactive') default 'Inactive',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `WorkDays` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`status` enum('Full Day','Half Day','Non-working Day') default 'Full Day',
|
||||||
|
`country` bigint(20) DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key `workdays_name_country` (`name`,`country`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `HoliDays` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`dateh` date default '0000-00-00',
|
||||||
|
`status` enum('Full Day','Half Day') default 'Full Day',
|
||||||
|
`country` bigint(20) DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key `holidays_dateh_country` (`dateh`,`country`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EmployeeLeaves` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`leave_type` bigint(20) NOT NULL,
|
||||||
|
`leave_period` bigint(20) NOT NULL,
|
||||||
|
`date_start` date default '0000-00-00',
|
||||||
|
`date_end` date default '0000-00-00',
|
||||||
|
`details` text default null,
|
||||||
|
`status` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled') default 'Pending',
|
||||||
|
`attachment` varchar(100) NULL,
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaves_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaves_LeaveTypes` FOREIGN KEY (`leave_type`) REFERENCES `LeaveTypes` (`id`),
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaves_LeavePeriods` FOREIGN KEY (`leave_period`) REFERENCES `LeavePeriods` (`id`),
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EmployeeLeaveLog` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee_leave` bigint(20) NOT NULL,
|
||||||
|
`user_id` bigint(20) NULL,
|
||||||
|
`data` varchar(500) NOT NULL,
|
||||||
|
`status_from` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled') default 'Pending',
|
||||||
|
`status_to` enum('Approved','Pending','Rejected','Cancellation Requested','Cancelled') default 'Pending',
|
||||||
|
`created` timestamp default '0000-00-00 00:00:00',
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaveLog_EmployeeLeaves` FOREIGN KEY (`employee_leave`) REFERENCES `EmployeeLeaves` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaveLog_Users` FOREIGN KEY (`user_id`) REFERENCES `Users` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EmployeeLeaveDays` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee_leave` bigint(20) NOT NULL,
|
||||||
|
`leave_date` date default '0000-00-00',
|
||||||
|
`leave_type` enum('Full Day','Half Day - Morning','Half Day - Afternoon','1 Hour - Morning','2 Hours - Morning','3 Hours - Morning','1 Hour - Afternoon','2 Hours - Afternoon','3 Hours - Afternoon') NOT NULL,
|
||||||
|
CONSTRAINT `Fk_EmployeeLeaveDays_EmployeeLeaves` FOREIGN KEY (`employee_leave`) REFERENCES `EmployeeLeaves` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `Documents` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`details` text default null,
|
||||||
|
`expire_notification` enum('Yes','No') default 'Yes',
|
||||||
|
`expire_notification_month` enum('Yes','No') default 'Yes',
|
||||||
|
`expire_notification_week` enum('Yes','No') default 'Yes',
|
||||||
|
`expire_notification_day` enum('Yes','No') default 'Yes',
|
||||||
|
`sign` enum('Yes','No') default 'Yes',
|
||||||
|
`sign_label` VARCHAR(500) default null,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `EmployeeDocuments` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`document` bigint(20) NULL,
|
||||||
|
`date_added` date NOT NULL,
|
||||||
|
`valid_until` date NOT NULL,
|
||||||
|
`status` enum('Active','Inactive','Draft') default 'Active',
|
||||||
|
`details` text default null,
|
||||||
|
`attachment` varchar(100) NULL,
|
||||||
|
`signature` text default null,
|
||||||
|
`expire_notification_last` int(4) NULL,
|
||||||
|
CONSTRAINT `Fk_EmployeeDocuments_Documents` FOREIGN KEY (`document`) REFERENCES `Documents` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeDocuments_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`),
|
||||||
|
KEY `KEY_EmployeeDocuments_valid_until` (`valid_until`),
|
||||||
|
KEY `KEY_EmployeeDocuments_valid_until_status` (`valid_until`,`status`,`expire_notification_last`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `CompanyDocuments` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(100) NOT NULL,
|
||||||
|
`details` text default null,
|
||||||
|
`valid_until` date NOT NULL,
|
||||||
|
`status` enum('Active','Inactive','Draft') default 'Active',
|
||||||
|
`notify_employees` enum('Yes','No') default 'Yes',
|
||||||
|
`attachment` varchar(100) NULL,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `Courses` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`code` varchar(300) NOT NULL,
|
||||||
|
`name` varchar(300) NOT NULL,
|
||||||
|
`description` text default null,
|
||||||
|
`coordinator` bigint(20) NULL,
|
||||||
|
`trainer` varchar(300) NULL,
|
||||||
|
`trainer_info` text default null,
|
||||||
|
`paymentType` enum('Company Sponsored','Paid by Employee') default 'Company Sponsored',
|
||||||
|
`currency` varchar(3) null,
|
||||||
|
`cost` decimal(12,2) DEFAULT 0.00,
|
||||||
|
`status` enum('Active','Inactive') default 'Active',
|
||||||
|
`created` datetime default '0000-00-00 00:00:00',
|
||||||
|
`updated` datetime default '0000-00-00 00:00:00',
|
||||||
|
CONSTRAINT `Fk_Courses_Employees` FOREIGN KEY (`coordinator`) REFERENCES `Employees` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `TrainingSessions` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(300) NOT NULL,
|
||||||
|
`course` bigint(20) NOT NULL,
|
||||||
|
`description` text default null,
|
||||||
|
`scheduled` datetime default '0000-00-00 00:00:00',
|
||||||
|
`dueDate` datetime default '0000-00-00 00:00:00',
|
||||||
|
`deliveryMethod` enum('Classroom','Self Study','Online') default 'Classroom',
|
||||||
|
`deliveryLocation` varchar(500) NULL,
|
||||||
|
`status` enum('Pending','Approved','Completed','Cancelled') default 'Pending',
|
||||||
|
`attendanceType` enum('Sign Up','Assign') default 'Sign Up',
|
||||||
|
`attachment` varchar(300) NULL,
|
||||||
|
`created` datetime default '0000-00-00 00:00:00',
|
||||||
|
`updated` datetime default '0000-00-00 00:00:00',
|
||||||
|
`requireProof` enum('Yes','No') default 'Yes',
|
||||||
|
CONSTRAINT `Fk_TrainingSessions_Courses` FOREIGN KEY (`course`) REFERENCES `Courses` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `EmployeeTrainingSessions` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`employee` bigint(20) NOT NULL,
|
||||||
|
`trainingSession` bigint(20) NULL,
|
||||||
|
`feedBack` varchar(1500) NULL,
|
||||||
|
`status` enum('Scheduled','Attended','Not-Attended','Completed') default 'Scheduled',
|
||||||
|
`proof` varchar(300) NULL,
|
||||||
|
CONSTRAINT `Fk_EmployeeTrainingSessions_TrainingSessions` FOREIGN KEY (`trainingSession`) REFERENCES `TrainingSessions` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_EmployeeTrainingSessions_Employee` FOREIGN KEY (`employee`) REFERENCES `Employees` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
create table `LeaveStartingBalance` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`leave_type` bigint(20) NOT NULL,
|
||||||
|
`employee` bigint(20) NULL,
|
||||||
|
`leave_period` bigint(20) NOT NULL,
|
||||||
|
`amount` decimal(10,3) NOT NULL,
|
||||||
|
`note` text DEFAULT NULL,
|
||||||
|
`created` datetime default '0000-00-00 00:00:00',
|
||||||
|
`updated` datetime default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Sync with Default Schema */
|
||||||
|
|
||||||
|
create table `EmployementType` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Industry` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `ExperienceLevel` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `JobFunction` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `EducationLevel` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Benifits` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Tags` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`name` varchar(250) not null default '',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Job` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`title` varchar(200) NOT NULL,
|
||||||
|
`shortDescription` text DEFAULT NULL,
|
||||||
|
`description` text DEFAULT NULL,
|
||||||
|
`requirements` text DEFAULT NULL,
|
||||||
|
`benefits` text DEFAULT NULL,
|
||||||
|
`country` bigint(20) DEFAULT NULL,
|
||||||
|
`company` bigint(20) DEFAULT NULL,
|
||||||
|
`department` VARCHAR(100) NULL,
|
||||||
|
`code` VARCHAR(20) NULL,
|
||||||
|
`employementType` bigint(20) DEFAULT NULL,
|
||||||
|
`industry` bigint(20) DEFAULT NULL,
|
||||||
|
`experienceLevel` bigint(20) DEFAULT NULL,
|
||||||
|
`jobFunction` bigint(20) DEFAULT NULL,
|
||||||
|
`educationLevel` bigint(20) DEFAULT NULL,
|
||||||
|
`currency` bigint(20) DEFAULT NULL,
|
||||||
|
`showSalary` enum('Yes','No') default NULL,
|
||||||
|
`salaryMin` bigint(20) DEFAULT NULL,
|
||||||
|
`salaryMax` bigint(20) DEFAULT NULL,
|
||||||
|
`keywords` text DEFAULT NULL,
|
||||||
|
`status` enum('Active','On hold','Closed') default NULL,
|
||||||
|
`closingDate` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`attachment` varchar(100) NULL,
|
||||||
|
`display` varchar(200) NOT NULL,
|
||||||
|
`postedBy` bigint(20) DEFAULT NULL,
|
||||||
|
INDEX `Job_status` (`status`),
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `Candidates` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`first_name` varchar(100) default '' not null,
|
||||||
|
`last_name` varchar(100) default '' not null,
|
||||||
|
`nationality` bigint(20) default null,
|
||||||
|
`birthday` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`gender` enum('Male','Female') default NULL,
|
||||||
|
`marital_status` enum('Married','Single','Divorced','Widowed','Other') default NULL,
|
||||||
|
`address1` varchar(100) default '',
|
||||||
|
`address2` varchar(100) default '',
|
||||||
|
`city` varchar(150) default '',
|
||||||
|
`country` char(2) default null,
|
||||||
|
`province` bigint(20) default null,
|
||||||
|
`postal_code` varchar(20) default null,
|
||||||
|
`email` varchar(200) default null,
|
||||||
|
`home_phone` varchar(50) default null,
|
||||||
|
`mobile_phone` varchar(50) default null,
|
||||||
|
`cv_title` varchar(200) default '' not null,
|
||||||
|
`cv` varchar(150) NULL,
|
||||||
|
`cvtext` text NULL,
|
||||||
|
`industry` text DEFAULT NULL,
|
||||||
|
`profileImage` varchar(150) NULL,
|
||||||
|
`head_line` text DEFAULT NULL,
|
||||||
|
`objective` text DEFAULT NULL,
|
||||||
|
`work_history` text DEFAULT NULL,
|
||||||
|
`education` text DEFAULT NULL,
|
||||||
|
`skills` text DEFAULT NULL,
|
||||||
|
`referees` text DEFAULT NULL,
|
||||||
|
`linkedInUrl` varchar(500) DEFAULT NULL,
|
||||||
|
`linkedInData` text DEFAULT NULL,
|
||||||
|
`totalYearsOfExperience` int(11) default null,
|
||||||
|
`totalMonthsOfExperience` int(11) default null,
|
||||||
|
`htmlCVData` longtext DEFAULT NULL,
|
||||||
|
`generatedCVFile` varchar(150) DEFAULT NULL,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`expectedSalary` int(11) default null,
|
||||||
|
`preferedPositions` text default null,
|
||||||
|
`preferedJobtype` varchar(60) default null,
|
||||||
|
`preferedCountries` text default null,
|
||||||
|
`tags` text default null,
|
||||||
|
`notes` text default null,
|
||||||
|
`calls` text default null,
|
||||||
|
`age` int(11) default null,
|
||||||
|
`hash` varchar(100) DEFAULT NULL,
|
||||||
|
`linkedInProfileLink` varchar(250) DEFAULT NULL,
|
||||||
|
`linkedInProfileId` varchar(50) DEFAULT NULL,
|
||||||
|
`facebookProfileLink` varchar(250) DEFAULT NULL,
|
||||||
|
`facebookProfileId` varchar(50) DEFAULT NULL,
|
||||||
|
`twitterProfileLink` varchar(250) DEFAULT NULL,
|
||||||
|
`twitterProfileId` varchar(50) DEFAULT NULL,
|
||||||
|
`googleProfileLink` varchar(250) DEFAULT NULL,
|
||||||
|
`googleProfileId` varchar(50) DEFAULT NULL,
|
||||||
|
primary key (`id`)
|
||||||
|
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `Applications` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`job` bigint(20) NOT NULL,
|
||||||
|
`candidate` bigint(20) DEFAULT NULL,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`referredByEmail` varchar(200) DEFAULT NULL,
|
||||||
|
`notes` text DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
unique key (`job`,`candidate`),
|
||||||
|
CONSTRAINT `Fk_Applications_Job` FOREIGN KEY (`job`) REFERENCES `Job` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_Applications_Candidates` FOREIGN KEY (`candidate`) REFERENCES `Candidates` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
create table `Interviews` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`job` bigint(20) NOT NULL,
|
||||||
|
`candidate` bigint(20) DEFAULT NULL,
|
||||||
|
`level` varchar(100) DEFAULT NULL,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`scheduled` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`location` varchar(500) DEFAULT NULL,
|
||||||
|
`mapId` bigint(20) NULL,
|
||||||
|
`status` varchar(100) default null,
|
||||||
|
`notes` text DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
CONSTRAINT `Fk_Interviews_Job` FOREIGN KEY (`job`) REFERENCES `Job` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_Interviews_Candidates` FOREIGN KEY (`candidate`) REFERENCES `Candidates` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `Calls` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`job` bigint(20) NOT NULL,
|
||||||
|
`candidate` bigint(20) DEFAULT NULL,
|
||||||
|
`phone` varchar(20) default null,
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`status` varchar(100) default null,
|
||||||
|
`notes` text DEFAULT NULL,
|
||||||
|
primary key (`id`),
|
||||||
|
CONSTRAINT `Fk_Calls_Job` FOREIGN KEY (`job`) REFERENCES `Job` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT `Fk_Calls_Candidates` FOREIGN KEY (`candidate`) REFERENCES `Candidates` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Add Missing Master Data */
|
||||||
|
|
||||||
|
INSERT INTO `WorkDays` (`id`, `name`, `status`, `country`) VALUES
|
||||||
|
(1, 'Monday', 'Full Day',NULL),
|
||||||
|
(2, 'Tuesday', 'Full Day',NULL),
|
||||||
|
(3, 'Wednesday', 'Full Day',NULL),
|
||||||
|
(4, 'Thursday', 'Full Day',NULL),
|
||||||
|
(5, 'Friday', 'Full Day',NULL),
|
||||||
|
(6, 'Saturday', 'Non-working Day',NULL),
|
||||||
|
(7, 'Sunday', 'Non-working Day',NULL);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('System: Reset Module Names', '1', 'Select this to reset module names in Database','["value", {"label":"Value","type":"select","source":[["1","Yes"],["0","No"]]}]'),
|
||||||
|
('Leave: Share Calendar to Whole Company', '1', '','["value", {"label":"Value","type":"select","source":[["1","Yes"],["0","No"]]}]'),
|
||||||
|
('Leave: CC Emails', '', 'Every email sent though leave module will be CC to these comma seperated list of emails addresses',''),
|
||||||
|
('Leave: BCC Emails', '', 'Every email sent though leave module will be BCC to these comma seperated list of emails addresses',''),
|
||||||
|
('Api: REST Api Enabled', '1', '','["value", {"label":"Value","type":"select","source":[["0","No"],["1","Yes"]]}]'),
|
||||||
|
('Api: REST Api Token', 'Click on edit icon', '','["value", {"label":"Value","type":"placeholder"}]');
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('LDAP: Enabled', '0', '','["value", {"label":"Value","type":"select","source":[["0","No"],["1","Yes"]]}]'),
|
||||||
|
('LDAP: Server', '', 'LDAP Server IP or DNS',''),
|
||||||
|
('LDAP: Port', '389', 'LDAP Server Port',''),
|
||||||
|
('LDAP: Root DN', '', 'e.g: dc=mycompany,dc=net',''),
|
||||||
|
('LDAP: Manager DN', '', 'e.g: cn=admin,dc=mycompany,dc=net',''),
|
||||||
|
('LDAP: Manager Password', '', 'Password of the manager user',''),
|
||||||
|
('LDAP: Version 3', '1', 'Are you using LDAP v3','["value", {"label":"Value","type":"select","source":[["1","Yes"],["0","No"]]}]'),
|
||||||
|
('LDAP: User Filter', '', 'e.g: uid={}, we will replace {} with actual username provided by the user at the time of login','');
|
||||||
|
|
||||||
|
REPLACE INTO `Settings` (`name`, `value`, `description`, `meta`) VALUES
|
||||||
|
('Leave: Allow Indirect Admins to Approve', '0', 'Allow indirect admins to approve leave requests','["value", {"label":"Value","type":"select","source":[["1","Yes"],["0","No"]]}]');
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `Documents` (`id`, `name`, `details`, `expire_notification`, `expire_notification_month`, `expire_notification_week`, `expire_notification_day`,`sign`,`created`, `updated`) VALUES
|
||||||
|
(1, 'ID Copy', 'Your ID copy','Yes','Yes','Yes','Yes','No',NOW(), NOW()),
|
||||||
|
(2, 'Degree Certificate', 'Degree Certificate','Yes','Yes','Yes','Yes','Yes',NOW(), NOW()),
|
||||||
|
(3, 'Driving License', 'Driving License','Yes','Yes','Yes','Yes','Yes',NOW(), NOW());
|
||||||
|
|
||||||
|
REPLACE INTO `HoliDays` (`id`, `name`, `dateh`, `status`) VALUES
|
||||||
|
(1, 'New Year''s Day', '2015-01-01', 'Full Day'),
|
||||||
|
(2, 'Christmas Day', '2015-12-25', 'Full Day');
|
||||||
|
|
||||||
|
REPLACE INTO `LeavePeriods` (`id`, `name`, `date_start`, `date_end`, `status`) VALUES
|
||||||
|
(3, 'Year 2015', '2015-01-01', '2015-12-31', 'Active'),
|
||||||
|
(4, 'Year 2016', '2016-01-01', '2016-12-31', 'Active'),
|
||||||
|
(5, 'Year 2017', '2017-01-01', '2017-12-31', 'Active');
|
||||||
|
|
||||||
|
REPLACE INTO `LeaveTypes` (`id`, `name`, `supervisor_leave_assign`, `employee_can_apply`, `apply_beyond_current`, `leave_accrue`, `carried_forward`, `default_per_year`) VALUES
|
||||||
|
(1, 'Annual leave', 'No', 'Yes', 'No', 'No', 'No', 14),
|
||||||
|
(2, 'Casual leave', 'Yes', 'Yes', 'No', 'No', 'No', 7),
|
||||||
|
(3, 'Medical leave', 'Yes', 'Yes', 'Yes', 'No', 'No', 7);
|
||||||
|
|
||||||
|
REPLACE INTO `Courses` (`id`,`code`, `name`, `description`, `coordinator`, `trainer`, `trainer_info`, `paymentType`, `currency`, `cost`, `status`, `created`, `updated`) VALUES
|
||||||
|
(1,'C0001', 'Info Marketing', 'Learn how to Create and Outsource Info Marketing Products', 1, 'Tim Jhon', 'Tim Jhon has a background in business management and has been working with small business to establish their online presence','Company Sponsored','USD','55','Active',now(), now()),
|
||||||
|
(2,'C0002', 'People Management', 'Learn how to Manage People', 1, 'Tim Jhon', 'Tim Jhon has a background in business management and has been working with small business to establish their online presence','Company Sponsored','USD','59','Active',now(), now());
|
||||||
|
|
||||||
|
REPLACE INTO `EmployementType` (`name`) VALUES
|
||||||
|
('Full-time'),
|
||||||
|
('Part-time'),
|
||||||
|
('Contract'),
|
||||||
|
('Temporary'),
|
||||||
|
('Other');
|
||||||
|
|
||||||
|
REPLACE INTO `Benifits` (`name`) VALUES
|
||||||
|
('Retirement plan'),
|
||||||
|
('Health plan'),
|
||||||
|
('Life insurance'),
|
||||||
|
('Paid vacations');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `ExperienceLevel` (`name`) VALUES
|
||||||
|
('Not Applicable'),
|
||||||
|
('Internship'),
|
||||||
|
('Entry level'),
|
||||||
|
('Associate'),
|
||||||
|
('Mid-Senior level'),
|
||||||
|
('Director'),
|
||||||
|
('Executive');
|
||||||
|
|
||||||
|
REPLACE INTO `JobFunction` (`name`) VALUES
|
||||||
|
('Accounting/Auditing'),
|
||||||
|
('Administrative'),
|
||||||
|
('Advertising'),
|
||||||
|
('Business Analyst'),
|
||||||
|
('Financial Analyst'),
|
||||||
|
('Data Analyst'),
|
||||||
|
('Art/Creative'),
|
||||||
|
('Business Development'),
|
||||||
|
('Consulting'),
|
||||||
|
('Customer Service'),
|
||||||
|
('Distribution'),
|
||||||
|
('Design'),
|
||||||
|
('Education'),
|
||||||
|
('Engineering'),
|
||||||
|
('Finance'),
|
||||||
|
('General Business'),
|
||||||
|
('Health Care Provider'),
|
||||||
|
('Human Resources'),
|
||||||
|
('Information Technology'),
|
||||||
|
('Legal'),
|
||||||
|
('Management'),
|
||||||
|
('Manufacturing'),
|
||||||
|
('Marketing'),
|
||||||
|
('Other'),
|
||||||
|
('Public Relations'),
|
||||||
|
('Purchasing'),
|
||||||
|
('Product Management'),
|
||||||
|
('Project Management'),
|
||||||
|
('Production'),
|
||||||
|
('Quality Assurance'),
|
||||||
|
('Research'),
|
||||||
|
('Sales'),
|
||||||
|
('Science'),
|
||||||
|
('Strategy/Planning'),
|
||||||
|
('Supply Chain'),
|
||||||
|
('Training'),
|
||||||
|
('Writing/Editing');
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `EducationLevel` (`name`) VALUES
|
||||||
|
('Unspecified'),
|
||||||
|
('High School or equivalent'),
|
||||||
|
('Certification'),
|
||||||
|
('Vocational'),
|
||||||
|
('Associate Degree'),
|
||||||
|
('Bachelor\'s Degree'),
|
||||||
|
('Master\'s Degree'),
|
||||||
|
('Doctorate'),
|
||||||
|
('Professional'),
|
||||||
|
('Some College Coursework Completed'),
|
||||||
|
('Vocational - HS Diploma'),
|
||||||
|
('Vocational - Degree'),
|
||||||
|
('Some High School Coursework');
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `Crons` (`name`,`class`, `lastrun`, `frequency`, `time`, `type`, `status`) VALUES
|
||||||
|
('Email Sender Task', 'EmailSenderTask', NULL, 1, 1, 'Minutely', 'Enabled'),
|
||||||
|
('Document Expire Alert', 'DocumentExpiryNotificationTask', NULL, 1, (FLOOR( 1 + RAND( ) *58 )), 'Hourly', 'Enabled');
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `ExpensesPaymentMethods` (`name`) VALUES
|
||||||
|
('Cash'),
|
||||||
|
('Check'),
|
||||||
|
('Credit Card'),
|
||||||
|
('Debit Card');
|
||||||
|
|
||||||
|
|
||||||
|
REPLACE INTO `ExpensesCategories` (`name`) VALUES
|
||||||
|
('Auto - Gas'),
|
||||||
|
('Auto - Insurance'),
|
||||||
|
('Auto - Maintenance'),
|
||||||
|
('Auto - Payment'),
|
||||||
|
('Transportation'),
|
||||||
|
('Bank Fees'),
|
||||||
|
('Dining Out'),
|
||||||
|
('Entertainment'),
|
||||||
|
('Hotel / Motel'),
|
||||||
|
('Insurance'),
|
||||||
|
('Interest Charges'),
|
||||||
|
('Loan Payment'),
|
||||||
|
('Medical'),
|
||||||
|
('Mileage'),
|
||||||
|
('Rent'),
|
||||||
|
('Rental Car'),
|
||||||
|
('Utility');
|
||||||
481
core-ext/scripts/upgrade_v16.0.PRO_v18.0.PRO.sql
Normal file
481
core-ext/scripts/upgrade_v16.0.PRO_v18.0.PRO.sql
Normal file
File diff suppressed because one or more lines are too long
2
docker/docker.md
Normal file
2
docker/docker.md
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
https://hub.docker.com/r/thilinah/icehrm/
|
||||||
|
docker run -i -t -p 192.168.99.100:80:80 thilinah/icehrm /bin/start.sh
|
||||||
30
docker/start.sh
Normal file
30
docker/start.sh
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
service nginx start
|
||||||
|
service php5-fpm start
|
||||||
|
service mysql start
|
||||||
|
|
||||||
|
if [ -d "/usr/share/nginx/www/" ]; then
|
||||||
|
echo 'Already Installed'
|
||||||
|
else
|
||||||
|
echo 'Installing IceHrm'
|
||||||
|
cd /usr/share/nginx
|
||||||
|
curl -s https://api.github.com/repos/gamonoid/icehrm/releases/latest | jq -r ".assets[] | select(.name) | .browser_download_url" | grep '.zip' | xargs wget
|
||||||
|
ls | grep 'zip' | xargs unzip
|
||||||
|
mv `ls -d */ | grep icehrm | head -1` www/
|
||||||
|
rm *.zip
|
||||||
|
|
||||||
|
echo 'Your MySQL root password : icehrmpwd'
|
||||||
|
|
||||||
|
echo "Following will be needed during installation"
|
||||||
|
echo "--------------------------------------------"
|
||||||
|
echo 'IceHrm Database : icehrmdb'
|
||||||
|
echo 'IceHrm User : icehrmuser'
|
||||||
|
echo 'IceHrm User Password : icehrmuserpwd'
|
||||||
|
echo 'IceHrm Database host : localhost'
|
||||||
|
|
||||||
|
echo 'Please visit your docker installation url to begin installation.'
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
/bin/bash
|
||||||
@@ -41,7 +41,7 @@ class AttendanceActionManager extends SubActionManager{
|
|||||||
|
|
||||||
//check if dates are differnet
|
//check if dates are differnet
|
||||||
if(!empty($outDate) && $inDate != $outDate){
|
if(!empty($outDate) && $inDate != $outDate){
|
||||||
return new IceResponse(IceResponse::ERROR,"Attendance entry should be within a single day");
|
return new IceResponse(IceResponse::ERROR,LanguageManager::tran("Attendance entry should be within a single day"));
|
||||||
}
|
}
|
||||||
|
|
||||||
//compare dates
|
//compare dates
|
||||||
|
|||||||
@@ -34,6 +34,14 @@ if (!class_exists('AttendanceAdminManager')) {
|
|||||||
UIManager::getInstance()->addQuickAccessMenuItem("Clocked In Employees","fa-clock-o",CLIENT_BASE_URL."?g=admin&n=attendance&m=admin_Employees#tabAttendanceStatus",array("Admin","Manager"));
|
UIManager::getInstance()->addQuickAccessMenuItem("Clocked In Employees","fa-clock-o",CLIENT_BASE_URL."?g=admin&n=attendance&m=admin_Employees#tabAttendanceStatus",array("Admin","Manager"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function initCalculationHooks(){
|
||||||
|
$this->addCalculationHook('AttendanceUtil_getTimeWorkedHours','Total Hours from Attendance','AttendanceUtil','getTimeWorkedHours');
|
||||||
|
$this->addCalculationHook('AttendanceUtil_getRegularWorkedHours','Total Regular Hours from Attendance','AttendanceUtil','getRegularWorkedHours');
|
||||||
|
$this->addCalculationHook('AttendanceUtil_getOverTimeWorkedHours','Total Overtime Hours from Attendance','AttendanceUtil','getOverTimeWorkedHours');
|
||||||
|
$this->addCalculationHook('AttendanceUtil_getWeeklyRegularWorkedHours','Total Weekly Regular Hours from Attendance','AttendanceUtil','getWeeklyBasedRegularHours');
|
||||||
|
$this->addCalculationHook('AttendanceUtil_getWeeklyOverTimeWorkedHours','Total Weekly Overtime Hours from Attendance','AttendanceUtil','getWeeklyBasedOvertimeHours');
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -213,6 +221,113 @@ if (!class_exists('AttendanceStatus')) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!class_exists('AttendanceUtil')) {
|
||||||
|
class AttendanceUtil{
|
||||||
|
public function getAttendanceSummary($employeeId, $startDate, $endDate){
|
||||||
|
$startTime = $startDate." 00:00:00";
|
||||||
|
$endTime = $endDate." 23:59:59";
|
||||||
|
$attendance = new Attendance();
|
||||||
|
$atts = $attendance->Find("employee = ? and in_time >= ? and out_time <= ?",array($employeeId, $startTime, $endTime));
|
||||||
|
|
||||||
|
$atCalClassName = SettingsManager::getInstance()->getSetting('Attendance: Overtime Calculation Class');
|
||||||
|
|
||||||
|
$atCal = new $atCalClassName();
|
||||||
|
$atSum = $atCal->getDataSeconds($atts, $startDate, true);
|
||||||
|
|
||||||
|
return $atSum;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTimeWorkedHours($employeeId, $startDate, $endDate){
|
||||||
|
$atSum = $this->getAttendanceSummary($employeeId, $startDate, $endDate);
|
||||||
|
return round(($atSum['t']/60)/60,2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRegularWorkedHours($employeeId, $startDate, $endDate){
|
||||||
|
$atSum = $this->getAttendanceSummary($employeeId, $startDate, $endDate);
|
||||||
|
return round(($atSum['r']/60)/60,2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getOverTimeWorkedHours($employeeId, $startDate, $endDate){
|
||||||
|
$atSum = $this->getAttendanceSummary($employeeId, $startDate, $endDate);
|
||||||
|
return round(($atSum['o']/60)/60,2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getWeeklyBasedRegularHours($employeeId, $startDate, $endDate){
|
||||||
|
$atSum = $this->getWeeklyBasedOvertimeSummary($employeeId, $startDate, $endDate);
|
||||||
|
return round(($atSum['r']/60)/60,2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getWeeklyBasedOvertimeHours($employeeId, $startDate, $endDate){
|
||||||
|
$atSum = $this->getWeeklyBasedOvertimeSummary($employeeId, $startDate, $endDate);
|
||||||
|
return round(($atSum['o']/60)/60,2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getWeeklyBasedOvertimeSummary($employeeId, $startDate, $endDate){
|
||||||
|
|
||||||
|
$attendance = new Attendance();
|
||||||
|
$atTimeByWeek = array();
|
||||||
|
|
||||||
|
//Find weeks starting from sunday and ending from saturday in day period
|
||||||
|
|
||||||
|
$weeks = $this->getWeeklyDays($startDate,$endDate);
|
||||||
|
foreach($weeks as $k=>$week){
|
||||||
|
$startTime = $week[0]." 00:00:00";
|
||||||
|
$endTime = $week[count($week) - 1]." 23:59:59";
|
||||||
|
$atts = $attendance->Find("employee = ? and in_time >= ? and out_time <= ?",array($employeeId, $startTime, $endTime));
|
||||||
|
foreach($atts as $atEntry){
|
||||||
|
if($atEntry->out_time == "0000-00-00 00:00:00" || empty($atEntry->out_time)){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if(!isset($atTimeByWeek[$k])){
|
||||||
|
$atTimeByWeek[$k] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
$diff = strtotime($atEntry->out_time) - strtotime($atEntry->in_time);
|
||||||
|
if($diff < 0){
|
||||||
|
$diff = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
$atTimeByWeek[$k] += $diff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$overtimeStarts = SettingsManager::getInstance()->getSetting('Attendance: Overtime Start Hour');
|
||||||
|
$overtimeStarts = (is_numeric($overtimeStarts))?floatval($overtimeStarts)*60*60*5:0;
|
||||||
|
$regTime = 0;
|
||||||
|
$overTime = 0;
|
||||||
|
foreach($atTimeByWeek as $value){
|
||||||
|
if($value > $overtimeStarts){
|
||||||
|
$regTime += $overtimeStarts;
|
||||||
|
$overTime = $value - $overtimeStarts;
|
||||||
|
}else{
|
||||||
|
$regTime += $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return array('r'=>$regTime,'o'=>$overTime);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getWeeklyDays($startDate,$endDate){
|
||||||
|
$start = new DateTime($startDate);
|
||||||
|
$end = new DateTime($endDate.' 23:59');
|
||||||
|
$interval = new DateInterval('P1D');
|
||||||
|
$dateRange = new DatePeriod($start, $interval, $end);
|
||||||
|
|
||||||
|
$weekNumber = 1;
|
||||||
|
$weeks = array();
|
||||||
|
foreach ($dateRange as $date) {
|
||||||
|
$weeks[$weekNumber][] = $date->format('Y-m-d');
|
||||||
|
if ($date->format('w') == 6) {
|
||||||
|
$weekNumber++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $weeks;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (!class_exists('BasicOvertimeCalculator')) {
|
if (!class_exists('BasicOvertimeCalculator')) {
|
||||||
|
|
||||||
@@ -305,6 +420,18 @@ if (!class_exists('BasicOvertimeCalculator')) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getDataSeconds($atts, $actualStartDate, $aggregate = false){
|
||||||
|
$atSummary = $this->createAttendanceSummary($atts);
|
||||||
|
$overtime = $this->calculateOvertime($this->removeAdditionalDays($atSummary, $actualStartDate));
|
||||||
|
if($aggregate){
|
||||||
|
$overtime = $this->aggregateData($overtime);
|
||||||
|
return $overtime;
|
||||||
|
}else{
|
||||||
|
return $overtime;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public function convertToHours($overtime){
|
public function convertToHours($overtime){
|
||||||
|
|||||||
@@ -2,17 +2,17 @@
|
|||||||
<div class="small-box bg-yellow">
|
<div class="small-box bg-yellow">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>
|
<h3>
|
||||||
Attendance
|
<t>Attendance</t>
|
||||||
</h3>
|
</h3>
|
||||||
<p id="numberOfAttendanceLastWeek">
|
<p id="numberOfAttendanceLastWeek">
|
||||||
#_numberOfAttendanceLastWeek_# Entries Last Week
|
#_numberOfAttendanceLastWeek_# <t>Entries Last Week</t>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-clock"></i>
|
<i class="ion ion-clock"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="attendanceLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="attendanceLink">
|
||||||
Monitor Attendance <i class="fa fa-arrow-circle-right"></i>
|
<t>Monitor Attendance</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -28,11 +28,8 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabAttendance" href="#tabPageAttendance">Monitor Attendance</a></li>
|
<li class="active"><a id="tabAttendance" href="#tabPageAttendance"><?=LanguageManager::tran('Monitor Attendance')?></a></li>
|
||||||
<li class=""><a id="tabAttendanceStatus" href="#tabPageAttendanceStatus">Current Clocked In Status</a></li>
|
<li class=""><a id="tabAttendanceStatus" href="#tabPageAttendanceStatus"><?=LanguageManager::tran('Current Clocked In Status')?></a></li>
|
||||||
<!--
|
|
||||||
<li class=""><a id="tabAttendanceData" href="#tabPageAttendanceData">Attendance Data Update</a></li>
|
|
||||||
-->
|
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
@@ -52,20 +49,6 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!--
|
|
||||||
<div class="tab-pane" id="tabPageAttendanceData">
|
|
||||||
<div class="control-group" id="field__id_">
|
|
||||||
<div class="controls">
|
|
||||||
<textarea class="input-xxlarge" placeholder="Insert CSV data to submit" type="textarea" width="96%" rows="100" id="attendanceData" name="attendanceData"></textarea>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="control-group">
|
|
||||||
<div class="controls">
|
|
||||||
<button onclick="return false;" class="btn">Update Attendance Data</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
-->
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
@@ -56,6 +56,51 @@ if (!class_exists('CompanyStructure')) {
|
|||||||
|
|
||||||
return new IceResponse(IceResponse::SUCCESS,"");
|
return new IceResponse(IceResponse::SUCCESS,"");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function getAllChildCompanyStructures($companyStructureId){
|
||||||
|
$structures = array();
|
||||||
|
$companyStructure = new CompanyStructure();
|
||||||
|
$companyStructure->Load("id = ?",array($companyStructureId));
|
||||||
|
|
||||||
|
if($companyStructure->id != $companyStructureId || empty($companyStructure->id)){
|
||||||
|
return new IceResponse(IceResponse::ERROR, array());
|
||||||
|
}
|
||||||
|
|
||||||
|
self::getChildCompanyStructures($companyStructure, $structures);
|
||||||
|
|
||||||
|
$structures[$companyStructure->id] = $companyStructure;
|
||||||
|
|
||||||
|
return new IceResponse(IceResponse::SUCCESS, array_values($structures));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function getChildCompanyStructures($companyStructure, &$structures){
|
||||||
|
$child = new CompanyStructure();
|
||||||
|
$children = $child->Find("parent = ?",array($companyStructure->id));
|
||||||
|
if(!empty($children)){
|
||||||
|
foreach($children as $c){
|
||||||
|
if(isset($structures[$c->id])){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$structures[$c->id] = $c;
|
||||||
|
self::getChildCompanyStructures($c, $structures);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function isHeadOfCompanyStructure($companyStructureId, $profileId){
|
||||||
|
$companyStructure = new CompanyStructure();
|
||||||
|
$companyStructure->Load("id = ?",array($companyStructureId));
|
||||||
|
|
||||||
|
if(isset($companyStructure->heads) && !empty($companyStructure->heads)){
|
||||||
|
$heads = json_decode($companyStructure->heads);
|
||||||
|
if(is_array($heads) && !empty($heads) && in_array($profileId, $heads)){
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,16 +2,16 @@
|
|||||||
|
|
||||||
<div class="small-box bg-green">
|
<div class="small-box bg-green">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>Company</h3>
|
<h3><t>Company</t></h3>
|
||||||
<p id="numberOfCompanyStuctures">
|
<p id="numberOfCompanyStuctures">
|
||||||
#_numberOfCompanyStuctures_# Departments
|
#_numberOfCompanyStuctures_# <t>Departments</t>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-shuffle"></i>
|
<i class="ion ion-shuffle"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="companyLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="companyLink">
|
||||||
Manage Company <i class="fa fa-arrow-circle-right"></i>
|
<t>Manage</t> <t>Company</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -54,8 +54,8 @@ path.link {
|
|||||||
<div class="span9">
|
<div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabCompanyStructure" href="#tabPageCompanyStructure">Company Structure</a></li>
|
<li class="active"><a id="tabCompanyStructure" href="#tabPageCompanyStructure"><?=LanguageManager::tran('Company Structure')?></a></li>
|
||||||
<li><a id="tabCompanyGraph" href="#tabPageCompanyGraph">Company Graph</a></li>
|
<li><a id="tabCompanyGraph" href="#tabPageCompanyGraph"><?=LanguageManager::tran('Company Graph')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
|
|||||||
@@ -43,7 +43,8 @@ CompanyStructureAdapter.method('getFormFields', function() {
|
|||||||
[ "type", {"label":"Type","type":"select","source":[["Company","Company"],["Head Office","Head Office"],["Regional Office","Regional Office"],["Department","Department"],["Unit","Unit"],["Sub Unit","Sub Unit"],["Other","Other"]]}],
|
[ "type", {"label":"Type","type":"select","source":[["Company","Company"],["Head Office","Head Office"],["Regional Office","Regional Office"],["Department","Department"],["Unit","Unit"],["Sub Unit","Sub Unit"],["Other","Other"]]}],
|
||||||
[ "country", {"label":"Country","type":"select2","remote-source":["Country","code","name"]}],
|
[ "country", {"label":"Country","type":"select2","remote-source":["Country","code","name"]}],
|
||||||
[ "timezone", {"label":"Time Zone","type":"select2","allow-null":false,"remote-source":["Timezone","name","details"]}],
|
[ "timezone", {"label":"Time Zone","type":"select2","allow-null":false,"remote-source":["Timezone","name","details"]}],
|
||||||
[ "parent", {"label":"Parent Structure","type":"select","allow-null":true,"remote-source":["CompanyStructure","id","title"]}]
|
[ "parent", {"label":"Parent Structure","type":"select","allow-null":true,"remote-source":["CompanyStructure","id","title"]}],
|
||||||
|
[ "heads", {"label":"Heads","type":"select2multi","allow-null":true,"remote-source":["Employee","id","first_name+last_name"]}]
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -58,7 +58,21 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
</div>
|
</div>
|
||||||
|
<div id="iceannon">
|
||||||
|
<div class="callout callout-danger lead" style="font-size: 14px;font-weight: bold;">
|
||||||
|
<h4>Why not upgrade to IceHrm Pro Version</h4>
|
||||||
|
<p>
|
||||||
|
IceHrm Pro is the feature rich upgrade to IceHrm open source version. It comes with improved modules for
|
||||||
|
employee management, leave management and number of other features over open source version.
|
||||||
|
Hit this <a href="http://icehrm.com/#compare" class="btn btn-primary btn-xs target="_blank">link</a> to do a full one to one comparison.
|
||||||
|
|
||||||
|
Also you can learn more about IceHrm Pro <a href="http://blog.icehrm.com/docs/icehrm-pro/" class="btn btn-primary btn-xs" target="_blank">here</a>
|
||||||
|
<br/>
|
||||||
|
<br/>
|
||||||
|
<a href="http://icehrm.com/modules.php" class="btn btn-success btm-xs" target="_blank"><i class="fa fa-checkout"></i> Buy IceHrm Pro</a>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<script>
|
<script>
|
||||||
@@ -68,5 +82,17 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
|
|
||||||
var modJs = modJsList['tabDashboard'];
|
var modJs = modJsList['tabDashboard'];
|
||||||
|
|
||||||
|
$(document).ready(function() {
|
||||||
|
try {
|
||||||
|
$.ajax({
|
||||||
|
url: "https://icehrm-public.s3.amazonaws.com/icehrmnews.html",
|
||||||
|
success: function (result) {
|
||||||
|
$('#iceannon').html(result);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} catch (e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
<?php include APP_BASE_PATH.'footer.php';?>
|
<?php include APP_BASE_PATH.'footer.php';?>
|
||||||
164
ext/admin/employees/api/EmployeesActionManager.php
Normal file
164
ext/admin/employees/api/EmployeesActionManager.php
Normal file
@@ -0,0 +1,164 @@
|
|||||||
|
<?php
|
||||||
|
class EmployeesActionManager extends SubActionManager{
|
||||||
|
|
||||||
|
public function terminateEmployee($req){
|
||||||
|
$employee = new Employee();
|
||||||
|
$employee->Load("id = ?",array($req->id));
|
||||||
|
|
||||||
|
if(empty($employee->id)){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Employee Not Found");
|
||||||
|
}
|
||||||
|
|
||||||
|
$employee->termination_date = date('Y-m-d H:i:s');
|
||||||
|
$employee->status = 'Terminated';
|
||||||
|
|
||||||
|
$ok = $employee->Save();
|
||||||
|
if(!$ok){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Error occured while terminating employee");
|
||||||
|
}
|
||||||
|
|
||||||
|
return new IceResponse(IceResponse::SUCCESS, $employee);
|
||||||
|
|
||||||
|
//$user = BaseService::getInstance()->getUserFromProfileId($employee->id);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function activateEmployee($req){
|
||||||
|
$employee = new Employee();
|
||||||
|
$employee->Load("id = ?",array($req->id));
|
||||||
|
|
||||||
|
if(empty($employee->id)){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Employee Not Found");
|
||||||
|
}
|
||||||
|
|
||||||
|
$employee->termination_date = NULL;
|
||||||
|
$employee->status = 'Active';
|
||||||
|
|
||||||
|
$ok = $employee->Save();
|
||||||
|
if(!$ok){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Error occurred while activating employee");
|
||||||
|
}
|
||||||
|
|
||||||
|
return new IceResponse(IceResponse::SUCCESS, $employee);
|
||||||
|
|
||||||
|
//$user = BaseService::getInstance()->getUserFromProfileId($employee->id);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function deleteEmployee($req){
|
||||||
|
|
||||||
|
$employee = new Employee();
|
||||||
|
$employee->Load("id = ?",array($req->id));
|
||||||
|
|
||||||
|
if(empty($employee->id)){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Employee Not Found");
|
||||||
|
}
|
||||||
|
|
||||||
|
$archived = new ArchivedEmployee();
|
||||||
|
$archived->ref_id = $employee->id;
|
||||||
|
$archived->employee_id = $employee->employee_id;
|
||||||
|
$archived->first_name = $employee->first_name;
|
||||||
|
$archived->last_name = $employee->last_name;
|
||||||
|
$archived->gender = $employee->gender;
|
||||||
|
$archived->ssn_num = $employee->ssn_num;
|
||||||
|
$archived->nic_num = $employee->nic_num;
|
||||||
|
$archived->other_id = $employee->other_id;
|
||||||
|
$archived->work_email = $employee->work_email;
|
||||||
|
$archived->joined_date = $employee->joined_date;
|
||||||
|
$archived->confirmation_date = $employee->confirmation_date;
|
||||||
|
$archived->supervisor = $employee->supervisor;
|
||||||
|
$archived->department = $employee->department;
|
||||||
|
$archived->termination_date = $employee->termination_date;
|
||||||
|
$archived->notes = $employee->notes;
|
||||||
|
|
||||||
|
//$archived = BaseService::getInstance()->cleanUpAdoDB($archived);
|
||||||
|
|
||||||
|
$mapping = '{"nationality":["Nationality","id","name"],"employment_status":["EmploymentStatus","id","name"],"job_title":["JobTitle","id","name"],"pay_grade":["PayGrade","id","name"],"country":["Country","code","name"],"province":["Province","id","name"],"department":["CompanyStructure","id","title"],"supervisor":["Employee","id","first_name+last_name"]}';
|
||||||
|
|
||||||
|
$employeeEnriched = BaseService::getInstance()->getElement('Employee',$employee->id,$mapping,true);
|
||||||
|
$employeeEnriched = BaseService::getInstance()->cleanUpAdoDB($employeeEnriched);
|
||||||
|
|
||||||
|
$data = new stdClass();
|
||||||
|
$data->enrichedEmployee = $employeeEnriched;
|
||||||
|
|
||||||
|
$data->timesheets = $this->getEmployeeData($employee->id, new EmployeeTimeSheet());
|
||||||
|
$data->timesheetEntries = $this->getEmployeeData($employee->id, new EmployeeTimeEntry());
|
||||||
|
$data->attendance = $this->getEmployeeData($employee->id, new Attendance());
|
||||||
|
$data->documents = $this->getEmployeeData($employee->id, new EmployeeDocument());
|
||||||
|
if(class_exists('EmployeeTrainingSession')){
|
||||||
|
$data->trainingSessions = $this->getEmployeeData($employee->id, new EmployeeTrainingSession());
|
||||||
|
}
|
||||||
|
$data->travelRecords = $this->getEmployeeData($employee->id, new EmployeeTravelRecord());
|
||||||
|
$data->qualificationSkills = $this->getEmployeeData($employee->id, new EmployeeSkill());
|
||||||
|
$data->qualificationEducation = $this->getEmployeeData($employee->id, new EmployeeEducation());
|
||||||
|
$data->qualificationCertifications = $this->getEmployeeData($employee->id, new EmployeeCertification());
|
||||||
|
$data->qualificationLanguages = $this->getEmployeeData($employee->id, new EmployeeLanguage());
|
||||||
|
$data->salary = $this->getEmployeeData($employee->id, new EmployeeSalary());
|
||||||
|
$data->dependants = $this->getEmployeeData($employee->id, new EmployeeDependent());
|
||||||
|
$data->emergencyContacts = $this->getEmployeeData($employee->id, new EmergencyContact());
|
||||||
|
$data->projects = $this->getEmployeeData($employee->id, new EmployeeProject());
|
||||||
|
$data->leaves = $this->getEmployeeData($employee->id, new EmployeeLeave());
|
||||||
|
$data->leaveDays = $this->getEmployeeData($employee->id, new EmployeeLeaveDay());
|
||||||
|
|
||||||
|
$archived->data = json_encode($data, JSON_PRETTY_PRINT);
|
||||||
|
|
||||||
|
$ok = $archived->Save();
|
||||||
|
if(!$ok){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Error occured while archiving employee");
|
||||||
|
}
|
||||||
|
|
||||||
|
$ok = $employee->Delete();
|
||||||
|
if(!$ok){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Error occured while deleting employee");
|
||||||
|
}
|
||||||
|
|
||||||
|
return new IceResponse(IceResponse::SUCCESS, $archived);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function downloadArchivedEmployee($req){
|
||||||
|
|
||||||
|
|
||||||
|
if($this->baseService->currentUser->user_level != 'Admin'){
|
||||||
|
echo "Error: Permission denied";
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
$employee = new ArchivedEmployee();
|
||||||
|
$employee->Load("id = ?",array($req->id));
|
||||||
|
|
||||||
|
if(empty($employee->id)){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Employee Not Found");
|
||||||
|
}
|
||||||
|
|
||||||
|
$employee->data = json_decode($employee->data);
|
||||||
|
$employee = $this->baseService->cleanUpAdoDB($employee);
|
||||||
|
|
||||||
|
$str = json_encode($employee, JSON_PRETTY_PRINT);
|
||||||
|
|
||||||
|
$filename = uniqid();
|
||||||
|
$file = fopen("/tmp/".$filename,"w");
|
||||||
|
fwrite($file,$str);
|
||||||
|
fclose($file);
|
||||||
|
|
||||||
|
$downloadFileName = "employee_".$employee->id."_".str_replace(" ", "_", $employee->first_name)."_".str_replace(" ", "_", $employee->last_name).".txt";
|
||||||
|
|
||||||
|
header("Pragma: public"); // required
|
||||||
|
header("Expires: 0");
|
||||||
|
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
|
||||||
|
header("Content-Description: File Transfer");
|
||||||
|
header("Content-Type: image/jpg");
|
||||||
|
header('Content-Disposition: attachment; filename="'.$downloadFileName.'"');
|
||||||
|
header("Content-Transfer-Encoding: binary");
|
||||||
|
header("Content-Length: ".filesize("/tmp/".$filename));
|
||||||
|
readfile("/tmp/".$filename);
|
||||||
|
exit();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getEmployeeData($id, $obj){
|
||||||
|
$data = array();
|
||||||
|
$objs = $obj->Find("employee = ?",array($id));
|
||||||
|
foreach($objs as $entry){
|
||||||
|
$data[] = BaseService::getInstance()->cleanUpAdoDB($entry);
|
||||||
|
}
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -10,6 +10,18 @@ if (!class_exists('EmployeesAdminManager')) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function setupRestEndPoints(){
|
||||||
|
\NoahBuscher\Macaw\Macaw::get(REST_API_PATH.'employee/(:any)', function($pathParams) {
|
||||||
|
$empRestEndPoint = new EmployeeRestEndPoint();
|
||||||
|
$empRestEndPoint->process('get',$pathParams);
|
||||||
|
});
|
||||||
|
|
||||||
|
\NoahBuscher\Macaw\Macaw::get(REST_API_PATH.'employees', function() {
|
||||||
|
$empRestEndPoint = new EmployeesRestEndPoint();
|
||||||
|
$empRestEndPoint->process('get',NULL);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
public function initializeDatabaseErrorMappings(){
|
public function initializeDatabaseErrorMappings(){
|
||||||
$this->addDatabaseErrorMapping('CONSTRAINT `Fk_User_Employee` FOREIGN KEY',"Can not delete Employee, please delete the User for this employee first.");
|
$this->addDatabaseErrorMapping('CONSTRAINT `Fk_User_Employee` FOREIGN KEY',"Can not delete Employee, please delete the User for this employee first.");
|
||||||
$this->addDatabaseErrorMapping("Duplicate entry|for key 'employee'","A duplicate entry found");
|
$this->addDatabaseErrorMapping("Duplicate entry|for key 'employee'","A duplicate entry found");
|
||||||
@@ -18,6 +30,7 @@ if (!class_exists('EmployeesAdminManager')) {
|
|||||||
public function setupModuleClassDefinitions(){
|
public function setupModuleClassDefinitions(){
|
||||||
$this->addModelClass('Employee');
|
$this->addModelClass('Employee');
|
||||||
$this->addModelClass('EmploymentStatus');
|
$this->addModelClass('EmploymentStatus');
|
||||||
|
$this->addModelClass('EmployeeApproval');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDashboardItemData(){
|
public function getDashboardItemData(){
|
||||||
@@ -41,6 +54,43 @@ if (!class_exists('EmployeesAdminManager')) {
|
|||||||
if (!class_exists('Employee')) {
|
if (!class_exists('Employee')) {
|
||||||
class Employee extends ICEHRM_Record {
|
class Employee extends ICEHRM_Record {
|
||||||
|
|
||||||
|
var $oldObj = null;
|
||||||
|
var $oldObjOrig = null;
|
||||||
|
var $historyUpdateList = array();
|
||||||
|
var $historyFieldsToTrack = array(
|
||||||
|
"employee_id"=>"employee_id",
|
||||||
|
"first_name"=>"first_name",
|
||||||
|
"middle_name"=>"middle_name",
|
||||||
|
"last_name"=>"last_name",
|
||||||
|
"nationality"=>"nationality_Name",
|
||||||
|
"birthday"=>"birthday",
|
||||||
|
"gender"=>"gender",
|
||||||
|
"marital_status"=>"marital_status",
|
||||||
|
"ssn_num"=>"ssn_num",
|
||||||
|
"nic_num"=>"nic_num",
|
||||||
|
"other_id"=>"other_id",
|
||||||
|
"employment_status"=>"employment_status_Name",
|
||||||
|
"job_title"=>"job_title_Name",
|
||||||
|
"pay_grade"=>"pay_grade_Name",
|
||||||
|
"work_station_id"=>"work_station_id",
|
||||||
|
"address1"=>"address1",
|
||||||
|
"address2"=>"address2",
|
||||||
|
"city"=>"city_Name",
|
||||||
|
"country"=>"country_Name",
|
||||||
|
"province"=>"province_Name",
|
||||||
|
"postal_code"=>"postal_code",
|
||||||
|
"home_phone"=>"home_phone",
|
||||||
|
"mobile_phone"=>"mobile_phone",
|
||||||
|
"work_phone"=>"work_phone",
|
||||||
|
"work_email"=>"work_email",
|
||||||
|
"private_email"=>"private_email",
|
||||||
|
"joined_date"=>"joined_date",
|
||||||
|
"confirmation_date"=>"confirmation_date",
|
||||||
|
"supervisor"=>"supervisor_Name",
|
||||||
|
"indirect_supervisors"=>"indirect_supervisors",
|
||||||
|
"department"=>"department_Name"
|
||||||
|
);
|
||||||
|
|
||||||
public function getAdminAccess(){
|
public function getAdminAccess(){
|
||||||
return array("get","element","save","delete");
|
return array("get","element","save","delete");
|
||||||
}
|
}
|
||||||
@@ -61,10 +111,165 @@ if (!class_exists('Employee')) {
|
|||||||
return "id";
|
return "id";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private function initHistory($obj){
|
||||||
|
|
||||||
|
$oldObjOrig = new Employee();
|
||||||
|
$oldObjOrig->Load("id = ?",array($obj->id));
|
||||||
|
$this->oldObjOrig = $oldObjOrig;
|
||||||
|
|
||||||
|
$mapping = '{"nationality":["Nationality","id","name"],"employment_status":["EmploymentStatus","id","name"],"job_title":["JobTitle","id","name"],"pay_grade":["PayGrade","id","name"],"country":["Country","code","name"],"province":["Province","id","name"],"department":["CompanyStructure","id","title"],"supervisor":["Employee","id","first_name+last_name"]}';
|
||||||
|
|
||||||
|
$this->oldObj = BaseService::getInstance()->getElement('Employee',$obj->id,$mapping,true);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private function saveHistory($obj){
|
||||||
|
|
||||||
|
$oldObj = $this->oldObj;
|
||||||
|
$oldObjOrig = $this->oldObjOrig;
|
||||||
|
|
||||||
|
$mapping = '{"nationality":["Nationality","id","name"],"employment_status":["EmploymentStatus","id","name"],"job_title":["JobTitle","id","name"],"pay_grade":["PayGrade","id","name"],"country":["Country","code","name"],"province":["Province","id","name"],"department":["CompanyStructure","id","title"],"supervisor":["Employee","id","first_name+last_name"]}';
|
||||||
|
|
||||||
|
$objEnriched = BaseService::getInstance()->getElement('Employee',$obj->id,$mapping,true);
|
||||||
|
|
||||||
|
foreach($this->historyFieldsToTrack as $k => $v){
|
||||||
|
|
||||||
|
if(empty($oldObjOrig->$k) && $obj->$k = '[]'){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(empty($obj->$k) && $oldObjOrig->$k = '0000-00-00'){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if($oldObjOrig->$k != $obj->$k){
|
||||||
|
|
||||||
|
$enrichNewVal = '';
|
||||||
|
$enrichOldVal = '';
|
||||||
|
|
||||||
|
if($k == 'indirect_supervisors'){
|
||||||
|
if(!empty($obj->$k) && $obj->$k != '[]'){
|
||||||
|
$newIndeirectSupervisorIds = json_decode($obj->$k);
|
||||||
|
foreach($newIndeirectSupervisorIds as $id){
|
||||||
|
$item = BaseService::getInstance()->getItemFromCache("Employee", $id);
|
||||||
|
if($enrichNewVal != ""){
|
||||||
|
$enrichNewVal .= ", ";
|
||||||
|
}
|
||||||
|
$enrichNewVal .= $item->first_name." ".$item->last_name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!empty($oldObjOrig->$k) && $oldObjOrig->$k != '[]'){
|
||||||
|
$oldIndeirectSupervisorIds = json_decode($oldObjOrig->$k);
|
||||||
|
foreach($oldIndeirectSupervisorIds as $id){
|
||||||
|
$item = BaseService::getInstance()->getItemFromCache("Employee", $id);
|
||||||
|
if($enrichOldVal != ""){
|
||||||
|
$enrichOldVal .= ", ";
|
||||||
|
}
|
||||||
|
$enrichOldVal .= $item->first_name." ".$item->last_name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
$enrichOldVal = $oldObj->$v;
|
||||||
|
$enrichNewVal = $objEnriched->$v;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->historyUpdateList[] = array($obj->id,$k,$enrichOldVal,$enrichNewVal);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
while(count($this->historyUpdateList)){
|
||||||
|
$ele = array_pop($this->historyUpdateList);
|
||||||
|
BaseService::getInstance()->addHistoryItem("Employee","Employee",$ele[0],$ele[1],$ele[2],$ele[3]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function executePreSaveActions($obj){
|
||||||
|
if(empty($obj->status)){
|
||||||
|
$obj->status = 'Active';
|
||||||
|
}
|
||||||
|
return new IceResponse(IceResponse::SUCCESS,$obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function executePreUpdateActions($obj){
|
||||||
|
$this->initHistory($obj);
|
||||||
|
return new IceResponse(IceResponse::SUCCESS,$obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function executePostUpdateActions($obj){
|
||||||
|
$this->saveHistory($obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function postProcessGetData($obj){
|
||||||
|
$obj = FileService::getInstance()->updateSmallProfileImage($obj);
|
||||||
|
return $obj;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getVirtualFields(){
|
||||||
|
return array(
|
||||||
|
"image"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getActiveEmployees(){
|
||||||
|
$employee = new Employee();
|
||||||
|
$list = $employee->Find("status = ?",array('Active'));
|
||||||
|
return $list;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getActiveSubordinateEmployees(){
|
||||||
|
|
||||||
|
$employee = new Employee();
|
||||||
|
if(BaseService::getInstance()->currentUser->user_level != 'Admin'){
|
||||||
|
$cemp = BaseService::getInstance()->getCurrentProfileId();
|
||||||
|
$list = $employee->Find("status = ? and supervisor = ?",array('Active', $cemp));
|
||||||
|
}else{
|
||||||
|
$list = $employee->Find("status = ?",array('Active'));
|
||||||
|
}
|
||||||
|
return $list;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function cleanEmployeeData($obj){
|
||||||
|
unset($obj->historyFieldsToTrack);
|
||||||
|
unset($obj->historyUpdateList);
|
||||||
|
unset($obj->oldObjOrig);
|
||||||
|
unset($obj->oldObj);
|
||||||
|
unset($obj->oldObj);
|
||||||
|
return $obj;
|
||||||
|
}
|
||||||
|
|
||||||
var $_table = 'Employees';
|
var $_table = 'Employees';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!class_exists('ArchivedEmployee')) {
|
||||||
|
class ArchivedEmployee extends ICEHRM_Record {
|
||||||
|
|
||||||
|
public function getAdminAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getManagerAccess(){
|
||||||
|
return array("get","element","save");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserAccess(){
|
||||||
|
return array("get");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserOnlyMeAccess(){
|
||||||
|
return array("element","save");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserOnlyMeAccessField(){
|
||||||
|
return "id";
|
||||||
|
}
|
||||||
|
|
||||||
|
var $_table = 'ArchivedEmployees';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!class_exists('EmploymentStatus')) {
|
if (!class_exists('EmploymentStatus')) {
|
||||||
class EmploymentStatus extends ICEHRM_Record {
|
class EmploymentStatus extends ICEHRM_Record {
|
||||||
|
|
||||||
@@ -84,3 +289,71 @@ if (!class_exists('EmploymentStatus')) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!class_exists('EmployeeApproval')) {
|
||||||
|
class EmployeeApproval extends ICEHRM_Record {
|
||||||
|
|
||||||
|
var $_table = 'EmployeeApprovals';
|
||||||
|
|
||||||
|
public function getAdminAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getManagerAccess(){
|
||||||
|
return array("get","element","save");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserAccess(){
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (!class_exists('EmployeeRestEndPoint')) {
|
||||||
|
class EmployeeRestEndPoint extends RestEndPoint{
|
||||||
|
public function get($parameter){
|
||||||
|
if(empty($parameter)){
|
||||||
|
return new IceResponse(IceResponse::ERROR, "Employee ID not provided");
|
||||||
|
}
|
||||||
|
|
||||||
|
$accessTokenValidation = $this->validateAccessToken();
|
||||||
|
if($accessTokenValidation->getStatus() == IceResponse::ERROR){
|
||||||
|
return $accessTokenValidation;
|
||||||
|
}
|
||||||
|
|
||||||
|
$mapping = '{"nationality":["Nationality","id","name"],"ethnicity":["Ethnicity","id","name"],"immigration_status":["ImmigrationStatus","id","name"],"employment_status":["EmploymentStatus","id","name"],"job_title":["JobTitle","id","name"],"pay_grade":["PayGrade","id","name"],"country":["Country","code","name"],"province":["Province","id","name"],"department":["CompanyStructure","id","title"],"supervisor":["Employee","id","first_name+last_name"]}';
|
||||||
|
$employeeResp = BaseService::getInstance()->getElement('Employee',$parameter,$mapping,true);
|
||||||
|
if($employeeResp->getStatus() == IceResponse::SUCCESS){
|
||||||
|
$emp = $employeeResp->getObject();
|
||||||
|
$emp = Employee::cleanEmployeeData($emp);
|
||||||
|
return new IceResponse(IceResponse::SUCCESS,$emp);
|
||||||
|
}
|
||||||
|
return $employeeResp;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!class_exists('EmployeesRestEndPoint')) {
|
||||||
|
class EmployeesRestEndPoint extends RestEndPoint{
|
||||||
|
public function get($parameter){
|
||||||
|
|
||||||
|
$accessTokenValidation = $this->validateAccessToken();
|
||||||
|
if($accessTokenValidation->getStatus() == IceResponse::ERROR){
|
||||||
|
return $accessTokenValidation;
|
||||||
|
}
|
||||||
|
|
||||||
|
$emp = new Employee();
|
||||||
|
$emps = $emp->Find("1=1");
|
||||||
|
$newEmps = array();
|
||||||
|
foreach($emps as $emp){
|
||||||
|
$newEmps[] = Employee::cleanEmployeeData($emp);
|
||||||
|
}
|
||||||
|
return new IceResponse(IceResponse::SUCCESS, $newEmps);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
238
ext/admin/employees/customTemplates/myDetails.html
Normal file
238
ext/admin/employees/customTemplates/myDetails.html
Normal file
@@ -0,0 +1,238 @@
|
|||||||
|
<div class="row">
|
||||||
|
<div class="col-xs-12 col-md-2">
|
||||||
|
<div class="row-fluid">
|
||||||
|
<div class="col-xs-12" style="text-align: center;">
|
||||||
|
<img id="profile_image__id_" src="" class="img-polaroid img-thumbnail" style="max-width: 140px;max-height: 140px;">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-12 col-md-10">
|
||||||
|
<div class="row-fluid">
|
||||||
|
<div class="col-md-12"><h2 id="name"></h2></div>
|
||||||
|
</div>
|
||||||
|
<div class="row-fluid">
|
||||||
|
<div class="col-md-12">
|
||||||
|
<p>
|
||||||
|
<i class="fa fa-phone"></i> <span id="mobile_phone"></span>
|
||||||
|
<i class="fa fa-envelope"></i> <span id="work_email"></span>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row-fluid">
|
||||||
|
<div class="col-xs-12" style="font-size:18px;border-bottom: 1px solid #DDD;margin-bottom: 10px;padding-bottom: 10px;">
|
||||||
|
<button id="employeeProfileEditInfo" class="btn btn-small btn-success" onclick="modJs.edit(_id_);" style="margin-right:10px;"><i class="fa fa-edit"></i> Edit Info</button>
|
||||||
|
<button id="employeeUploadProfileImage" onclick="showUploadDialog('profile_image__id_','Upload Profile Image','profile_image',_id_,'profile_image__id_','src','url','image');return false;" class="btn btn-small btn-primary" type="button" style="margin-right:10px;"><i class="fa fa-upload"></i> Upload Profile Image</button>
|
||||||
|
<button id="employeeDeleteProfileImage" onclick="modJs.deleteProfileImage(_id_);return false;" class="btn btn-small btn-warning" type="button" style="margin-right:10px;"><i class="fa fa-times"></i> Delete Profile Image</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row-fluid" style="border-top: 1px;">
|
||||||
|
<div class="col-xs-6 col-md-4" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;font-size:13px;">#_label_employee_id_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="employee_id"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-4" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_nic_num_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="nic_num"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-4" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_ssn_num_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="ssn_num"></label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="nav nav-tabs" id="subModTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
|
<li class="active"><a id="tabBasic" href="#tabPageBasic">Basic Information</a></li>
|
||||||
|
<li class=""><a id="tabQualifications" href="#tabPageQualifications">Qualifications</a></li>
|
||||||
|
<li class=""><a id="tabDocuments" href="#tabPageDocuments">Documents</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<div class="tab-content">
|
||||||
|
<div class="tab-pane active" id="tabPageBasic" style="border:1px solid #DDD;">
|
||||||
|
<div class="row" style="margin-left:10px;margin-top:20px;">
|
||||||
|
<div class="panel panel-default" style="width:97.5%;">
|
||||||
|
<div class="panel-heading"><h4>Personal Information</h4></div>
|
||||||
|
<div class="panel-body" id="cont_personal_information">
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_driving_license_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="driving_license"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_other_id_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="other_id"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_birthday_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="birthday"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_gender_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="gender"></label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_nationality_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="nationality_Name"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_marital_status_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="marital_status"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_joined_date_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="joined_date"></label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row" style="margin-left:10px;margin-top:20px;">
|
||||||
|
<div class="panel panel-default" style="width:97.5%;">
|
||||||
|
<div class="panel-heading"><h4>Contact Information</h4></div>
|
||||||
|
<div class="panel-body" id="cont_contact_information">
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_address1_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="address1"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_address2_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="address2"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_city_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="city"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_country_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="country_Name"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_postal_code_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="postal_code"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_home_phone_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="home_phone"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_work_phone_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="work_phone"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_private_email_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="private_email"></label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row" style="margin-left:10px;margin-top:20px;">
|
||||||
|
<div class="panel panel-default" style="width:97.5%;">
|
||||||
|
<div class="panel-heading"><h4>Job Details</h4></div>
|
||||||
|
<div class="panel-body" id="cont_job_details">
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_job_title_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="job_title_Name"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_employment_status_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="employment_status_Name"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_supervisor_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="supervisor_Name"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">Direct Reports</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="subordinates"></label>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-6 col-md-3" style="font-size:16px;">
|
||||||
|
<label class="control-label col-xs-12" style="font-size:13px;">#_label_department_#</label>
|
||||||
|
<label class="control-label col-xs-12 iceLabel" style="font-size:13px;font-weight: bold;" id="department_Name"></label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div id="customFieldsCont">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="modal" id="adminUsersModel" tabindex="-1" role="dialog" aria-labelledby="messageModelLabel" aria-hidden="true">
|
||||||
|
<div class="modal-dialog">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true"><li class="fa fa-times"/></button>
|
||||||
|
<h3 style="font-size: 17px;">Change User Password</h3>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<form id="adminUsersChangePwd">
|
||||||
|
<div class="control-group">
|
||||||
|
<div class="controls">
|
||||||
|
<span class="label label-warning" id="adminUsersChangePwd_error" style="display:none;"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group" id="field_newpwd">
|
||||||
|
<label class="control-label" for="newpwd">New Password</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input class="" type="password" id="newpwd" name="newpwd" value="" class="form-control"/>
|
||||||
|
<span class="help-inline" id="help_newpwd"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group" id="field_conpwd">
|
||||||
|
<label class="control-label" for="conpwd">Confirm Password</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input class="" type="password" id="conpwd" name="conpwd" value="" class="form-control"/>
|
||||||
|
<span class="help-inline" id="help_conpwd"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button class="btn btn-primary" onclick="modJs.changePasswordConfirm();">Change Password</button>
|
||||||
|
<button class="btn" onclick="modJs.closeChangePassword();">Not Now</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div><!-- End tabPageBasic -->
|
||||||
|
<div class="tab-pane" id="tabPageQualifications" style="border:1px solid #DDD;">
|
||||||
|
<div class="row" style="margin-top:20px;">
|
||||||
|
<div class="col-md-3">
|
||||||
|
<div id="EmployeeSkillSubTab" class="" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-3">
|
||||||
|
<div id="EmployeeEducationSubTab" class="" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-3">
|
||||||
|
<div id="EmployeeCertificationSubTab" class="" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-3">
|
||||||
|
<div id="EmployeeLanguageSubTab" class="" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div><!-- End tabPageQualifications -->
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageDocuments" style="border:1px solid #DDD;">
|
||||||
|
<div class="row" style="margin-top:20px;">
|
||||||
|
<div class="col-md-12">
|
||||||
|
<div id="EmployeeDocumentSubTab" class="" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div><!-- End tabPageQualifications -->
|
||||||
|
</div>
|
||||||
|
</div><!-- End tab-content -->
|
||||||
@@ -3,17 +3,17 @@
|
|||||||
<div class="small-box bg-aqua">
|
<div class="small-box bg-aqua">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>
|
<h3>
|
||||||
People
|
<t>People</t>
|
||||||
</h3>
|
</h3>
|
||||||
<p id="numberOfEmployees">
|
<p id="numberOfEmployees">
|
||||||
#_numberOfEmployees_# Employees
|
#_numberOfEmployees_# <t>Employees</t>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-person-stalker"></i>
|
<i class="ion ion-person-stalker"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="employeeLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="employeeLink">
|
||||||
Manage Employees <i class="fa fa-arrow-circle-right"></i>
|
<t>Manage</t> <t>Employees</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
108
ext/admin/employees/db_update.sql
Normal file
108
ext/admin/employees/db_update.sql
Normal file
@@ -0,0 +1,108 @@
|
|||||||
|
ALTER TABLE Employees ADD COLUMN `status` enum('Active','Terminated') default 'Active';
|
||||||
|
|
||||||
|
create table `ArchivedEmployees` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`ref_id` bigint(20) NOT NULL,
|
||||||
|
`employee_id` varchar(50) default null,
|
||||||
|
`first_name` varchar(100) default '' not null,
|
||||||
|
`last_name` varchar(100) default '' not null,
|
||||||
|
`gender` enum('Male','Female') default NULL,
|
||||||
|
`ssn_num` varchar(100) default '',
|
||||||
|
`nic_num` varchar(100) default '',
|
||||||
|
`other_id` varchar(100) default '',
|
||||||
|
`work_email` varchar(100) default null,
|
||||||
|
`joined_date` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`confirmation_date` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`supervisor` bigint(20) default null,
|
||||||
|
`department` bigint(20) default null,
|
||||||
|
`termination_date` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`notes` text default null,
|
||||||
|
`data` longtext default null,
|
||||||
|
primary key (`id`)
|
||||||
|
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
create table `FieldNameMappings` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`type` varchar(20) NOT NULL,
|
||||||
|
`name` varchar(20) NOT NULL,
|
||||||
|
`textOrig` varchar(200) default null,
|
||||||
|
`textMapped` varchar(200) default null,
|
||||||
|
`display` enum('Form','Table and Form','Hidden') default 'Form',
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
INSERT INTO `FieldNameMappings` (`type`, `name`, `textOrig`, `textMapped`, `display`) VALUES
|
||||||
|
('Employee', 'employee_id', 'Employee Number', 'Employee Number', 'Table and Form'),
|
||||||
|
('Employee', 'first_name', 'First Name', 'First Name', 'Table and Form'),
|
||||||
|
('Employee', 'middle_name', 'Middle Name', 'Middle Name', 'Form'),
|
||||||
|
('Employee', 'last_name', 'Last Name', 'Last Name', 'Table and Form'),
|
||||||
|
('Employee', 'nationality', 'Nationality', 'Nationality', 'Form'),
|
||||||
|
('Employee', 'birthday', 'Date of Birth', 'Date of Birth', 'Form'),
|
||||||
|
('Employee', 'gender', 'Gender', 'Gender', 'Form'),
|
||||||
|
('Employee', 'marital_status', 'Marital Status', 'Marital Status', 'Form'),
|
||||||
|
('Employee', 'ssn_num', 'SSN/NRIC', 'SSN/NRIC', 'Form'),
|
||||||
|
('Employee', 'nic_num', 'NIC', 'NIC', 'Form'),
|
||||||
|
('Employee', 'other_id', 'Other ID', 'Other ID', 'Form'),
|
||||||
|
('Employee', 'driving_license', 'Driving License No', 'Driving License No', 'Form'),
|
||||||
|
('Employee', 'employment_status', 'Employment Status', 'Employment Status', 'Form'),
|
||||||
|
('Employee', 'job_title', 'Job Title', 'Job Title', 'Form'),
|
||||||
|
('Employee', 'pay_grade', 'Pay Grade', 'Pay Grade', 'Form'),
|
||||||
|
('Employee', 'work_station_id', 'Work Station Id', 'Work Station Id', 'Form'),
|
||||||
|
('Employee', 'address1', 'Address Line 1', 'Address Line 1', 'Form'),
|
||||||
|
('Employee', 'address2', 'Address Line 2', 'Address Line 2', 'Form'),
|
||||||
|
('Employee', 'city', 'City', 'City', 'Form'),
|
||||||
|
('Employee', 'country', 'Country', 'Country', 'Form'),
|
||||||
|
('Employee', 'province', 'Province', 'Province', 'Form'),
|
||||||
|
('Employee', 'postal_code', 'Postal/Zip Code', 'Postal/Zip Code', 'Form'),
|
||||||
|
('Employee', 'home_phone', 'Home Phone', 'Home Phone', 'Form'),
|
||||||
|
('Employee', 'mobile_phone', 'Mobile Phone', 'Mobile Phone', 'Table and Form'),
|
||||||
|
('Employee', 'work_phone', 'Work Phone', 'Work Phone', 'Form'),
|
||||||
|
('Employee', 'work_email', 'Work Email', 'Work Email', 'Form'),
|
||||||
|
('Employee', 'private_email', 'Private Email', 'Private Email', 'Form'),
|
||||||
|
('Employee', 'joined_date', 'Joined Date', 'Joined Date', 'Form'),
|
||||||
|
('Employee', 'confirmation_date', 'Confirmation Date', 'Confirmation Date', 'Form'),
|
||||||
|
('Employee', 'termination_date', 'Termination Date', 'Termination Date', 'Form'),
|
||||||
|
('Employee', 'supervisor', 'Supervisor', 'Supervisor', 'Table and Form'),
|
||||||
|
('Employee', 'department', 'Department', 'Department', 'Table and Form'),
|
||||||
|
('Employee', 'notes', 'Notes', 'Notes', 'Form');
|
||||||
|
|
||||||
|
|
||||||
|
create table `CustomFields` (
|
||||||
|
`id` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||||
|
`type` varchar(20) NOT NULL,
|
||||||
|
`name` varchar(20) NOT NULL,
|
||||||
|
`data` text default null,
|
||||||
|
`display` enum('Form','Table and Form','Hidden') default 'Form',
|
||||||
|
`created` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
`updated` DATETIME default '0000-00-00 00:00:00',
|
||||||
|
primary key (`id`)
|
||||||
|
) engine=innodb default charset=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
INSERT INTO `CustomFields` (`type`, `name`, `data`,`display`) VALUES
|
||||||
|
('Employee', 'custom1', '', 'Hidden'),
|
||||||
|
('Employee', 'custom2', '', 'Hidden'),
|
||||||
|
('Employee', 'custom3', '', 'Hidden'),
|
||||||
|
('Employee', 'custom4', '', 'Hidden'),
|
||||||
|
('Employee', 'custom5', '', 'Hidden'),
|
||||||
|
('Employee', 'custom6', '', 'Hidden'),
|
||||||
|
('Employee', 'custom7', '', 'Hidden'),
|
||||||
|
('Employee', 'custom8', '', 'Hidden'),
|
||||||
|
('Employee', 'custom9', '', 'Hidden'),
|
||||||
|
('Employee', 'custom10', '', 'Hidden');
|
||||||
|
|
||||||
|
|
||||||
|
Alter table `Employees` MODIFY COLUMN `middle_name` varchar(100) default null;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `last_name` varchar(100) default null;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `ssn_num` varchar(100) default NULL;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `nic_num` varchar(100) default NULL;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `other_id` varchar(100) default NULL;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `driving_license` varchar(100) default NULL;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `work_station_id` varchar(100) default NULL;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `address1` varchar(100) default NULL;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `address2` varchar(100) default NULL;
|
||||||
|
Alter table `Employees` MODIFY COLUMN `city` varchar(150) default NULL;
|
||||||
@@ -4,10 +4,41 @@ $moduleName = 'employees';
|
|||||||
define('MODULE_PATH',dirname(__FILE__));
|
define('MODULE_PATH',dirname(__FILE__));
|
||||||
include APP_BASE_PATH.'header.php';
|
include APP_BASE_PATH.'header.php';
|
||||||
include APP_BASE_PATH.'modulejslibs.inc.php';
|
include APP_BASE_PATH.'modulejslibs.inc.php';
|
||||||
|
$fieldNameMap = BaseService::getInstance()->getFieldNameMappings("Employee");
|
||||||
|
$customFields = BaseService::getInstance()->getCustomFields("Employee");
|
||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabEmployee" href="#tabPageEmployee">Employees</a></li>
|
<?php if($user->user_level != "Admin"){
|
||||||
|
?>
|
||||||
|
<li class="active"><a id="tabEmployee" href="#tabPageEmployee"><?=LanguageManager::tran('Employees (Direct Reports)')?></a></li>
|
||||||
|
<?php }else{ ?>
|
||||||
|
<li class="active"><a id="tabEmployee" href="#tabPageEmployee"><?=LanguageManager::tran('Employees')?></a></li>
|
||||||
|
<?php }?>
|
||||||
|
|
||||||
|
<?php if($user->user_level == "Admin"){
|
||||||
|
?>
|
||||||
|
<li><a id="tabEmployeeSkill" href="#tabPageEmployeeSkill"><?=LanguageManager::tran('Skills')?></a></li>
|
||||||
|
<li><a id="tabEmployeeEducation" href="#tabPageEmployeeEducation"><?=LanguageManager::tran('Education')?></a></li>
|
||||||
|
<li><a id="tabEmployeeCertification" href="#tabPageEmployeeCertification"><?=LanguageManager::tran('Certifications')?></a></li>
|
||||||
|
<li><a id="tabEmployeeLanguage" href="#tabPageEmployeeLanguage"><?=LanguageManager::tran('Languages')?></a></li>
|
||||||
|
<li><a id="tabEmployeeDependent" href="#tabPageEmployeeDependent"><?=LanguageManager::tran('Dependents')?></a></li>
|
||||||
|
<li><a id="tabEmergencyContact" href="#tabPageEmergencyContact"><?=LanguageManager::tran('Emergency Contacts')?></a></li>
|
||||||
|
<?php if (class_exists('DocumentsAdminManager')) {?>
|
||||||
|
<li><a id="tabEmployeeDocument" href="#tabPageEmployeeDocument"><?=LanguageManager::tran('Documents')?></a></li>
|
||||||
|
<?php } ?>
|
||||||
|
<?php }?>
|
||||||
|
<?php if($user->user_level == "Admin"){
|
||||||
|
?>
|
||||||
|
<li class="dropdown">
|
||||||
|
<a href="#" id="terminatedEmployeeMenu" class="dropdown-toggle" data-toggle="dropdown" aria-controls="terminatedEmployeeMenu-contents"><?=LanguageManager::tran('Deactivated Employees')?> <span class="caret"></span></a>
|
||||||
|
<ul class="dropdown-menu" role="menu" aria-labelledby="terminatedEmployeeMenu" id="terminatedEmployeeMenu-contents">
|
||||||
|
<li><a id="tabTerminatedEmployee" href="#tabPageTerminatedEmployee"><?=LanguageManager::tran('Temporarily Deactivated Employees')?></a></li>
|
||||||
|
<li><a id="tabArchivedEmployee" href="#tabPageArchivedEmployee"><?=LanguageManager::tran('Terminated Employee Data')?></a></li>
|
||||||
|
</ul>
|
||||||
|
</li>
|
||||||
|
<?php }?>
|
||||||
|
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
@@ -19,16 +50,161 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageEmployeeSkill">
|
||||||
|
<div id="EmployeeSkill" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmployeeSkillForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageEmployeeEducation">
|
||||||
|
<div id="EmployeeEducation" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmployeeEducationForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageEmployeeCertification">
|
||||||
|
<div id="EmployeeCertification" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmployeeCertificationForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageEmployeeLanguage">
|
||||||
|
<div id="EmployeeLanguage" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmployeeLanguageForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageEmployeeDependent">
|
||||||
|
<div id="EmployeeDependent" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmployeeDependentForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageEmergencyContact">
|
||||||
|
<div id="EmergencyContact" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmergencyContactForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="tab-pane" id="tabPageArchivedEmployee">
|
||||||
|
<div id="ArchivedEmployee" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="ArchivedEmployeeForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageTerminatedEmployee">
|
||||||
|
<div id="TerminatedEmployee" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="TerminatedEmployeeForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<?php if (class_exists('DocumentsAdminManager')) {?>
|
||||||
|
<div class="tab-pane" id="tabPageEmployeeDocument">
|
||||||
|
<div id="EmployeeDocument" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmployeeDocumentForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<?php } ?>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<script>
|
<script>
|
||||||
var modJsList = new Array();
|
var modJsList = new Array();
|
||||||
modJsList['tabEmployee'] = new EmployeeAdapter('Employee');
|
<?php if($user->user_level != "Admin"){
|
||||||
|
?>
|
||||||
|
modJsList['tabEmployee'] = new EmployeeAdapter('Employee','Employee',{"status":"Active"});
|
||||||
|
modJsList['tabEmployee'].setShowAddNew(false);
|
||||||
|
<?php
|
||||||
|
}else{
|
||||||
|
?>
|
||||||
|
modJsList['tabEmployee'] = new EmployeeAdapter('Employee','Employee',{"status":"Active"});
|
||||||
|
<?php
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
|
||||||
modJsList['tabEmployee'].setRemoteTable(true);
|
modJsList['tabEmployee'].setRemoteTable(true);
|
||||||
|
modJsList['tabEmployee'].setFieldNameMap(<?=json_encode($fieldNameMap)?>);
|
||||||
|
modJsList['tabEmployee'].setCustomFields(<?=json_encode($customFields)?>);
|
||||||
|
|
||||||
|
modJsList['tabEmployeeSkill'] = new EmployeeSkillAdapter('EmployeeSkill');
|
||||||
|
modJsList['tabEmployeeSkill'].setRemoteTable(true);
|
||||||
|
|
||||||
|
modJsList['tabEmployeeEducation'] = new EmployeeEducationAdapter('EmployeeEducation');
|
||||||
|
modJsList['tabEmployeeEducation'].setRemoteTable(true);
|
||||||
|
|
||||||
|
modJsList['tabEmployeeCertification'] = new EmployeeCertificationAdapter('EmployeeCertification');
|
||||||
|
modJsList['tabEmployeeCertification'].setRemoteTable(true);
|
||||||
|
|
||||||
|
modJsList['tabEmployeeLanguage'] = new EmployeeLanguageAdapter('EmployeeLanguage');
|
||||||
|
modJsList['tabEmployeeLanguage'].setRemoteTable(true);
|
||||||
|
|
||||||
|
modJsList['tabEmployeeDependent'] = new EmployeeDependentAdapter('EmployeeDependent');
|
||||||
|
modJsList['tabEmployeeDependent'].setRemoteTable(true);
|
||||||
|
|
||||||
|
modJsList['tabEmergencyContact'] = new EmergencyContactAdapter('EmergencyContact');
|
||||||
|
modJsList['tabEmergencyContact'].setRemoteTable(true);
|
||||||
|
|
||||||
|
modJsList['tabEmployeeImmigration'] = new EmployeeImmigrationAdapter('EmployeeImmigration');
|
||||||
|
modJsList['tabEmployeeImmigration'].setRemoteTable(true);
|
||||||
|
|
||||||
|
modJsList['tabArchivedEmployee'] = new ArchivedEmployeeAdapter('ArchivedEmployee');
|
||||||
|
modJsList['tabArchivedEmployee'].setRemoteTable(true);
|
||||||
|
modJsList['tabArchivedEmployee'].setShowAddNew(false);
|
||||||
|
|
||||||
|
modJsList['tabTerminatedEmployee'] = new TerminatedEmployeeAdapter('Employee','TerminatedEmployee',{"status":"Terminated"});
|
||||||
|
modJsList['tabTerminatedEmployee'].setRemoteTable(true);
|
||||||
|
modJsList['tabTerminatedEmployee'].setShowAddNew(false);
|
||||||
|
|
||||||
|
<?php if (class_exists('DocumentsAdminManager')) {?>
|
||||||
|
modJsList['tabEmployeeDocument'] = new EmployeeDocumentAdapter('EmployeeDocument','EmployeeDocument');
|
||||||
|
modJsList['tabTerminatedEmployee'].setRemoteTable(true);
|
||||||
|
<?php } ?>
|
||||||
|
|
||||||
var modJs = modJsList['tabEmployee'];
|
var modJs = modJsList['tabEmployee'];
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="modal" id="createUserModel" tabindex="-1" role="dialog" aria-labelledby="messageModelLabel" aria-hidden="true">
|
||||||
|
<div class="modal-dialog">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true"><li class="fa fa-times"/></button>
|
||||||
|
<h3 style="font-size: 17px;"><?=LanguageManager::tran('Employee Saved Successfully')?></h3>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<?=LanguageManager::tran('Employee needs a User to login to IceHrm. Do you want to create a user for this employee now?')?> <br/><br/><?=LanguageManager::tran('You can do this later through Users module if required.')?>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button class="btn btn-primary" onclick="modJs.createUser();">Yes</button>
|
||||||
|
<button class="btn" onclick="modJs.closeCreateUser();">No</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<?php include APP_BASE_PATH.'footer.php';?>
|
<?php include APP_BASE_PATH.'footer.php';?>
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
82
ext/admin/fieldnames/api/FieldnamesAdminManager.php
Normal file
82
ext/admin/fieldnames/api/FieldnamesAdminManager.php
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
<?php
|
||||||
|
if (!class_exists('FieldnamesAdminManager')) {
|
||||||
|
class FieldnamesAdminManager extends AbstractModuleManager{
|
||||||
|
public function initializeUserClasses(){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function initializeFieldMappings(){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function initializeDatabaseErrorMappings(){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setupModuleClassDefinitions(){
|
||||||
|
$this->addModelClass('FieldNameMapping');
|
||||||
|
$this->addModelClass('CustomField');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!class_exists('FieldNameMapping')) {
|
||||||
|
class FieldNameMapping extends ICEHRM_Record {
|
||||||
|
var $_table = 'FieldNameMappings';
|
||||||
|
|
||||||
|
public function getAdminAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserAccess(){
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAnonymousAccess(){
|
||||||
|
return array("get","element");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!class_exists('CustomField')) {
|
||||||
|
class CustomField extends ICEHRM_Record {
|
||||||
|
var $_table = 'CustomFields';
|
||||||
|
|
||||||
|
public function getAdminAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserAccess(){
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAnonymousAccess(){
|
||||||
|
return array("get","element");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateSave($obj){
|
||||||
|
$type = $obj->type;
|
||||||
|
$baseObject = new $type();
|
||||||
|
$fields = $baseObject->getObjectKeys();
|
||||||
|
if(isset($fields[$obj->name])){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Column name already exists by default");
|
||||||
|
}
|
||||||
|
|
||||||
|
$cf = new CustomField();
|
||||||
|
if(empty($obj->id)){
|
||||||
|
$cf->Load("type = ? and name = ?",array($obj->type, $obj->name));
|
||||||
|
if($cf->name == $obj->name){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Another custom field with same name has already been added");
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
$cf->Load("type = ? and name = ? and id <> ?",array($obj->type, $obj->name, $obj->id));
|
||||||
|
if($cf->name == $obj->name){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Another custom field with same name has already been added");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return new IceResponse(IceResponse::SUCCESS,"");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
57
ext/admin/fieldnames/index.php
Normal file
57
ext/admin/fieldnames/index.php
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
<?php
|
||||||
|
/*
|
||||||
|
This file is part of Ice Framework.
|
||||||
|
|
||||||
|
------------------------------------------------------------------
|
||||||
|
|
||||||
|
Original work Copyright (c) 2012 [Gamonoid Media Pvt. Ltd]
|
||||||
|
Developer: Thilina Hasantha (thilina.hasantha[at]gmail.com / facebook.com/thilinah)
|
||||||
|
*/
|
||||||
|
|
||||||
|
$moduleName = 'fieldnames';
|
||||||
|
define('MODULE_PATH',dirname(__FILE__));
|
||||||
|
include APP_BASE_PATH.'header.php';
|
||||||
|
include APP_BASE_PATH.'modulejslibs.inc.php';
|
||||||
|
?><div class="span9">
|
||||||
|
|
||||||
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
|
<li class="active"><a id="tabEmployeeFieldName" href="#tabPageEmployeeFieldName"><?=LanguageManager::tran('Employee Field Names')?></a></li>
|
||||||
|
<li><a id="tabEmployeeCustomField" href="#tabPageEmployeeCustomField"><?=LanguageManager::tran('Employee Custom Fields')?></a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<div class="tab-content">
|
||||||
|
<div class="tab-pane active" id="tabPageEmployeeFieldName">
|
||||||
|
<div id="EmployeeFieldName" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmployeeFieldNameForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="tab-pane" id="tabPageEmployeeCustomField">
|
||||||
|
<div id="EmployeeCustomField" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="EmployeeCustomFieldForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<script>
|
||||||
|
var modJsList = new Array();
|
||||||
|
|
||||||
|
modJsList['tabEmployeeFieldName'] = new FieldNameAdapter('FieldNameMapping','EmployeeFieldName',{"type":"Employee"});
|
||||||
|
modJsList['tabEmployeeFieldName'].setRemoteTable(true);
|
||||||
|
modJsList['tabEmployeeFieldName'].setShowAddNew(false);
|
||||||
|
|
||||||
|
modJsList['tabEmployeeCustomField'] = new CustomFieldAdapter('CustomField','EmployeeCustomField',{"type":"Employee"},"display_order desc");
|
||||||
|
modJsList['tabEmployeeCustomField'].setRemoteTable(true);
|
||||||
|
modJsList['tabEmployeeCustomField'].setTableType("Employee");
|
||||||
|
|
||||||
|
|
||||||
|
var modJs = modJsList['tabEmployeeFieldName'];
|
||||||
|
|
||||||
|
</script>
|
||||||
|
<?php include APP_BASE_PATH.'footer.php';?>
|
||||||
145
ext/admin/fieldnames/lib.js
Normal file
145
ext/admin/fieldnames/lib.js
Normal file
@@ -0,0 +1,145 @@
|
|||||||
|
/**
|
||||||
|
* Author: Thilina Hasantha
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FieldNameAdapter
|
||||||
|
*/
|
||||||
|
|
||||||
|
function FieldNameAdapter(endPoint,tab,filter,orderBy) {
|
||||||
|
this.initAdapter(endPoint,tab,filter,orderBy);
|
||||||
|
}
|
||||||
|
|
||||||
|
FieldNameAdapter.inherits(AdapterBase);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FieldNameAdapter.method('getDataMapping', function() {
|
||||||
|
return [
|
||||||
|
"id",
|
||||||
|
"name",
|
||||||
|
"textOrig",
|
||||||
|
"textMapped",
|
||||||
|
"display"
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
FieldNameAdapter.method('getHeaders', function() {
|
||||||
|
return [
|
||||||
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
|
{ "sTitle": "Name" },
|
||||||
|
{ "sTitle": "Original Text"},
|
||||||
|
{ "sTitle": "Mapped Text"},
|
||||||
|
{ "sTitle": "Display Status"}
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
FieldNameAdapter.method('getFormFields', function() {
|
||||||
|
return [
|
||||||
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
|
[ "type", {"label":"Type","type":"placeholder","validation":""}],
|
||||||
|
[ "name", {"label":"Name","type":"placeholder","validation":""}],
|
||||||
|
[ "textOrig", {"label":"Original Text","type":"placeholder","validation":""}],
|
||||||
|
[ "textMapped", {"label":"Mapped Text","type":"text","validation":""}],
|
||||||
|
[ "display", {"label":"Display Status","type":"select","source":[["Form","Form"],["Table and Form","Table and Form"],["Hidden","Hidden"]]}]
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
function CustomFieldAdapter(endPoint,tab,filter,orderBy) {
|
||||||
|
this.initAdapter(endPoint,tab,filter,orderBy);
|
||||||
|
this.tableType = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
CustomFieldAdapter.inherits(AdapterBase);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
CustomFieldAdapter.method('getDataMapping', function() {
|
||||||
|
return [
|
||||||
|
"id",
|
||||||
|
"name",
|
||||||
|
"display",
|
||||||
|
"display_order"
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
CustomFieldAdapter.method('getHeaders', function() {
|
||||||
|
return [
|
||||||
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
|
{ "sTitle": "Name" },
|
||||||
|
{ "sTitle": "Display Status"},
|
||||||
|
{ "sTitle": "Priority"}
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
CustomFieldAdapter.method('getFormFields', function() {
|
||||||
|
return [
|
||||||
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
|
//[ "type", {"label":"Type","type":"placeholder","validation":""}],
|
||||||
|
[ "name", {"label":"Name","type":"text","validation":""}],
|
||||||
|
[ "display", {"label":"Display Status","type":"select","source":[["Form","Show"],["Hidden","Hidden"]]}],
|
||||||
|
[ "field_type", {"label":"Field Type","type":"select","source":[["text","Text Field"],["textarea","Text Area"],["select","Select"],["select2","Select2"],["select2multi","Multi Select"],["fileupload","File Upload"],["date","Date"],["datetime","Date Time"],["time","Time"]]}],
|
||||||
|
[ "field_label", {"label":"Field Label","type":"text","validation":""}],
|
||||||
|
[ "field_validation", {"label":"Validation","type":"select","validation":"none","sort":"none","source":[["","Required"],["none","None"],["number","Number"],["numberOrEmpty","Number or Empty"],["float","Decimal"],["email","Email"],["emailOrEmpty","Email or Empty"]]}],
|
||||||
|
[ "field_options", {"label":"Field Options","type":"datagroup",
|
||||||
|
"form":[
|
||||||
|
[ "label", {"label":"Label","type":"text","validation":""}],
|
||||||
|
[ "value", {"label":"Value","type":"text","validation":"none"}]
|
||||||
|
],
|
||||||
|
"html":'<div id="#_id_#" class="panel panel-default"><div class="panel-body">#_delete_##_edit_#<span style="color:#999;font-size:13px;font-weight:bold">#_label_#</span>:#_value_#</div></div>',
|
||||||
|
"validation":"none"
|
||||||
|
}],
|
||||||
|
[ "display_order", {"label":"Priority","type":"text","validation":"number"}],
|
||||||
|
[ "display_section", {"label":"Display Section","type":"text","validation":""}]
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
CustomFieldAdapter.method('setTableType', function(type) {
|
||||||
|
this.tableType = type;
|
||||||
|
});
|
||||||
|
|
||||||
|
CustomFieldAdapter.method('doCustomValidation', function(params) {
|
||||||
|
var validateName= function (str) {
|
||||||
|
var name = /^[a-z][a-z0-9\._]+$/;
|
||||||
|
return str != null && name.test(str);
|
||||||
|
};
|
||||||
|
|
||||||
|
if(!validateName(params.name)){
|
||||||
|
return "Invalid name for custom field";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return null;
|
||||||
|
});
|
||||||
|
|
||||||
|
CustomFieldAdapter.method('forceInjectValuesBeforeSave', function(params) {
|
||||||
|
|
||||||
|
|
||||||
|
//Build data field
|
||||||
|
var data = [params.name], options = [], optionsData;
|
||||||
|
data.push({});
|
||||||
|
data[1]['label'] = params.field_label;
|
||||||
|
data[1]['type'] = params.field_type;
|
||||||
|
data[1]['validation'] = params.field_validation;
|
||||||
|
if(["select","select2","select2multi"].indexOf(params.field_type) >= 0){
|
||||||
|
optionsData = JSON.parse(params.field_options);
|
||||||
|
for(index in optionsData){
|
||||||
|
options.push([optionsData[index].value, optionsData[index].label]);
|
||||||
|
}
|
||||||
|
data[1]['source'] = options;
|
||||||
|
}
|
||||||
|
if(params.field_validation == null || params.field_validation == undefined){
|
||||||
|
params.field_validation = "";
|
||||||
|
}
|
||||||
|
params.data = JSON.stringify(data);
|
||||||
|
params.type = this.tableType;
|
||||||
|
return params;
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
11
ext/admin/fieldnames/meta.json
Normal file
11
ext/admin/fieldnames/meta.json
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"label":"Field Names Setup",
|
||||||
|
"menu":"System",
|
||||||
|
"order":"7",
|
||||||
|
"icon":"fa-sort-alpha-asc",
|
||||||
|
"user_levels":["Admin"],
|
||||||
|
|
||||||
|
"permissions":
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -20,7 +20,6 @@ along with iCE Hrm. If not, see <http://www.gnu.org/licenses/>.
|
|||||||
Original work Copyright (c) 2012 [Gamonoid Media Pvt. Ltd]
|
Original work Copyright (c) 2012 [Gamonoid Media Pvt. Ltd]
|
||||||
Developer: Thilina Hasantha (thilina.hasantha[at]gmail.com / facebook.com/thilinah)
|
Developer: Thilina Hasantha (thilina.hasantha[at]gmail.com / facebook.com/thilinah)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$moduleName = 'jobs';
|
$moduleName = 'jobs';
|
||||||
define('MODULE_PATH',dirname(__FILE__));
|
define('MODULE_PATH',dirname(__FILE__));
|
||||||
include APP_BASE_PATH.'header.php';
|
include APP_BASE_PATH.'header.php';
|
||||||
@@ -28,9 +27,9 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabJobTitles" href="#tabPageJobTitles">Job Titles</a></li>
|
<li class="active"><a id="tabJobTitles" href="#tabPageJobTitles"><?=LanguageManager::tran('Job Titles')?></a></li>
|
||||||
<li><a id="tabPayGrades" href="#tabPagePayGrades">Pay Grades</a></li>
|
<li><a id="tabPayGrades" href="#tabPagePayGrades"><?=LanguageManager::tran('Pay Grades')?></a></li>
|
||||||
<li><a id="tabEmploymentStatus" href="#tabPageEmploymentStatus">Employment Status</a></li>
|
<li><a id="tabEmploymentStatus" href="#tabPageEmploymentStatus"><?=LanguageManager::tran('Employment Status')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
|
|||||||
@@ -28,8 +28,8 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabCompanyLoan" href="#tabPageCompanyLoan">Loan Types</a></li>
|
<li class="active"><a id="tabCompanyLoan" href="#tabPageCompanyLoan"><?=LanguageManager::tran('Loan Types')?></a></li>
|
||||||
<li><a id="tabEmployeeCompanyLoan" href="#tabPageEmployeeCompanyLoan">Employee Loans</a></li>
|
<li><a id="tabEmployeeCompanyLoan" href="#tabPageEmployeeCompanyLoan"><?=LanguageManager::tran('Employee Loans')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"Admin":"fa-cubes",
|
"Admin":"fa-cubes",
|
||||||
"Employees":"fa-users",
|
"Employees":"fa-users",
|
||||||
"Reports":"fa-file-text",
|
"Admin Reports":"fa-file-text",
|
||||||
"System":"fa-cogs",
|
"System":"fa-cogs",
|
||||||
"Salary Details":"fa-money"
|
"Payroll":"fa-money"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ if (!class_exists('MetadataAdminManager')) {
|
|||||||
$this->addModelClass('Nationality');
|
$this->addModelClass('Nationality');
|
||||||
$this->addModelClass('ImmigrationStatus');
|
$this->addModelClass('ImmigrationStatus');
|
||||||
$this->addModelClass('Ethnicity');
|
$this->addModelClass('Ethnicity');
|
||||||
|
$this->addModelClass('CalculationHook');
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -42,6 +43,25 @@ if (!class_exists('Country')) {
|
|||||||
public function getAnonymousAccess(){
|
public function getAnonymousAccess(){
|
||||||
return array("get","element");
|
return array("get","element");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function Find($whereOrderBy,$bindarr=false,$pkeysArr=false,$extra=array()){
|
||||||
|
$allowedCountriesStr = SettingsManager::getInstance()->getSetting('System: Allowed Countries');
|
||||||
|
$allowedCountries = array();
|
||||||
|
if(!empty($allowedCountriesStr)){
|
||||||
|
$allowedCountries = json_decode($allowedCountriesStr,true);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!empty($allowedCountries)){
|
||||||
|
$res = parent::Find("id in (".implode(",",$allowedCountries).")" , array());
|
||||||
|
if(empty($res)){
|
||||||
|
SettingsManager::getInstance()->setSetting('System: Allowed Countries','');
|
||||||
|
}else{
|
||||||
|
return $res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::Find($whereOrderBy, $bindarr, $pkeysArr, $extra);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -79,6 +99,25 @@ if (!class_exists('CurrencyType')) {
|
|||||||
public function getAnonymousAccess(){
|
public function getAnonymousAccess(){
|
||||||
return array("get","element");
|
return array("get","element");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function Find($whereOrderBy,$bindarr=false,$pkeysArr=false,$extra=array()){
|
||||||
|
$allowedCountriesStr = SettingsManager::getInstance()->getSetting('System: Allowed Currencies');
|
||||||
|
$allowedCountries = array();
|
||||||
|
if(!empty($allowedCountriesStr)){
|
||||||
|
$allowedCountries = json_decode($allowedCountriesStr,true);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!empty($allowedCountries)){
|
||||||
|
$res = parent::Find("id in (".implode(",",$allowedCountries).")" , array());
|
||||||
|
if(empty($res)){
|
||||||
|
SettingsManager::getInstance()->setSetting('System: Allowed Currencies','');
|
||||||
|
}else{
|
||||||
|
return $res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::Find($whereOrderBy, $bindarr, $pkeysArr, $extra);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -98,6 +137,27 @@ if (!class_exists('Nationality')) {
|
|||||||
public function getAnonymousAccess(){
|
public function getAnonymousAccess(){
|
||||||
return array("get","element");
|
return array("get","element");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function Find($whereOrderBy,$bindarr=false,$pkeysArr=false,$extra=array()){
|
||||||
|
$allowedCountriesStr = SettingsManager::getInstance()->getSetting('System: Allowed Nationality');
|
||||||
|
$allowedCountries = array();
|
||||||
|
if(!empty($allowedCountriesStr)){
|
||||||
|
$allowedCountries = json_decode($allowedCountriesStr,true);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!empty($allowedCountries)){
|
||||||
|
$res = parent::Find("id in (".implode(",",$allowedCountries).")" , array());
|
||||||
|
if(empty($res)){
|
||||||
|
SettingsManager::getInstance()->setSetting('System: Allowed Currencies','');
|
||||||
|
}else{
|
||||||
|
return $res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::Find($whereOrderBy, $bindarr, $pkeysArr, $extra);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -139,6 +199,68 @@ if (!class_exists('Ethnicity')) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!class_exists('CalculationHook')) {
|
||||||
|
class CalculationHook extends ICEHRM_Record {
|
||||||
|
var $_table = 'CalculationHooks';
|
||||||
|
|
||||||
|
public function getAdminAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserAccess(){
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAnonymousAccess(){
|
||||||
|
return array("get","element");
|
||||||
|
}
|
||||||
|
|
||||||
|
function Find($whereOrderBy,$bindarr=false,$pkeysArr=false,$extra=array()){
|
||||||
|
return BaseService::getInstance()->getCalculationHooks();
|
||||||
|
}
|
||||||
|
|
||||||
|
function Load($where=null,$bindarr=false){
|
||||||
|
return BaseService::getInstance()->getCalculationHook($bindarr[0]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!class_exists('CustomFieldValue')) {
|
||||||
|
class CustomFieldValue extends ICEHRM_Record {
|
||||||
|
var $_table = 'CustomFieldValues';
|
||||||
|
|
||||||
|
public function getAdminAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAnonymousAccess(){
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!class_exists('SupportedLanguage')) {
|
||||||
|
class SupportedLanguage extends ICEHRM_Record {
|
||||||
|
var $_table = 'SupportedLanguages';
|
||||||
|
|
||||||
|
public function getAdminAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserAccess(){
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAnonymousAccess(){
|
||||||
|
return array("get","element");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -32,7 +32,6 @@ $moduleBuilder->addModuleOrGroup(new ModuleTab('Country','Country','Countries','
|
|||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('Province','Province','Provinces','ProvinceAdapter','',''));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('Province','Province','Provinces','ProvinceAdapter','',''));
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('CurrencyType','CurrencyType','Currency Types','CurrencyTypeAdapter','',''));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('CurrencyType','CurrencyType','Currency Types','CurrencyTypeAdapter','',''));
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('Nationality','Nationality','Nationality','NationalityAdapter','',''));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('Nationality','Nationality','Nationality','NationalityAdapter','',''));
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('Nationality','Nationality','Nationality','NationalityAdapter','',''));
|
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('Ethnicity','Ethnicity','Ethnicity','EthnicityAdapter','',''));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('Ethnicity','Ethnicity','Ethnicity','EthnicityAdapter','',''));
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('ImmigrationStatus','ImmigrationStatus','Immigration Status','ImmigrationStatusAdapter','',''));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('ImmigrationStatus','ImmigrationStatus','Immigration Status','ImmigrationStatusAdapter','',''));
|
||||||
|
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabModule" href="#tabPageModule">Modules</a></li>
|
<li class="active"><a id="tabModule" href="#tabPageModule"><?=LanguageManager::tran('Modules')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
@@ -46,9 +46,9 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
<script>
|
<script>
|
||||||
var modJsList = new Array();
|
var modJsList = new Array();
|
||||||
|
|
||||||
modJsList['moduleModule'] = new ModuleAdapter('Module','Module');
|
modJsList['tabModule'] = new ModuleAdapter('Module','Module');
|
||||||
modJsList['moduleModule'].setShowAddNew(false);
|
modJsList['tabModule'].setShowAddNew(false);
|
||||||
var modJs = modJsList['moduleModule'];
|
var modJs = modJsList['tabModule'];
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
<?php include APP_BASE_PATH.'footer.php';?>
|
<?php include APP_BASE_PATH.'footer.php';?>
|
||||||
@@ -58,7 +58,7 @@ ModuleAdapter.method('getActionButtonsHtml', function(id,data) {
|
|||||||
var nonEditableFields = {};
|
var nonEditableFields = {};
|
||||||
nonEditableFields["admin_Company Structure"] = 1;
|
nonEditableFields["admin_Company Structure"] = 1;
|
||||||
nonEditableFields["admin_Employees"] = 1;
|
nonEditableFields["admin_Employees"] = 1;
|
||||||
nonEditableFields["admin_Jobs"] = 1;
|
nonEditableFields["admin_Job Details Setup"] = 1;
|
||||||
nonEditableFields["admin_Leaves"] = 1;
|
nonEditableFields["admin_Leaves"] = 1;
|
||||||
nonEditableFields["admin_Manage Modules"] = 1;
|
nonEditableFields["admin_Manage Modules"] = 1;
|
||||||
nonEditableFields["admin_Projects"] = 1;
|
nonEditableFields["admin_Projects"] = 1;
|
||||||
@@ -66,9 +66,10 @@ ModuleAdapter.method('getActionButtonsHtml', function(id,data) {
|
|||||||
nonEditableFields["admin_Settings"] = 1;
|
nonEditableFields["admin_Settings"] = 1;
|
||||||
nonEditableFields["admin_Users"] = 1;
|
nonEditableFields["admin_Users"] = 1;
|
||||||
nonEditableFields["admin_Upgrade"] = 1;
|
nonEditableFields["admin_Upgrade"] = 1;
|
||||||
nonEditableFields["admin_Upgrade"] = 1;
|
nonEditableFields["admin_Dashboard"] = 1;
|
||||||
|
|
||||||
nonEditableFields["user_Basic Information"] = 1;
|
nonEditableFields["user_Basic Information"] = 1;
|
||||||
|
nonEditableFields["user_Dashboard"] = 1;
|
||||||
|
|
||||||
if(nonEditableFields[data[3]+"_"+data[1]] == 1){
|
if(nonEditableFields[data[3]+"_"+data[1]] == 1){
|
||||||
return "";
|
return "";
|
||||||
|
|||||||
@@ -1,274 +0,0 @@
|
|||||||
/**
|
|
||||||
* Author: Thilina Hasantha
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* SalaryComponentTypeAdapter
|
|
||||||
*/
|
|
||||||
|
|
||||||
function SalaryComponentTypeAdapter(endPoint,tab,filter,orderBy) {
|
|
||||||
this.initAdapter(endPoint,tab,filter,orderBy);
|
|
||||||
}
|
|
||||||
|
|
||||||
SalaryComponentTypeAdapter.inherits(AdapterBase);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
SalaryComponentTypeAdapter.method('getDataMapping', function() {
|
|
||||||
return [
|
|
||||||
"id",
|
|
||||||
"code",
|
|
||||||
"name"
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
SalaryComponentTypeAdapter.method('getHeaders', function() {
|
|
||||||
return [
|
|
||||||
{ "sTitle": "ID" ,"bVisible":false},
|
|
||||||
{ "sTitle": "Code" },
|
|
||||||
{ "sTitle": "Name"}
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
SalaryComponentTypeAdapter.method('getFormFields', function() {
|
|
||||||
return [
|
|
||||||
[ "id", {"label":"ID","type":"hidden"}],
|
|
||||||
[ "code", {"label":"Code","type":"text","validation":""}],
|
|
||||||
[ "name", {"label":"Name","type":"text","validation":""}]
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* SalaryComponentAdapter
|
|
||||||
*/
|
|
||||||
|
|
||||||
function SalaryComponentAdapter(endPoint,tab,filter,orderBy) {
|
|
||||||
this.initAdapter(endPoint,tab,filter,orderBy);
|
|
||||||
}
|
|
||||||
|
|
||||||
SalaryComponentAdapter.inherits(AdapterBase);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
SalaryComponentAdapter.method('getDataMapping', function() {
|
|
||||||
return [
|
|
||||||
"id",
|
|
||||||
"name",
|
|
||||||
"componentType",
|
|
||||||
"details"
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
SalaryComponentAdapter.method('getHeaders', function() {
|
|
||||||
return [
|
|
||||||
{ "sTitle": "ID" ,"bVisible":false},
|
|
||||||
{ "sTitle": "Name" },
|
|
||||||
{ "sTitle": "Salary Component Type" },
|
|
||||||
{ "sTitle": "Details"}
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
SalaryComponentAdapter.method('getFormFields', function() {
|
|
||||||
return [
|
|
||||||
[ "id", {"label":"ID","type":"hidden"}],
|
|
||||||
[ "name", {"label":"Name","type":"text","validation":""}],
|
|
||||||
[ "componentType", {"label":"Salary Component Type","type":"select2","remote-source":["SalaryComponentType","id","name"]}],
|
|
||||||
[ "details", {"label":"Details","type":"textarea","validation":"none"}]
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* DeductionAdapter
|
|
||||||
*/
|
|
||||||
|
|
||||||
function DeductionAdapter(endPoint,tab,filter,orderBy) {
|
|
||||||
this.initAdapter(endPoint,tab,filter,orderBy);
|
|
||||||
}
|
|
||||||
|
|
||||||
DeductionAdapter.inherits(AdapterBase);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
DeductionAdapter.method('getDataMapping', function() {
|
|
||||||
return [
|
|
||||||
"id",
|
|
||||||
"name",
|
|
||||||
"contributor",
|
|
||||||
"type",
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
DeductionAdapter.method('getHeaders', function() {
|
|
||||||
return [
|
|
||||||
{ "sTitle": "ID" ,"bVisible":false},
|
|
||||||
{ "sTitle": "Name" },
|
|
||||||
{ "sTitle": "Contributor"},
|
|
||||||
{ "sTitle": "Deduction Type"}
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
DeductionAdapter.method('getFormFields', function() {
|
|
||||||
|
|
||||||
var rangeAmounts = [ "rangeAmounts", {"label":"Deduction Amounts","type":"datagroup",
|
|
||||||
"form":[
|
|
||||||
[ "lowerCondition", {"label":"Lower Limit Condition","type":"select","source":[["No Lower Limit","No Lower Limit"],[">","Greater than"],[">=","Greater than or Equal"]]}],
|
|
||||||
[ "lowerLimit", {"label":"Lower Limit","type":"text","validation":"none"}],
|
|
||||||
[ "upperCondition", {"label":"Upper Limit Condition","type":"select","source":[["No Upper Limit","No Upper Limit"],["<","Less than"],["<=","Less than or Equal"]]}],
|
|
||||||
[ "upperLimit", {"label":"Upper Limit","type":"text","validation":"none"}],
|
|
||||||
[ "amount", {"label":"Value","type":"text","validation":"float"}]
|
|
||||||
],
|
|
||||||
"html":'<div id="#_id_#" class="panel panel-default">#_delete_##_edit_#<div class="panel-body">#_renderFunction_#</div></div>',
|
|
||||||
"validation":"none",
|
|
||||||
"render":function(item){
|
|
||||||
var output = "";
|
|
||||||
if(item.lowerCondition != "No Lower Limit"){
|
|
||||||
output += item.lowerLimit + " " + item.lowerCondition + " ";
|
|
||||||
output += " and ";
|
|
||||||
}
|
|
||||||
|
|
||||||
if(item.upperCondition != "No Upper Limit"){
|
|
||||||
output += item.upperCondition + " " + item.upperLimit + " ";
|
|
||||||
}
|
|
||||||
if(output == ""){
|
|
||||||
return "Deduction is "+item.amount + " for all ranges";
|
|
||||||
}else{
|
|
||||||
return "If salary component "+output+ " deduction is "+item.amount;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
return output;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}];
|
|
||||||
|
|
||||||
return [
|
|
||||||
[ "id", {"label":"ID","type":"hidden"}],
|
|
||||||
[ "name", {"label":"Name","type":"text","validation":""}],
|
|
||||||
[ "contributor", {"label":"Contributor","type":"select","source":[["Employee","Employee"],["Employer","Employer"]]}],
|
|
||||||
[ "type", {"label":"Deduction Type","type":"select","source":[["Fixed","Fixed"],["Percentage","Percentage"]]}],
|
|
||||||
[ "percentage_type", {"label":"Percentage Type","type":"select","source":[["On Component","On Component"],["On Component Type","On Component Type"]]}],
|
|
||||||
[ "componentType", {"label":"Salary Component Type","type":"select2","allow-null":true,"null-label":"N/A","remote-source":["SalaryComponentType","id","name"]}],
|
|
||||||
[ "component", {"label":"Salary Component","type":"select2","allow-null":true,"null-label":"N/A","remote-source":["SalaryComponent","id","name"]}],
|
|
||||||
rangeAmounts,
|
|
||||||
[ "country", {"label":"Country","type":"select2","remote-source":["Country","id","name"]}]
|
|
||||||
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
DeductionAdapter.method('doCustomValidation', function(params) {
|
|
||||||
if(params.type == "Fixed"){
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
if(params.percentage_type == "On Component Type"){
|
|
||||||
params.component = "NULL";
|
|
||||||
if(params.componentType == "NULL"){
|
|
||||||
return "Salary component type should be selected";
|
|
||||||
}
|
|
||||||
}else if(params.percentage_type == "On Component"){
|
|
||||||
params.componentType = "NULL";
|
|
||||||
if(params.component == "NULL"){
|
|
||||||
return "Salary component should be selected";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
});
|
|
||||||
|
|
||||||
DeductionAdapter.method('postRenderForm', function(object, $tempDomObj) {
|
|
||||||
|
|
||||||
$tempDomObj.find("#field_componentType").hide();
|
|
||||||
$tempDomObj.find("#field_percentage_type").hide();
|
|
||||||
$tempDomObj.find("#field_component").hide();
|
|
||||||
|
|
||||||
|
|
||||||
$tempDomObj.find("#percentage_type").off().on('change',function(e){
|
|
||||||
if(e.val == "On Component"){
|
|
||||||
$("#componentType").hide();
|
|
||||||
$("#component").show();
|
|
||||||
}else{
|
|
||||||
$("#componentType").show();
|
|
||||||
$("#component").hide();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$tempDomObj.find("#type").off().on('change',function(e){
|
|
||||||
if(e.val == "Fixed"){
|
|
||||||
$("#componentType").hide();
|
|
||||||
$("#percentage_type").hide();
|
|
||||||
$("#component").hide();
|
|
||||||
}else{
|
|
||||||
$("#percentage_type").show();
|
|
||||||
if($("#percentage_type").select2('data').id == 'On Component'){
|
|
||||||
$("#field_componentType").hide();
|
|
||||||
$("#field_component").show();
|
|
||||||
}else{
|
|
||||||
$("#field_componentType").show();
|
|
||||||
$("#field_component").hide();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* EmployeeSalaryAdapter
|
|
||||||
*/
|
|
||||||
|
|
||||||
function EmployeeSalaryAdapter(endPoint,tab,filter,orderBy) {
|
|
||||||
this.initAdapter(endPoint,tab,filter,orderBy);
|
|
||||||
}
|
|
||||||
|
|
||||||
EmployeeSalaryAdapter.inherits(AdapterBase);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
EmployeeSalaryAdapter.method('getDataMapping', function() {
|
|
||||||
return [
|
|
||||||
"id",
|
|
||||||
"employee",
|
|
||||||
"component",
|
|
||||||
"pay_frequency",
|
|
||||||
"currency",
|
|
||||||
"amount",
|
|
||||||
"details"
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
EmployeeSalaryAdapter.method('getHeaders', function() {
|
|
||||||
return [
|
|
||||||
{ "sTitle": "ID" ,"bVisible":false},
|
|
||||||
{ "sTitle": "Employee" },
|
|
||||||
{ "sTitle": "Salary Component" },
|
|
||||||
{ "sTitle": "Pay Frequency"},
|
|
||||||
{ "sTitle": "Currency"},
|
|
||||||
{ "sTitle": "Amount"},
|
|
||||||
{ "sTitle": "Details"}
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
EmployeeSalaryAdapter.method('getFormFields', function() {
|
|
||||||
return [
|
|
||||||
[ "id", {"label":"ID","type":"hidden"}],
|
|
||||||
[ "employee", {"label":"Employee","type":"select2","remote-source":["Employee","id","first_name+last_name"]}],
|
|
||||||
[ "component", {"label":"Salary Component","type":"select2","remote-source":["SalaryComponent","id","name"]}],
|
|
||||||
[ "pay_frequency", {"label":"Pay Frequency","type":"select","source":[["Hourly","Hourly"],["Daily","Daily"],["Bi Weekly","Bi Weekly"],["Weekly","Weekly"],["Semi Monthly","Semi Monthly"],["Monthly","Monthly"]]}],
|
|
||||||
[ "currency", {"label":"Currency","type":"select2","remote-source":["CurrencyType","id","name"]}],
|
|
||||||
[ "amount", {"label":"Amount","type":"text","validation":"float"}],
|
|
||||||
[ "details", {"label":"Details","type":"textarea","validation":"none"}]
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
EmployeeSalaryAdapter.method('getFilters', function() {
|
|
||||||
return [
|
|
||||||
[ "employee", {"label":"Employee","type":"select2","remote-source":["Employee","id","first_name+last_name"]}]
|
|
||||||
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
{
|
|
||||||
"label":"Setup",
|
|
||||||
"menu":"Salary Details",
|
|
||||||
"order":"6",
|
|
||||||
"icon":"fa-cogs",
|
|
||||||
"user_levels":["Admin"],
|
|
||||||
|
|
||||||
"permissions":
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -3,17 +3,17 @@
|
|||||||
<div class="small-box bg-aqua">
|
<div class="small-box bg-aqua">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>
|
<h3>
|
||||||
Permission
|
<t>Permission</t>
|
||||||
</h3>
|
</h3>
|
||||||
<p>
|
<p>
|
||||||
Management
|
<t>Management</t>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-locked"></i>
|
<i class="ion ion-locked"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="permissionLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="permissionLink">
|
||||||
Manage Permissions <i class="fa fa-arrow-circle-right"></i>
|
<t>Manage</t> <t>Permissions</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -28,7 +28,7 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabPermission" href="#tabPagePermission">Permissions</a></li>
|
<li class="active"><a id="tabPermission" href="#tabPagePermission"><?=LanguageManager::tran('Permissions')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
|
|||||||
@@ -69,5 +69,52 @@ if (!class_exists('Project')) {
|
|||||||
public function getUserAccess(){
|
public function getUserAccess(){
|
||||||
return array("get","element");
|
return array("get","element");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getAllProjects(){
|
||||||
|
$project = new Project();
|
||||||
|
$projects = $project->Find("status = ?",'Active');
|
||||||
|
foreach($projects as $project){
|
||||||
|
$client = new Client();
|
||||||
|
$client->Load("id = ?",array($project->client));
|
||||||
|
|
||||||
|
$project->name = $project->name." (".$client->name.")";
|
||||||
|
$employeeProjects[] = $project;
|
||||||
|
}
|
||||||
|
return $employeeProjects;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getEmployeeProjects(){
|
||||||
|
$allowAllProjects = SettingsManager::getInstance()->getSetting("Projects: Make All Projects Available to Employees");
|
||||||
|
$employeeProjects = array();
|
||||||
|
if($allowAllProjects == 0){
|
||||||
|
$employeeProjectsTemp = new EmployeeProject();
|
||||||
|
$employeeProjectsTemp = $employeeProjectsTemp->Find("employee = ?",array(BaseService::getInstance()->getCurrentProfileId()));
|
||||||
|
foreach($employeeProjectsTemp as $p){
|
||||||
|
$project = new Project();
|
||||||
|
$project->Load("id = ?",array($p->project));
|
||||||
|
if($project->status == 'Active'){
|
||||||
|
|
||||||
|
$client = new Client();
|
||||||
|
$client->Load("id = ?",array($project->client));
|
||||||
|
|
||||||
|
$project->name = $project->name." (".$client->name.")";
|
||||||
|
$employeeProjects[] = $project;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
$project = new Project();
|
||||||
|
$projects = $project->Find("status = ?",array('Active'));
|
||||||
|
foreach($projects as $project){
|
||||||
|
$client = new Client();
|
||||||
|
$client->Load("id = ?",array($project->client));
|
||||||
|
|
||||||
|
$project->name = $project->name." (".$client->name.")";
|
||||||
|
$employeeProjects[] = $project;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $employeeProjects;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2,16 +2,16 @@
|
|||||||
|
|
||||||
<div class="small-box bg-red">
|
<div class="small-box bg-red">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>Projects</h3>
|
<h3><t>Projects</t></h3>
|
||||||
<p id="numberOfProjects">
|
<p id="numberOfProjects">
|
||||||
#_numberOfProjects_# Active Projects
|
#_numberOfProjects_# <t>Active Projects</t>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-pie-graph"></i>
|
<i class="ion ion-pie-graph"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="projectsLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="projectsLink">
|
||||||
Update Clients/Projects <i class="fa fa-arrow-circle-right"></i>
|
<t>Update Clients/Projects</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -28,9 +28,9 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabClient" href="#tabPageClient">Clients</a></li>
|
<li class="active"><a id="tabClient" href="#tabPageClient"><?=LanguageManager::tran('Clients')?></a></li>
|
||||||
<li><a id="tabProject" href="#tabPageProject">Projects</a></li>
|
<li><a id="tabProject" href="#tabPageProject"><?=LanguageManager::tran('Projects')?></a></li>
|
||||||
<li><a id="tabEmployeeProject" href="#tabPageEmployeeProject">Employee Projects</a></li>
|
<li><a id="tabEmployeeProject" href="#tabPageEmployeeProject"><?=LanguageManager::tran('Employee Projects')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
|
|||||||
@@ -95,13 +95,14 @@ ProjectAdapter.method('getHeaders', function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
ProjectAdapter.method('getFormFields', function() {
|
ProjectAdapter.method('getFormFields', function() {
|
||||||
|
|
||||||
if(this.showSave){
|
if(this.showSave){
|
||||||
return [
|
return [
|
||||||
[ "id", {"label":"ID","type":"hidden"}],
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
[ "name", {"label":"Name","type":"text"}],
|
[ "name", {"label":"Name","type":"text"}],
|
||||||
[ "client", {"label":"Client","type":"select2","allow-null":true,"remote-source":["Client","id","name"]}],
|
[ "client", {"label":"Client","type":"select2","allow-null":true,"remote-source":["Client","id","name"]}],
|
||||||
[ "details", {"label":"Details","type":"textarea","validation":"none"}],
|
[ "details", {"label":"Details","type":"textarea","validation":"none"}],
|
||||||
[ "status", {"label":"Status","type":"select","source":[["Active","Active"],["Inactive","Inactive"]]}]
|
[ "status", {"label":"Status","type":"select","source":[["Active","Active"],["On Hold","On Hold"],["Completed","Completed"],["Dropped","Dropped"]]}]
|
||||||
];
|
];
|
||||||
}else{
|
}else{
|
||||||
return [
|
return [
|
||||||
@@ -109,7 +110,7 @@ ProjectAdapter.method('getFormFields', function() {
|
|||||||
[ "name", {"label":"Name","type":"placeholder"}],
|
[ "name", {"label":"Name","type":"placeholder"}],
|
||||||
[ "client", {"label":"Client","type":"placeholder","allow-null":true,"remote-source":["Client","id","name"]}],
|
[ "client", {"label":"Client","type":"placeholder","allow-null":true,"remote-source":["Client","id","name"]}],
|
||||||
[ "details", {"label":"Details","type":"placeholder","validation":"none"}],
|
[ "details", {"label":"Details","type":"placeholder","validation":"none"}],
|
||||||
[ "status", {"label":"Status","type":"placeholder","source":[["Active","Active"],["Inactive","Inactive"]]}]
|
[ "status", {"label":"Status","type":"select","source":[["Active","Active"],["On Hold","On Hold"],["Completed","Completed"],["Dropped","Dropped"]]}]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -137,8 +138,7 @@ EmployeeProjectAdapter.method('getDataMapping', function() {
|
|||||||
return [
|
return [
|
||||||
"id",
|
"id",
|
||||||
"employee",
|
"employee",
|
||||||
"project",
|
"project"
|
||||||
"status"
|
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -146,9 +146,7 @@ EmployeeProjectAdapter.method('getHeaders', function() {
|
|||||||
return [
|
return [
|
||||||
{ "sTitle": "ID" ,"bVisible":false},
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
{ "sTitle": "Employee" },
|
{ "sTitle": "Employee" },
|
||||||
{ "sTitle": "Project" },
|
{ "sTitle": "Project" }
|
||||||
/*{ "sTitle": "Start Date"},*/
|
|
||||||
{ "sTitle": "Status"}
|
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -157,9 +155,6 @@ EmployeeProjectAdapter.method('getFormFields', function() {
|
|||||||
[ "id", {"label":"ID","type":"hidden"}],
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
[ "employee", {"label":"Employee","type":"select2","remote-source":["Employee","id","first_name+last_name"]}],
|
[ "employee", {"label":"Employee","type":"select2","remote-source":["Employee","id","first_name+last_name"]}],
|
||||||
[ "project", {"label":"Project","type":"select2","remote-source":["Project","id","name"]}],
|
[ "project", {"label":"Project","type":"select2","remote-source":["Project","id","name"]}],
|
||||||
/*[ "date_start", {"label":"Start Date","type":"date","validation":""}],
|
|
||||||
[ "date_end", {"label":"End Date","type":"date","validation":"none"}],*/
|
|
||||||
[ "status", {"label":"Status","type":"select","source":[["Current","Current"],["Inactive","Inactive"],["Completed","Completed"]]}],
|
|
||||||
[ "details", {"label":"Details","type":"textarea","validation":"none"}]
|
[ "details", {"label":"Details","type":"textarea","validation":"none"}]
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -28,10 +28,10 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabSkill" href="#tabPageSkill">Skills</a></li>
|
<li class="active"><a id="tabSkill" href="#tabPageSkill"><?=LanguageManager::tran('Skills')?></a></li>
|
||||||
<li><a id="tabEducation" href="#tabPageEducation">Education</a></li>
|
<li><a id="tabEducation" href="#tabPageEducation"><?=LanguageManager::tran('Education')?></a></li>
|
||||||
<li><a id="tabCertification" href="#tabPageCertification">Certifications</a></li>
|
<li><a id="tabCertification" href="#tabPageCertification"><?=LanguageManager::tran('Certifications')?></a></li>
|
||||||
<li><a id="tabLanguage" href="#tabPageLanguage">Languages</a></li>
|
<li><a id="tabLanguage" href="#tabPageLanguage"><?=LanguageManager::tran('Languages')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
|
|||||||
@@ -2,16 +2,16 @@
|
|||||||
|
|
||||||
<div class="small-box bg-teal">
|
<div class="small-box bg-teal">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>Reports</h3>
|
<h3><t>Reports</t></h3>
|
||||||
<p>
|
<p>
|
||||||
View / Download Reports
|
<t>View / Download Reports</t>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-document-text"></i>
|
<i class="ion ion-document-text"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="reportsLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="reportsLink">
|
||||||
Create a Report <i class="fa fa-arrow-circle-right"></i>
|
<t>Generate a Report</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -7,7 +7,7 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabReport" href="#tabPageReport">Reports</a></li>
|
<li class="active"><a id="tabReport" href="#tabPageReport"><?=LanguageManager::tran('Reports')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
@@ -30,10 +30,7 @@ modJsList['tabReport'] = new ReportAdapter('Report','Report','','report_group');
|
|||||||
modJsList['tabReport'].setShowAddNew(false);
|
modJsList['tabReport'].setShowAddNew(false);
|
||||||
modJsList['tabReport'].setRemoteTable(true);
|
modJsList['tabReport'].setRemoteTable(true);
|
||||||
|
|
||||||
/*
|
|
||||||
modJsList['tabReport'] = new ReportGenAdapter('File','File','{"file_group":"Report"}','group');
|
|
||||||
modJsList['tabReport'].setShowAddNew(false);
|
|
||||||
*/
|
|
||||||
|
|
||||||
var modJs = modJsList['tabReport'];
|
var modJs = modJsList['tabReport'];
|
||||||
|
|
||||||
|
|||||||
@@ -10,14 +10,19 @@
|
|||||||
|
|
||||||
function ReportAdapter(endPoint,tab,filter,orderBy) {
|
function ReportAdapter(endPoint,tab,filter,orderBy) {
|
||||||
this.initAdapter(endPoint,tab,filter,orderBy);
|
this.initAdapter(endPoint,tab,filter,orderBy);
|
||||||
|
this._construct();
|
||||||
|
}
|
||||||
|
|
||||||
|
ReportAdapter.inherits(AdapterBase);
|
||||||
|
|
||||||
|
ReportAdapter.method('_construct', function() {
|
||||||
this._formFileds = [
|
this._formFileds = [
|
||||||
[ "id", {"label":"ID","type":"hidden"}],
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
[ "name", {"label":"Name","type":"label","validation":""}],
|
[ "name", {"label":"Name","type":"label","validation":""}],
|
||||||
[ "parameters", {"label":"Parameters","type":"fieldset","validation":"none"}]
|
[ "parameters", {"label":"Parameters","type":"fieldset","validation":"none"}]
|
||||||
];
|
];
|
||||||
}
|
this.remoteFieldsExists = false;
|
||||||
|
});
|
||||||
ReportAdapter.inherits(AdapterBase);
|
|
||||||
|
|
||||||
ReportAdapter.method('_initLocalFormFields', function() {
|
ReportAdapter.method('_initLocalFormFields', function() {
|
||||||
this._formFileds = [
|
this._formFileds = [
|
||||||
@@ -27,9 +32,14 @@ ReportAdapter.method('_initLocalFormFields', function() {
|
|||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
|
ReportAdapter.method('setRemoteFieldExists', function(val) {
|
||||||
|
this.remoteFieldsExists = val;
|
||||||
|
});
|
||||||
|
|
||||||
ReportAdapter.method('getDataMapping', function() {
|
ReportAdapter.method('getDataMapping', function() {
|
||||||
return [
|
return [
|
||||||
"id",
|
"id",
|
||||||
|
"icon",
|
||||||
"name",
|
"name",
|
||||||
"details",
|
"details",
|
||||||
"parameters"
|
"parameters"
|
||||||
@@ -39,12 +49,14 @@ ReportAdapter.method('getDataMapping', function() {
|
|||||||
ReportAdapter.method('getHeaders', function() {
|
ReportAdapter.method('getHeaders', function() {
|
||||||
return [
|
return [
|
||||||
{ "sTitle": "ID" ,"bVisible":false},
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
{ "sTitle": "Name" },
|
{ "sTitle": "","bSortable":false,"sWidth":"22px"},
|
||||||
|
{ "sTitle": "Name","sWidth":"30%"},
|
||||||
{ "sTitle": "Details"},
|
{ "sTitle": "Details"},
|
||||||
{ "sTitle": "Parameters","bVisible":false},
|
{ "sTitle": "Parameters","bVisible":false},
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
ReportAdapter.method('getFormFields', function() {
|
ReportAdapter.method('getFormFields', function() {
|
||||||
return this._formFileds;
|
return this._formFileds;
|
||||||
});
|
});
|
||||||
@@ -55,12 +67,16 @@ ReportAdapter.method('processFormFieldsWithObject', function(object) {
|
|||||||
var len = this._formFileds.length;
|
var len = this._formFileds.length;
|
||||||
var fieldIDsToDelete = [];
|
var fieldIDsToDelete = [];
|
||||||
var fieldsToDelete = [];
|
var fieldsToDelete = [];
|
||||||
|
this.remoteFieldsExists = false;
|
||||||
for(var i=0;i<len;i++){
|
for(var i=0;i<len;i++){
|
||||||
if(this._formFileds[i][1]['type']=="fieldset"){
|
if(this._formFileds[i][1]['type']=="fieldset"){
|
||||||
var newFields = JSON.parse(object[this._formFileds[i][0]]);
|
var newFields = JSON.parse(object[this._formFileds[i][0]]);
|
||||||
fieldsToDelete.push(this._formFileds[i][0]);
|
fieldsToDelete.push(this._formFileds[i][0]);
|
||||||
newFields.forEach(function(entry) {
|
newFields.forEach(function(entry) {
|
||||||
that._formFileds.push(entry);
|
that._formFileds.push(entry);
|
||||||
|
if(entry[1]['remote-source'] != undefined && entry[1]['remote-source'] != null){
|
||||||
|
that.remoteFieldsExists = true;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -76,13 +92,178 @@ ReportAdapter.method('processFormFieldsWithObject', function(object) {
|
|||||||
that._formFileds = tempArray;
|
that._formFileds = tempArray;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
ReportAdapter.method('renderForm', function(object) {
|
ReportAdapter.method('renderForm', function(object) {
|
||||||
var that = this;
|
var that = this;
|
||||||
this.processFormFieldsWithObject(object);
|
this.processFormFieldsWithObject(object);
|
||||||
|
if(this.remoteFieldsExists){
|
||||||
var cb = function(){
|
var cb = function(){
|
||||||
that.uber('renderForm',object);
|
that.renderFormNew(object);
|
||||||
};
|
};
|
||||||
this.initFieldMasterData(cb);
|
this.initFieldMasterData(cb);
|
||||||
|
}else{
|
||||||
|
this.initFieldMasterData();
|
||||||
|
that.renderFormNew(object);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.currentReport = object;
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
ReportAdapter.method('renderFormNew', function(object) {
|
||||||
|
|
||||||
|
var that = this;
|
||||||
|
var signatureIds = [];
|
||||||
|
if(object == null || object == undefined){
|
||||||
|
this.currentId = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.preRenderForm(object);
|
||||||
|
|
||||||
|
var formHtml = this.templates['formTemplate'];
|
||||||
|
var html = "";
|
||||||
|
var fields = this.getFormFields();
|
||||||
|
|
||||||
|
for(var i=0;i<fields.length;i++){
|
||||||
|
var metaField = this.getMetaFieldForRendering(fields[i][0]);
|
||||||
|
if(metaField == "" || metaField == undefined){
|
||||||
|
html += this.renderFormField(fields[i]);
|
||||||
|
}else{
|
||||||
|
var metaVal = object[metaField];
|
||||||
|
if(metaVal != '' && metaVal != null && metaVal != undefined && metaVal.trim() != ''){
|
||||||
|
html += this.renderFormField(JSON.parse(metaVal));
|
||||||
|
}else{
|
||||||
|
html += this.renderFormField(fields[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
formHtml = formHtml.replace(/_id_/g,this.getTableName()+"_submit");
|
||||||
|
formHtml = formHtml.replace(/_fields_/g,html);
|
||||||
|
|
||||||
|
|
||||||
|
var $tempDomObj;
|
||||||
|
var randomFormId = this.generateRandom(14);
|
||||||
|
if(!this.showFormOnPopup){
|
||||||
|
$tempDomObj = $("#"+this.getTableName()+'Form');
|
||||||
|
}else{
|
||||||
|
$tempDomObj = $('<div class="reviewBlock popupForm" data-content="Form"></div>');
|
||||||
|
$tempDomObj.attr('id',randomFormId);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
$tempDomObj.html(formHtml);
|
||||||
|
|
||||||
|
|
||||||
|
$tempDomObj.find('.datefield').datepicker({'viewMode':2});
|
||||||
|
$tempDomObj.find('.timefield').datetimepicker({
|
||||||
|
language: 'en',
|
||||||
|
pickDate: false
|
||||||
|
});
|
||||||
|
$tempDomObj.find('.datetimefield').datetimepicker({
|
||||||
|
language: 'en'
|
||||||
|
});
|
||||||
|
|
||||||
|
$tempDomObj.find('.colorpick').colorpicker();
|
||||||
|
|
||||||
|
//$tempDomObj.find('.select2Field').select2();
|
||||||
|
$tempDomObj.find('.select2Field').each(function() {
|
||||||
|
$(this).select2().select2('val', $(this).find("option:eq(0)").val());
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
$tempDomObj.find('.select2Multi').each(function() {
|
||||||
|
$(this).select2().on("change",function(e){
|
||||||
|
var parentRow = $(this).parents(".row");
|
||||||
|
var height = parentRow.find(".select2-choices").height();
|
||||||
|
parentRow.height(parseInt(height));
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
$tempDomObj.find('.signatureField').each(function() {
|
||||||
|
//$(this).data('signaturePad',new SignaturePad($(this)));
|
||||||
|
signatureIds.push($(this).attr('id'));
|
||||||
|
});
|
||||||
|
|
||||||
|
for(var i=0;i<fields.length;i++){
|
||||||
|
if(fields[i][1].type == "datagroup"){
|
||||||
|
$tempDomObj.find("#"+fields[i][0]).data('field',fields[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.showSave == false){
|
||||||
|
$tempDomObj.find('.saveBtn').remove();
|
||||||
|
}else{
|
||||||
|
$tempDomObj.find('.saveBtn').off();
|
||||||
|
$tempDomObj.find('.saveBtn').data("modJs",this);
|
||||||
|
$tempDomObj.find('.saveBtn').on( "click", function() {
|
||||||
|
if($(this ).data('modJs').saveSuccessItemCallback != null && $(this ).data('modJs').saveSuccessItemCallback!= undefined){
|
||||||
|
$(this ).data('modJs').save($(this ).data('modJs').retriveItemsAfterSave(), $(this ).data('modJs').saveSuccessItemCallback);
|
||||||
|
}else{
|
||||||
|
$(this ).data('modJs').save();
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.showCancel== false){
|
||||||
|
$tempDomObj.find('.cancelBtn').remove();
|
||||||
|
}else{
|
||||||
|
$tempDomObj.find('.cancelBtn').off();
|
||||||
|
$tempDomObj.find('.cancelBtn').data("modJs",this);
|
||||||
|
$tempDomObj.find('.cancelBtn').on( "click", function() {
|
||||||
|
$(this ).data('modJs').cancel();
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!this.showFormOnPopup){
|
||||||
|
$("#"+this.getTableName()+'Form').show();
|
||||||
|
$("#"+this.getTableName()).hide();
|
||||||
|
|
||||||
|
for(var i=0;i<signatureIds.length;i++){
|
||||||
|
$("#"+signatureIds[i])
|
||||||
|
.data('signaturePad',
|
||||||
|
new SignaturePad(document.getElementById(signatureIds[i])));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(object != undefined && object != null){
|
||||||
|
this.fillForm(object);
|
||||||
|
}
|
||||||
|
|
||||||
|
}else{
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//var tHtml = $tempDomObj.wrap('<div>').parent().html();
|
||||||
|
//this.showMessage("Edit",tHtml,null,null,true);
|
||||||
|
this.showMessage("Edit","",null,null,true);
|
||||||
|
|
||||||
|
$("#plainMessageModel .modal-body").html("");
|
||||||
|
$("#plainMessageModel .modal-body").append($tempDomObj);
|
||||||
|
|
||||||
|
|
||||||
|
for(var i=0;i<signatureIds.length;i++){
|
||||||
|
$("#"+signatureIds[i])
|
||||||
|
.data('signaturePad',
|
||||||
|
new SignaturePad(document.getElementById(signatureIds[i])));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(object != undefined && object != null){
|
||||||
|
this.fillForm(object,"#"+randomFormId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.postRenderForm(object,$tempDomObj);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -94,9 +275,6 @@ ReportAdapter.method('getActionButtonsHtml', function(id,data) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
ReportAdapter.method('addSuccessCallBack', function(callBackData,serverData) {
|
ReportAdapter.method('addSuccessCallBack', function(callBackData,serverData) {
|
||||||
//var link = '<a href="'+this.getCustomActionUrl("download",{'file':serverData})+'" target="_blank">Download Report <i class="icon-download-alt"></i> </a>';
|
|
||||||
//this.showMessage("Download Report",link);
|
|
||||||
|
|
||||||
var fileName = serverData[0];
|
var fileName = serverData[0];
|
||||||
var link;
|
var link;
|
||||||
|
|
||||||
@@ -107,6 +285,17 @@ ReportAdapter.method('addSuccessCallBack', function(callBackData,serverData) {
|
|||||||
}
|
}
|
||||||
link = link.replace(/_BASE_/g,this.baseUrl);
|
link = link.replace(/_BASE_/g,this.baseUrl);
|
||||||
|
|
||||||
|
if(this.currentReport.output == "PDF"){
|
||||||
|
|
||||||
|
this.showMessage("Download Report",link);
|
||||||
|
|
||||||
|
}else{
|
||||||
|
if(serverData[1].length == 0){
|
||||||
|
this.showMessage("Empty Report","There were no data for selected filters");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
var tableHtml = link+'<br/><br/><div class="box-body table-responsive" style="overflow-x:scroll;padding: 5px;border: solid 1px #DDD;"><table id="tempReportTable" cellpadding="0" cellspacing="0" border="0" class="table table-bordered table-striped"></table></div>';
|
var tableHtml = link+'<br/><br/><div class="box-body table-responsive" style="overflow-x:scroll;padding: 5px;border: solid 1px #DDD;"><table id="tempReportTable" cellpadding="0" cellspacing="0" border="0" class="table table-bordered table-striped"></table></div>';
|
||||||
|
|
||||||
//Delete existing temp report table
|
//Delete existing temp report table
|
||||||
@@ -114,9 +303,9 @@ ReportAdapter.method('addSuccessCallBack', function(callBackData,serverData) {
|
|||||||
|
|
||||||
//this.showMessage("Report",tableHtml);
|
//this.showMessage("Report",tableHtml);
|
||||||
|
|
||||||
$("#Report").html(tableHtml);
|
$("#"+this.table).html(tableHtml);
|
||||||
$("#Report").show();
|
$("#"+this.table).show();
|
||||||
$("#ReportForm").hide();
|
$("#"+this.table+"Form").hide();
|
||||||
|
|
||||||
//Prepare headers
|
//Prepare headers
|
||||||
var headers = [];
|
var headers = [];
|
||||||
@@ -148,6 +337,10 @@ ReportAdapter.method('addSuccessCallBack', function(callBackData,serverData) {
|
|||||||
return (this.nodeType == 3);
|
return (this.nodeType == 3);
|
||||||
}).remove();
|
}).remove();
|
||||||
$('.tableActionButton').tooltip();
|
$('.tableActionButton').tooltip();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
@@ -201,4 +394,3 @@ ReportGenAdapter.method('getActionButtonsHtml', function(id,data) {
|
|||||||
html = html.replace(/_BASE_/g,this.baseUrl);
|
html = html.replace(/_BASE_/g,this.baseUrl);
|
||||||
return html;
|
return html;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"label":"Reports",
|
"label":"Reports",
|
||||||
"menu":"Reports",
|
"menu":"Admin Reports",
|
||||||
"order":"1",
|
"order":"1",
|
||||||
"icon":"fa-file-o",
|
"icon":"fa-file-o",
|
||||||
"user_levels":["Admin","Manager"],
|
"user_levels":["Admin","Manager"],
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
if(!class_exists('ReportBuilder')){
|
if(!class_exists('ReportBuilder')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
}
|
}
|
||||||
class ActiveEmployeeReport extends ReportBuilder{
|
class ActiveEmployeeReport extends CSVReportBuilder implements CSVReportBuilderInterface{
|
||||||
|
|
||||||
public function getMainQuery(){
|
public function getMainQuery(){
|
||||||
$query = "Select id, employee_id as 'Employee ID',
|
$query = "Select id, employee_id as 'Employee ID',
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
if(!class_exists('ReportBuilder')){
|
if(!class_exists('ReportBuilder')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
}
|
}
|
||||||
class EmployeeAttendanceReport extends ReportBuilder{
|
class EmployeeAttendanceReport extends CSVReportBuilder implements CSVReportBuilderInterface{
|
||||||
|
|
||||||
public function getMainQuery(){
|
public function getMainQuery(){
|
||||||
$query = "SELECT
|
$query = "SELECT
|
||||||
|
|||||||
@@ -1,4 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
|
if(!class_exists('ReportBuilder')){
|
||||||
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
|
}
|
||||||
if(!interface_exists('ReportBuilderInterface')){
|
if(!interface_exists('ReportBuilderInterface')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
||||||
}
|
}
|
||||||
@@ -6,7 +9,7 @@ if(!interface_exists('ReportBuilderInterface')){
|
|||||||
if(!class_exists('LeavesActionManager')){
|
if(!class_exists('LeavesActionManager')){
|
||||||
include_once APP_BASE_PATH.'modules/leaves/api/LeavesActionManager.php';
|
include_once APP_BASE_PATH.'modules/leaves/api/LeavesActionManager.php';
|
||||||
}
|
}
|
||||||
class EmployeeLeaveEntitlementReport implements ReportBuilderInterface{
|
class EmployeeLeaveEntitlementReport extends ClassBasedReportBuilder implements ReportBuilderInterface{
|
||||||
public function getData($report,$req){
|
public function getData($report,$req){
|
||||||
|
|
||||||
$leaveActionManager = new LeavesActionManager();
|
$leaveActionManager = new LeavesActionManager();
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
if(!class_exists('ReportBuilder')){
|
if(!class_exists('ReportBuilder')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
}
|
}
|
||||||
class EmployeeLeavesReport extends ReportBuilder{
|
class EmployeeLeavesReport extends CSVReportBuilder implements CSVReportBuilderInterface{
|
||||||
|
|
||||||
public function getMainQuery(){
|
public function getMainQuery(){
|
||||||
$query = "SELECT
|
$query = "SELECT
|
||||||
@@ -33,31 +33,47 @@ from EmployeeLeaves lv";
|
|||||||
$employeeList = array();
|
$employeeList = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($request['department'] != "NULL" && empty($employeeList)){
|
||||||
|
$empTmp = new Employee();
|
||||||
|
$empTemps = $empTmp->Find("department = ? and status = Active",array($request['department']));
|
||||||
|
foreach($empTemps as $empTmp){
|
||||||
|
$employeeList[] = $empTmp->id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if(!empty($employeeList) && ($request['status'] != "NULL" && !empty($request['status']))){
|
if(!empty($employeeList) && ($request['status'] != "NULL" && !empty($request['status']))){
|
||||||
$query = "where employee in (".implode(",", $employeeList).") and date_start >= ? and date_end <= ? and status = ?;";
|
$query = "where employee in (".implode(",", $employeeList).") and ((date_start >= ? and date_start <= ?) or (date_end >= ? and date_end <= ?)) and status = ?;";
|
||||||
$params = array(
|
$params = array(
|
||||||
$request['date_start'],
|
$request['date_start'],
|
||||||
|
$request['date_end'],
|
||||||
|
$request['date_start'],
|
||||||
$request['date_end'],
|
$request['date_end'],
|
||||||
$request['status']
|
$request['status']
|
||||||
);
|
);
|
||||||
}else if(!empty($employeeList)){
|
}else if(!empty($employeeList)){
|
||||||
$query = "where employee in (".implode(",", $employeeList).") and date_start >= ? and date_end <= ?;";
|
$query = "where employee in (".implode(",", $employeeList).") and ((date_start >= ? and date_start <= ?) or (date_end >= ? and date_end <= ?));";
|
||||||
$params = array(
|
$params = array(
|
||||||
|
$request['date_start'],
|
||||||
|
$request['date_end'],
|
||||||
$request['date_start'],
|
$request['date_start'],
|
||||||
$request['date_end']
|
$request['date_end']
|
||||||
);
|
);
|
||||||
}else if(($request['status'] != "NULL" && !empty($request['status']))){
|
}else if(($request['status'] != "NULL" && !empty($request['status']))){
|
||||||
$query = "where status = ? and date_start >= ? and date_end <= ?;";
|
$query = "where status = ? and ((date_start >= ? and date_start <= ?) or (date_end >= ? and date_end <= ?));";
|
||||||
$params = array(
|
$params = array(
|
||||||
$request['status'],
|
$request['status'],
|
||||||
$request['date_start'],
|
$request['date_start'],
|
||||||
|
$request['date_end'],
|
||||||
|
$request['date_start'],
|
||||||
$request['date_end']
|
$request['date_end']
|
||||||
);
|
);
|
||||||
}else{
|
}else{
|
||||||
$query = "where date_start >= ? and date_end <= ?;";
|
$query = "where ((date_start >= ? and date_start <= ?) or (date_end >= ? and date_end <= ?));";
|
||||||
$params = array(
|
$params = array(
|
||||||
$request['date_start'],
|
$request['date_start'],
|
||||||
|
$request['date_end'],
|
||||||
|
$request['date_start'],
|
||||||
$request['date_end']
|
$request['date_end']
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,10 +1,12 @@
|
|||||||
<?php
|
<?php
|
||||||
|
if(!class_exists('ReportBuilder')){
|
||||||
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
|
}
|
||||||
if(!interface_exists('ReportBuilderInterface')){
|
if(!interface_exists('ReportBuilderInterface')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
||||||
}
|
}
|
||||||
|
|
||||||
class EmployeeTimeSheetData implements ReportBuilderInterface{
|
class EmployeeTimeSheetData extends ClassBasedReportBuilder implements ReportBuilderInterface{
|
||||||
public function getData($report,$request){
|
public function getData($report,$request){
|
||||||
|
|
||||||
$employeeCache = array();
|
$employeeCache = array();
|
||||||
|
|||||||
@@ -1,8 +1,11 @@
|
|||||||
<?php
|
<?php
|
||||||
|
if(!class_exists('ReportBuilder')){
|
||||||
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
|
}
|
||||||
if(!interface_exists('ReportBuilderInterface')){
|
if(!interface_exists('ReportBuilderInterface')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
||||||
}
|
}
|
||||||
class EmployeeTimeTrackReport implements ReportBuilderInterface{
|
class EmployeeTimeTrackReport extends ClassBasedReportBuilder implements ReportBuilderInterface{
|
||||||
public function getData($report,$req){
|
public function getData($report,$req){
|
||||||
|
|
||||||
LogManager::getInstance()->info(json_encode($report));
|
LogManager::getInstance()->info(json_encode($report));
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
if(!class_exists('ReportBuilder')){
|
if(!class_exists('ReportBuilder')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
}
|
}
|
||||||
class EmployeeTimesheetReport extends ReportBuilder{
|
class EmployeeTimesheetReport extends CSVReportBuilder implements CSVReportBuilderInterface{
|
||||||
|
|
||||||
public function getMainQuery(){
|
public function getMainQuery(){
|
||||||
$query = "SELECT
|
$query = "SELECT
|
||||||
@@ -29,7 +29,29 @@ FROM EmployeeTimeEntry te";
|
|||||||
$employeeList = array();
|
$employeeList = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(($request['client'] != "NULL" && !empty($request['client']))) {
|
||||||
|
|
||||||
|
$project = new Project();
|
||||||
|
$projects = $project->Find("client = ?",array($request['client']));
|
||||||
|
$projectIds = array();
|
||||||
|
foreach($projects as $project){
|
||||||
|
$projectIds[] = $project->id;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($employeeList) && ($request['project'] != "NULL" && !empty($request['project']))) {
|
||||||
|
$query = "where employee in (" . implode(",", $employeeList) . ") and date_start >= ? and date_end <= ? and project in (".implode(",",$projectIds).");";
|
||||||
|
$params = array(
|
||||||
|
$request['date_start'],
|
||||||
|
$request['date_end']
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$query = "where date_start >= ? and date_end <= ? and project in (".implode(",",$projectIds).");";
|
||||||
|
$params = array(
|
||||||
|
$request['date_start'],
|
||||||
|
$request['date_end']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}else{
|
||||||
if (!empty($employeeList) && ($request['project'] != "NULL" && !empty($request['project']))) {
|
if (!empty($employeeList) && ($request['project'] != "NULL" && !empty($request['project']))) {
|
||||||
$query = "where employee in (" . implode(",", $employeeList) . ") and date_start >= ? and date_end <= ? and project = ?;";
|
$query = "where employee in (" . implode(",", $employeeList) . ") and date_start >= ? and date_end <= ? and project = ?;";
|
||||||
$params = array(
|
$params = array(
|
||||||
@@ -58,6 +80,8 @@ FROM EmployeeTimeEntry te";
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
LogManager::getInstance()->info("Query:".$query);
|
LogManager::getInstance()->info("Query:".$query);
|
||||||
LogManager::getInstance()->info("Params:".json_encode($params));
|
LogManager::getInstance()->info("Params:".json_encode($params));
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,10 @@
|
|||||||
if(!class_exists('ReportBuilder')){
|
if(!class_exists('ReportBuilder')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
}
|
}
|
||||||
class ExpenseReport extends ReportBuilder{
|
if(!class_exists('ReportBuilder')){
|
||||||
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
|
}
|
||||||
|
class ExpenseReport extends CSVReportBuilder implements CSVReportBuilderInterface{
|
||||||
|
|
||||||
public function getMainQuery(){
|
public function getMainQuery(){
|
||||||
$query = "SELECT
|
$query = "SELECT
|
||||||
|
|||||||
@@ -1,4 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
|
if(!class_exists('ReportBuilder')){
|
||||||
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
|
}
|
||||||
if(!interface_exists('ReportBuilderInterface')){
|
if(!interface_exists('ReportBuilderInterface')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
||||||
}
|
}
|
||||||
@@ -6,7 +9,7 @@ if(!interface_exists('ReportBuilderInterface')){
|
|||||||
if(!class_exists('AttendanceAdminManager')){
|
if(!class_exists('AttendanceAdminManager')){
|
||||||
include_once APP_BASE_PATH.'admin/attendance/api/AttendanceAdminManager.php';
|
include_once APP_BASE_PATH.'admin/attendance/api/AttendanceAdminManager.php';
|
||||||
}
|
}
|
||||||
class OvertimeReport implements ReportBuilderInterface{
|
class OvertimeReport extends ClassBasedReportBuilder implements ReportBuilderInterface{
|
||||||
public function getData($report,$request){
|
public function getData($report,$request){
|
||||||
|
|
||||||
$employeeList = array();
|
$employeeList = array();
|
||||||
|
|||||||
@@ -2,14 +2,7 @@
|
|||||||
if(!interface_exists('ReportBuilderInterface')){
|
if(!interface_exists('ReportBuilderInterface')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilderInterface.php';
|
||||||
}
|
}
|
||||||
abstract class ReportBuilder implements ReportBuilderInterface{
|
abstract class ReportBuilder{
|
||||||
|
|
||||||
public function getData($report,$request){
|
|
||||||
$query = $this->getMainQuery();
|
|
||||||
$where = $this->getWhereQuery($request);
|
|
||||||
$query.=" ".$where[0];
|
|
||||||
return $this->execute($report, $query, $where[1]);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function execute($report, $query, $parameters){
|
protected function execute($report, $query, $parameters){
|
||||||
$report->DB()->SetFetchMode(ADODB_FETCH_ASSOC);
|
$report->DB()->SetFetchMode(ADODB_FETCH_ASSOC);
|
||||||
@@ -47,11 +40,169 @@ abstract class ReportBuilder implements ReportBuilderInterface{
|
|||||||
return $reportData;
|
return $reportData;
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract public function getWhereQuery($request);
|
|
||||||
|
|
||||||
abstract public function getMainQuery();
|
|
||||||
|
|
||||||
public function transformData($name, $value){
|
public function transformData($name, $value){
|
||||||
return $value;
|
return $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function createReportFile($report, $data){
|
||||||
|
$fileFirstPart = "Report_".str_replace(" ", "_", $report->name)."-".date("Y-m-d_H-i-s");
|
||||||
|
$fileName = $fileFirstPart.".csv";
|
||||||
|
|
||||||
|
$fileFullName = CLIENT_BASE_PATH.'data/'.$fileName;
|
||||||
|
$fp = fopen($fileFullName, 'w');
|
||||||
|
|
||||||
|
foreach ($data as $fields) {
|
||||||
|
fputcsv($fp, $fields);
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose($fp);
|
||||||
|
return array($fileFirstPart, $fileName, $fileFullName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function saveFile($fileFirstPart, $file, $fileFullName){
|
||||||
|
$uploadedToS3 = false;
|
||||||
|
|
||||||
|
$uploadFilesToS3 = SettingsManager::getInstance()->getSetting("Files: Upload Files to S3");
|
||||||
|
$uploadFilesToS3Key = SettingsManager::getInstance()->getSetting("Files: Amazon S3 Key for File Upload");
|
||||||
|
$uploadFilesToS3Secret = SettingsManager::getInstance()->getSetting("Files: Amazone S3 Secret for File Upload");
|
||||||
|
$s3Bucket = SettingsManager::getInstance()->getSetting("Files: S3 Bucket");
|
||||||
|
$s3WebUrl = SettingsManager::getInstance()->getSetting("Files: S3 Web Url");
|
||||||
|
|
||||||
|
if($uploadFilesToS3.'' == '1' && !empty($uploadFilesToS3Key)
|
||||||
|
&& !empty($uploadFilesToS3Secret) && !empty($s3Bucket) && !empty($s3WebUrl)){
|
||||||
|
|
||||||
|
$uploadname = CLIENT_NAME."/".$file;
|
||||||
|
$s3FileSys = new S3FileSystem($uploadFilesToS3Key, $uploadFilesToS3Secret);
|
||||||
|
$res = $s3FileSys->putObject($s3Bucket, $uploadname, $fileFullName, 'authenticated-read');
|
||||||
|
|
||||||
|
if(empty($res)){
|
||||||
|
return array("ERROR",$file);
|
||||||
|
}
|
||||||
|
|
||||||
|
unlink($fileFullName);
|
||||||
|
$file_url = $s3WebUrl.$uploadname;
|
||||||
|
$file_url = $s3FileSys->generateExpiringURL($file_url);
|
||||||
|
$uploadedToS3 = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$fileObj = new File();
|
||||||
|
$fileObj->name = $fileFirstPart;
|
||||||
|
$fileObj->filename = $file;
|
||||||
|
$fileObj->file_group = "Report";
|
||||||
|
$ok = $fileObj->Save();
|
||||||
|
|
||||||
|
if(!$ok){
|
||||||
|
LogManager::getInstance()->info($fileObj->ErrorMsg());
|
||||||
|
return array("ERROR","Error generating report");
|
||||||
|
}
|
||||||
|
|
||||||
|
$reportFile = new ReportFile();
|
||||||
|
$reportFile->name = $fileObj->filename;
|
||||||
|
$reportFile->attachment = $fileObj->name;
|
||||||
|
$reportFile->created = date("Y-m-d H:i:s");
|
||||||
|
$reportFile->employee = BaseService::getInstance()->getCurrentProfileId();
|
||||||
|
$ok = $reportFile->Save();
|
||||||
|
|
||||||
|
if(!$ok){
|
||||||
|
LogManager::getInstance()->info($reportFile->ErrorMsg());
|
||||||
|
return array("ERROR","Error generating report");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if($uploadedToS3){
|
||||||
|
return array("SUCCESS",$file_url);
|
||||||
|
}else{
|
||||||
|
return array("SUCCESS",$file);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class CSVReportBuilder extends ReportBuilder{
|
||||||
|
public function getData($report,$request){
|
||||||
|
$query = $this->getMainQuery();
|
||||||
|
$where = $this->getWhereQuery($request);
|
||||||
|
if($query == null || $where == null){
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
$query.=" ".$where[0];
|
||||||
|
return $this->execute($report, $query, $where[1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class ClassBasedReportBuilder extends ReportBuilder{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class PDFReportBuilder extends ReportBuilder{
|
||||||
|
|
||||||
|
var $twig;
|
||||||
|
|
||||||
|
protected function getDefaultData(){
|
||||||
|
$defaultData = array();
|
||||||
|
$defaultData['BASE_URL'] = BASE_URL;
|
||||||
|
$defaultData['LOGO'] = UIManager::getInstance()->getCompanyLogoUrl();
|
||||||
|
$defaultData['LOGO'] = str_replace("https:","http:",$defaultData['LOGO']);
|
||||||
|
$defaultData['companyName'] = SettingsManager::getInstance()->getSetting("Company: Name");
|
||||||
|
LogManager::getInstance()->debug("Logo Url:".$defaultData['LOGO']);
|
||||||
|
return $defaultData;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function initTemplateEngine($report){
|
||||||
|
if($report->_table = "UserReports"){
|
||||||
|
$path = APP_BASE_PATH."modules/reports/customTemplates/";
|
||||||
|
}else{
|
||||||
|
$path = APP_BASE_PATH."admin/reports/customTemplates/";
|
||||||
|
}
|
||||||
|
$loader = new Twig_Loader_Filesystem($path);
|
||||||
|
$twigOptions = array();
|
||||||
|
//false
|
||||||
|
if(defined('CACHE_THEME') && CACHE_THEME){
|
||||||
|
$twigOptions = array(
|
||||||
|
);
|
||||||
|
}else{
|
||||||
|
$twigOptions = array(
|
||||||
|
"cache"=>false
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$this->twig = new Twig_Environment($loader, $twigOptions);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function createReportFile($report, $data){
|
||||||
|
$fileFirstPart = "Report_".str_replace(" ", "_", $report->name)."-".date("Y-m-d_H-i-s");
|
||||||
|
$fileName = $fileFirstPart.".html";
|
||||||
|
|
||||||
|
$fileFullName = CLIENT_BASE_PATH.'data/'.$fileName;
|
||||||
|
|
||||||
|
$this->initTemplateEngine($report);
|
||||||
|
|
||||||
|
$template = $this->twig->loadTemplate($this->getTemplate());
|
||||||
|
$result = $template->render($data);
|
||||||
|
|
||||||
|
|
||||||
|
$fp = fopen($fileFullName, 'w');
|
||||||
|
fwrite($fp,$result);
|
||||||
|
fclose($fp);
|
||||||
|
|
||||||
|
try{
|
||||||
|
$fileFullNamePdf = CLIENT_BASE_PATH.'data/'.$fileFirstPart.".pdf";
|
||||||
|
//Try generating the pdf
|
||||||
|
exec(WK_HTML_PATH." ".$fileFullName." ".$fileFullNamePdf, $output, $ret);
|
||||||
|
|
||||||
|
LogManager::getInstance()->debug("wkhtmltopdf:".print_r($output,true));
|
||||||
|
LogManager::getInstance()->debug("wkhtmltopdf:".print_r($ret,true));
|
||||||
|
|
||||||
|
if(file_exists($fileFullNamePdf)){
|
||||||
|
$fileName = $fileFirstPart.".pdf";
|
||||||
|
$fileFullName = $fileFullNamePdf;
|
||||||
|
}
|
||||||
|
}catch(Exception $exp){
|
||||||
|
|
||||||
|
}
|
||||||
|
return array($fileFirstPart, $fileName, $fileFullName);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -1,4 +1,18 @@
|
|||||||
<?php
|
<?php
|
||||||
interface ReportBuilderInterface{
|
interface ReportBuilderInterface{
|
||||||
public function getData($report,$request);
|
public function getData($report,$request);
|
||||||
|
public function createReportFile($report, $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
interface CSVReportBuilderInterface{
|
||||||
|
public function getData($report,$request);
|
||||||
|
public function createReportFile($report, $data);
|
||||||
|
public function getMainQuery();
|
||||||
|
public function getWhereQuery($request);
|
||||||
|
}
|
||||||
|
|
||||||
|
interface PDFReportBuilderInterface{
|
||||||
|
public function getData($report,$request);
|
||||||
|
public function createReportFile($report, $data);
|
||||||
|
public function getTemplate();
|
||||||
}
|
}
|
||||||
@@ -2,7 +2,7 @@
|
|||||||
if(!class_exists('ReportBuilder')){
|
if(!class_exists('ReportBuilder')){
|
||||||
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
include_once APP_BASE_PATH.'admin/reports/reportClasses/ReportBuilder.php';
|
||||||
}
|
}
|
||||||
class TravelRequestReport extends ReportBuilder{
|
class TravelRequestReport extends CSVReportBuilder implements CSVReportBuilderInterface{
|
||||||
|
|
||||||
public function getMainQuery(){
|
public function getMainQuery(){
|
||||||
$query = "SELECT
|
$query = "SELECT
|
||||||
|
|||||||
@@ -7,8 +7,8 @@
|
|||||||
_fields_
|
_fields_
|
||||||
<div class="control-group">
|
<div class="control-group">
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
<button onclick="try{modJs.save()}catch(e){};return false;" class="btn">Download</button>
|
<button onclick="try{modJs.save()}catch(e){};return false;" class="btn"><t>Download</t></button>
|
||||||
<button onclick="modJs.cancel();return false;" class="btn">Cancel</button>
|
<button onclick="modJs.cancel();return false;" class="btn"><t>Cancel</t></button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
44
ext/admin/salary/LICENSE.txt
Normal file
44
ext/admin/salary/LICENSE.txt
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
ICEHRM END USER LICENSE AGREEMENT
|
||||||
|
NOTICE TO ALL USERS: BY PURCHASING THE MODULE, YOU (EITHER AN INDIVIDUAL OR A SINGLE ENTITY) CONSENT TO BE BOUND BY AND BECOME A PARTY TO THIS AGREEMENT.
|
||||||
|
|
||||||
|
All references to "Software" herein shall be deemed to include the software license with which you will be provided by Gamonoid Media Pvt Ltd, as part of the Software.
|
||||||
|
|
||||||
|
1. LICENSE GRANT. Subject to the payment of the applicable licence fees, and subject to the terms and conditions of this Agreement, ICEHRM hereby grants to you a non-exclusive, non-transferable right to use one copy of the specified version of the Software and the accompanying documentation (the "Documentation") for the term of this Agreement solely for your own internal business purposes. You may install one copy of the Software for production use.
|
||||||
|
.
|
||||||
|
2. USE. The Software is licensed as a single product; it may not be used on more than one ICEHRM Server at a time. The Software is "in use" on a Server when its installed on a Server. You shall not, nor permit any third party to copy (other than as expressly permitted herein). You shall not rent, lease or lend the Software to any other person, nor transfer or sub-licence your licence rights to any other person.
|
||||||
|
|
||||||
|
3. TERM. This Agreement is effective until terminated as set forth herein. This Agreement will terminate automatically if you fail to comply with any of the conditions, limitations or other requirements described herein. Upon any termination of this Agreement, you must immediately destroy all copies of the Software and the Documentation. You may terminate this Agreement at any point by destroying all copies of the Software and the Documentation.
|
||||||
|
|
||||||
|
4. SUPPORT. Gamonoid Media Pvt Ltd will provide you support according to the support agreement subscribed by the company.
|
||||||
|
|
||||||
|
5. OWNERSHIP RIGHTS. The Software is protected by copyright laws. ICEHRM and Gamonoid Media Pvt Ltd own and retain all right, title and interest in and to the Software, including all copyrights, patents, trademarks and other intellectual property rights therein. Your possession, installation, or use of the Software does not transfer to you any title to the intellectual property in the Software, and you will not acquire any rights to the Software except as expressly set forth in this Agreement.
|
||||||
|
|
||||||
|
6. LIMITED WARRANTY. You may not rent, lease, loan or resell the Software. You may not permit third parties to benefit from the use or functionality of the Software via a timesharing, service bureau or other arrangement, except to the extent such use is specified in the applicable list price or product packaging for the Software. You may not transfer any of the rights granted to you under this Agreement. You may not modify, or create derivative works based upon, the Software in whole or in part. You may not copy the Software or Documentation except as expressly permitted in Section 1 above. You may not remove any proprietary notices or labels on the Software. All rights not expressly set forth hereunder are reserved by ICEHRM. ICEHRM reserves the right to periodically conduct audits upon advance written notice to verify compliance with the terms of this Agreement.
|
||||||
|
|
||||||
|
7. WARRANTY and DISCLAIMER.
|
||||||
|
|
||||||
|
(i) Gamonoid Media Pvt Ltd. warrants that for 30 days from first download or installation the Software will perform substantially in accordance with the functionality described in the Documentation (http://blog.icehrm.com) when operated properly and in the manner specified in the Documentation.
|
||||||
|
|
||||||
|
(ii) You accept all responsibility for the selection of this Software to meet your requirements.
|
||||||
|
|
||||||
|
(iii) Gamonoid Media Pvt Ltd. does not warrant that the Software and/or the Documentation will be suitable for such requirements nor that any use will be uninterrupted and error free.
|
||||||
|
|
||||||
|
(iv) The warranty in (i) shall not apply if you (a) make or cause to be made any modifications to this Software, (b) use the Software in a manner for which it was not intended or (c) use the Software other than as permitted under this Agreement.
|
||||||
|
|
||||||
|
(vii) The warranties and conditions stated in this Agreement are in lieu of all other conditions, warranties or other terms concerning the supply or purported supply of, failure to supply or delay in supplying the Software or the Documentation which might but for this paragraph (vii) have effect between the ICEHRM and you or would otherwise be implied into or incorporated into this Agreement or any collateral contract, whether by statute, common law or otherwise, all of which are hereby excluded (including, without limitation, the implied conditions, warranties or other terms as to satisfactory quality, fitness for purpose or as to the use of reasonable skill and care).
|
||||||
|
|
||||||
|
8. LIMITATION of LIABILITY. Gamonoid Media Pvt Ltd. shall have no liability (whether in contract, tort, restitution or otherwise) for any of the following losses or damage (whether such losses or damage were foreseen, foreseeable, known or otherwise):
|
||||||
|
- Loss of revenue;
|
||||||
|
- Loss of actual or anticipated profits (including for loss of profits on contracts);
|
||||||
|
- Loss of the use of money;
|
||||||
|
- Loss of anticipated savings;
|
||||||
|
- Loss of business;
|
||||||
|
- Loss of opportunity;
|
||||||
|
- Loss of goodwill;
|
||||||
|
- Loss of reputation;
|
||||||
|
- Loss of, damage to or corruption of data;
|
||||||
|
or
|
||||||
|
Any indirect or consequential loss or damage howsoever caused (including, for the avoidance of doubt, where such loss or damage is of the type specified in paragraph (ii), (a) to (ii), (i).
|
||||||
|
The ICEHRM liability (whether in contract, tort, restitution or otherwise) arising out of or in connection with the supply of the Software shall in no circumstances exceed a sum equal to the amount equally paid by you for the Software.
|
||||||
|
The construction and interpretation of this Agreement shall be governed in accordance with the laws of Sri Lanka. The parties hereby submit to the jurisdiction of the courts of Sri Lanka save that ICEHRM as claimant shall be entitled to initiate proceedings in any court of competent jurisdiction.
|
||||||
|
This Agreement contains the entire understanding of the parties with respect to the subject matter hereof and supersedes all and any prior understandings, undertakings and promises between you and ICEHRM, whether oral or in writing, which have been given or may be implied from anything written or said in negotiations between us or our representatives prior to this Agreement and all prior agreements between the parties relating to the matters aforesaid shall cease to have effect as from the Effective Date.
|
||||||
7
ext/admin/salary/README.txt
Normal file
7
ext/admin/salary/README.txt
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
This module is licensed under IceHrm Commercial License, which can be found in LICENSE.txt.
|
||||||
|
You are allowed to make any modification required to these module, but only allowed to use
|
||||||
|
the module in one production server (even with modifications).
|
||||||
|
|
||||||
|
Installation
|
||||||
|
------------
|
||||||
|
Copy this module into <icehrm path>/admin/ directory
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
if (!class_exists('PayrollAdminManager')) {
|
if (!class_exists('SalaryAdminManager')) {
|
||||||
class PayrollAdminManager extends AbstractModuleManager{
|
class SalaryAdminManager extends AbstractModuleManager{
|
||||||
|
|
||||||
public function initializeUserClasses(){
|
public function initializeUserClasses(){
|
||||||
|
|
||||||
@@ -17,8 +17,7 @@ if (!class_exists('PayrollAdminManager')) {
|
|||||||
public function setupModuleClassDefinitions(){
|
public function setupModuleClassDefinitions(){
|
||||||
$this->addModelClass('SalaryComponentType');
|
$this->addModelClass('SalaryComponentType');
|
||||||
$this->addModelClass('SalaryComponent');
|
$this->addModelClass('SalaryComponent');
|
||||||
$this->addModelClass('Deduction');
|
$this->addModelClass('PayrollEmployee');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -52,9 +51,10 @@ if (!class_exists('SalaryComponent')) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!class_exists('Deduction')) {
|
|
||||||
class Deduction extends ICEHRM_Record {
|
if (!class_exists('PayrollEmployee')) {
|
||||||
var $_table = 'Deductions';
|
class PayrollEmployee extends ICEHRM_Record {
|
||||||
|
var $_table = 'PayrollEmployees';
|
||||||
|
|
||||||
public function getAdminAccess(){
|
public function getAdminAccess(){
|
||||||
return array("get","element","save","delete");
|
return array("get","element","save","delete");
|
||||||
@@ -66,4 +66,20 @@ if (!class_exists('Deduction')) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!class_exists('PayFrequency')) {
|
||||||
|
class PayFrequency extends ICEHRM_Record {
|
||||||
|
var $_table = 'PayFrequency';
|
||||||
|
public function getAdminAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getManagerAccess(){
|
||||||
|
return array("get","element","save","delete");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getUserAccess(){
|
||||||
|
return array("get","element");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$moduleName = 'metadata';
|
$moduleName = 'salary';
|
||||||
define('MODULE_PATH',dirname(__FILE__));
|
define('MODULE_PATH',dirname(__FILE__));
|
||||||
include APP_BASE_PATH.'header.php';
|
include APP_BASE_PATH.'header.php';
|
||||||
include APP_BASE_PATH.'modulejslibs.inc.php';
|
include APP_BASE_PATH.'modulejslibs.inc.php';
|
||||||
@@ -9,7 +9,7 @@ $moduleBuilder = new ModuleBuilder();
|
|||||||
|
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('SalaryComponentType','SalaryComponentType','Salary Component Types','SalaryComponentTypeAdapter','','',true));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('SalaryComponentType','SalaryComponentType','Salary Component Types','SalaryComponentTypeAdapter','','',true));
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('SalaryComponent','SalaryComponent','Salary Components','SalaryComponentAdapter','',''));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('SalaryComponent','SalaryComponent','Salary Components','SalaryComponentAdapter','',''));
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('EmployeeSalary','EmployeeSalary','Employee Salary','EmployeeSalaryAdapter','','',false,array("setRemoteTable"=>"true")));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('EmployeeSalary','EmployeeSalary','Employee Salary Components','EmployeeSalaryAdapter','','',false,array("setRemoteTable"=>"true")));
|
||||||
|
|
||||||
|
|
||||||
echo UIManager::getInstance()->renderModule($moduleBuilder);
|
echo UIManager::getInstance()->renderModule($moduleBuilder);
|
||||||
134
ext/admin/salary/lib.js
Normal file
134
ext/admin/salary/lib.js
Normal file
@@ -0,0 +1,134 @@
|
|||||||
|
/**
|
||||||
|
* Author: Thilina Hasantha
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SalaryComponentTypeAdapter
|
||||||
|
*/
|
||||||
|
|
||||||
|
function SalaryComponentTypeAdapter(endPoint,tab,filter,orderBy) {
|
||||||
|
this.initAdapter(endPoint,tab,filter,orderBy);
|
||||||
|
}
|
||||||
|
|
||||||
|
SalaryComponentTypeAdapter.inherits(AdapterBase);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
SalaryComponentTypeAdapter.method('getDataMapping', function() {
|
||||||
|
return [
|
||||||
|
"id",
|
||||||
|
"code",
|
||||||
|
"name"
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
SalaryComponentTypeAdapter.method('getHeaders', function() {
|
||||||
|
return [
|
||||||
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
|
{ "sTitle": "Code" },
|
||||||
|
{ "sTitle": "Name"}
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
SalaryComponentTypeAdapter.method('getFormFields', function() {
|
||||||
|
return [
|
||||||
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
|
[ "code", {"label":"Code","type":"text","validation":""}],
|
||||||
|
[ "name", {"label":"Name","type":"text","validation":""}]
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SalaryComponentAdapter
|
||||||
|
*/
|
||||||
|
|
||||||
|
function SalaryComponentAdapter(endPoint,tab,filter,orderBy) {
|
||||||
|
this.initAdapter(endPoint,tab,filter,orderBy);
|
||||||
|
}
|
||||||
|
|
||||||
|
SalaryComponentAdapter.inherits(AdapterBase);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
SalaryComponentAdapter.method('getDataMapping', function() {
|
||||||
|
return [
|
||||||
|
"id",
|
||||||
|
"name",
|
||||||
|
"componentType",
|
||||||
|
"details"
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
SalaryComponentAdapter.method('getHeaders', function() {
|
||||||
|
return [
|
||||||
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
|
{ "sTitle": "Name" },
|
||||||
|
{ "sTitle": "Salary Component Type" },
|
||||||
|
{ "sTitle": "Details"}
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
SalaryComponentAdapter.method('getFormFields', function() {
|
||||||
|
return [
|
||||||
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
|
[ "name", {"label":"Name","type":"text","validation":""}],
|
||||||
|
[ "componentType", {"label":"Salary Component Type","type":"select2","remote-source":["SalaryComponentType","id","name"]}],
|
||||||
|
[ "details", {"label":"Details","type":"textarea","validation":"none"}]
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* EmployeeSalaryAdapter
|
||||||
|
*/
|
||||||
|
|
||||||
|
function EmployeeSalaryAdapter(endPoint,tab,filter,orderBy) {
|
||||||
|
this.initAdapter(endPoint,tab,filter,orderBy);
|
||||||
|
}
|
||||||
|
|
||||||
|
EmployeeSalaryAdapter.inherits(AdapterBase);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
EmployeeSalaryAdapter.method('getDataMapping', function() {
|
||||||
|
return [
|
||||||
|
"id",
|
||||||
|
"employee",
|
||||||
|
"component",
|
||||||
|
"amount",
|
||||||
|
"details"
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeSalaryAdapter.method('getHeaders', function() {
|
||||||
|
return [
|
||||||
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
|
{ "sTitle": "Employee" },
|
||||||
|
{ "sTitle": "Salary Component" },
|
||||||
|
{ "sTitle": "Amount"},
|
||||||
|
{ "sTitle": "Details"}
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeSalaryAdapter.method('getFormFields', function() {
|
||||||
|
return [
|
||||||
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
|
[ "employee", {"label":"Employee","type":"select2","remote-source":["Employee","id","first_name+last_name"]}],
|
||||||
|
[ "component", {"label":"Salary Component","type":"select2","remote-source":["SalaryComponent","id","name"]}],
|
||||||
|
[ "amount", {"label":"Amount","type":"text","validation":"float"}],
|
||||||
|
[ "details", {"label":"Details","type":"textarea","validation":"none"}]
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeSalaryAdapter.method('getFilters', function() {
|
||||||
|
return [
|
||||||
|
[ "employee", {"label":"Employee","type":"select2","remote-source":["Employee","id","first_name+last_name"]}]
|
||||||
|
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
11
ext/admin/salary/meta.json
Normal file
11
ext/admin/salary/meta.json
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"label":"Salary",
|
||||||
|
"menu":"Payroll",
|
||||||
|
"order":"1",
|
||||||
|
"icon":"fa-money",
|
||||||
|
"user_levels":["Admin"],
|
||||||
|
|
||||||
|
"permissions":
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -26,11 +26,14 @@ class SettingsInitialize extends AbstractInitialize{
|
|||||||
public function init(){
|
public function init(){
|
||||||
if(SettingsManager::getInstance()->getSetting("Api: REST Api Enabled") == "1"){
|
if(SettingsManager::getInstance()->getSetting("Api: REST Api Enabled") == "1"){
|
||||||
$user = BaseService::getInstance()->getCurrentUser();
|
$user = BaseService::getInstance()->getCurrentUser();
|
||||||
|
if(empty($user)){
|
||||||
|
return;
|
||||||
|
}
|
||||||
$dbUser = new User();
|
$dbUser = new User();
|
||||||
$dbUser->Load("id = ?",array($user->id));
|
$dbUser->Load("id = ?",array($user->id));
|
||||||
$resp = RestApiManager::getInstance()->getAccessTokenForUser($dbUser);
|
$resp = RestApiManager::getInstance()->getAccessTokenForUser($dbUser);
|
||||||
if($resp->getStatus() != IceResponse::SUCCESS){
|
if($resp->getStatus() != IceResponse::SUCCESS){
|
||||||
LogManager::getInstance()->error("Error occured while creating REST Api acces token for ".$user->username);
|
LogManager::getInstance()->error("Error occurred while creating REST Api access token for ".$user->username);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,16 +2,16 @@
|
|||||||
|
|
||||||
<div class="small-box bg-green">
|
<div class="small-box bg-green">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>Settings</h3>
|
<h3><t>Settings</t></h3>
|
||||||
<p>
|
<p>
|
||||||
Configure IceHrm
|
<t>Configure</t> IceHrm
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-settings"></i>
|
<i class="ion ion-settings"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="settingsLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="settingsLink">
|
||||||
Update Settings <i class="fa fa-arrow-circle-right"></i>
|
<t>Update</t> <t>Settings</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -25,37 +25,26 @@ $moduleName = 'settings';
|
|||||||
define('MODULE_PATH',dirname(__FILE__));
|
define('MODULE_PATH',dirname(__FILE__));
|
||||||
include APP_BASE_PATH.'header.php';
|
include APP_BASE_PATH.'header.php';
|
||||||
include APP_BASE_PATH.'modulejslibs.inc.php';
|
include APP_BASE_PATH.'modulejslibs.inc.php';
|
||||||
?><div class="span9">
|
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
$moduleBuilder = new ModuleBuilder();
|
||||||
<li class="active"><a id="tabSetting" href="#tabPageSetting">Settings</a></li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<div class="tab-content">
|
$options1 = array();
|
||||||
<div class="tab-pane active" id="tabPageSetting">
|
$options1['setShowAddNew'] = 'false';
|
||||||
<div id="Setting" class="reviewBlock" data-content="List" style="padding-left:5px;">
|
|
||||||
|
|
||||||
</div>
|
|
||||||
<div id="SettingForm" class="reviewBlock" data-content="Form" style="padding-left:5px;display:none;">
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('CompanySetting','Setting','Company','SettingAdapter','{"name":["Company:"]}','name',true,$options1));
|
||||||
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('SystemSetting','Setting','System','SettingAdapter','{"name":["System:"]}','name',false,$options1));
|
||||||
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('EmailSetting','Setting','Email','SettingAdapter','{"name":["Email:"]}','name',false,$options1));
|
||||||
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('LDAPSetting','Setting','LDAP','SettingAdapter','{"name":["LDAP:"]}','name',false,$options1));
|
||||||
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('AttendanceSetting','Setting','Attendance','SettingAdapter','{"name":["Attendance:"]}','name',false,$options1));
|
||||||
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('OtherSetting','Setting','Other','SettingAdapter','{"name":["Projects:","Recruitment:","Notifications:","Expense:","Travel:","Api:","Overtime:"]}','name',false,$options1));
|
||||||
|
echo UIManager::getInstance()->renderModule($moduleBuilder);
|
||||||
|
?>
|
||||||
</div>
|
</div>
|
||||||
<script>
|
<script>
|
||||||
var modJsList = new Array();
|
|
||||||
|
|
||||||
modJsList['tabSetting'] = new SettingAdapter('Setting','Setting','','name');
|
|
||||||
modJsList['tabSetting'].setShowAddNew(false);
|
|
||||||
|
|
||||||
var modJs = modJsList['tabSetting'];
|
|
||||||
|
|
||||||
$(window).load(function() {
|
$(window).load(function() {
|
||||||
modJs.loadRemoteDataForSettings();
|
modJs.loadRemoteDataForSettings();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
<?php include APP_BASE_PATH.'footer.php';?>
|
<?php include APP_BASE_PATH.'footer.php';?>
|
||||||
@@ -62,13 +62,34 @@ SettingAdapter.method('edit', function(id) {
|
|||||||
|
|
||||||
|
|
||||||
SettingAdapter.method('fillForm', function(object) {
|
SettingAdapter.method('fillForm', function(object) {
|
||||||
this.uber('fillForm',object);
|
|
||||||
|
var metaField = this.getMetaFieldForRendering('value');
|
||||||
|
var metaVal = object[metaField];
|
||||||
|
var formFields = null;
|
||||||
|
|
||||||
|
if(metaVal != "" && metaVal != undefined){
|
||||||
|
var formFields = [
|
||||||
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
|
JSON.parse(metaVal)
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
this.uber('fillForm',object, null, formFields);
|
||||||
$("#helptext").html(object.description);
|
$("#helptext").html(object.description);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
SettingAdapter.method('loadRemoteDataForSettings', function () {
|
SettingAdapter.method('loadRemoteDataForSettings', function () {
|
||||||
var field = ["country", {"label": "Country", "type": "select2", "remote-source": ["Country", "code", "name"]}];
|
var fields = [];
|
||||||
|
var field = null;
|
||||||
|
fields.push(["country", {"label": "Country", "type": "select2multi", "remote-source": ["Country", "id", "name"]}]);
|
||||||
|
fields.push(["currency", {"label": "Currency", "type": "select2multi", "remote-source": ["CurrencyType","id","code+name"]}]);
|
||||||
|
fields.push(["nationality", {"label": "Nationality", "type": "select2multi", "remote-source": ["Nationality","id","name"]}]);
|
||||||
|
fields.push(["supportedLanguage", {"label":"Value","type":"select2","allow-null":false,"remote-source":["SupportedLanguage","name","description"]}]);
|
||||||
|
|
||||||
|
for(index in fields){
|
||||||
|
field = fields[index];
|
||||||
if (field[1]['remote-source'] != undefined && field[1]['remote-source'] != null) {
|
if (field[1]['remote-source'] != undefined && field[1]['remote-source'] != null) {
|
||||||
var key = field[1]['remote-source'][0] + "_" + field[1]['remote-source'][1] + "_" + field[1]['remote-source'][2];
|
var key = field[1]['remote-source'][0] + "_" + field[1]['remote-source'][1] + "_" + field[1]['remote-source'][2];
|
||||||
this.fieldMasterDataKeys[key] = false;
|
this.fieldMasterDataKeys[key] = false;
|
||||||
@@ -80,6 +101,8 @@ SettingAdapter.method('loadRemoteDataForSettings', function () {
|
|||||||
|
|
||||||
this.getFieldValues(field[1]['remote-source'], callBackData);
|
this.getFieldValues(field[1]['remote-source'], callBackData);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -9,8 +9,8 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="control-group">
|
<div class="control-group">
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
<button onclick="try{modJs.save()}catch(e){};return false;" class="btn">Save</button>
|
<button onclick="try{modJs.save()}catch(e){};return false;" class="btn"><t>Save</t></button>
|
||||||
<button onclick="modJs.cancel();return false;" class="btn">Cancel</button>
|
<button onclick="modJs.cancel();return false;" class="btn"><t>Cancel</t></button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@@ -14,6 +14,14 @@ class TravelActionManager extends ApproveAdminActionManager{
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function getModuleTabUrl(){
|
public function getModuleTabUrl(){
|
||||||
return "g=modules&n=travel&m=module_Travel_Management";
|
return "g=modules&n=travel&m=module_Travel_Management#tabEmployeeTravelRecord";
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getModuleSubordinateTabUrl(){
|
||||||
|
return "g=modules&n=travel&m=module_Travel_Management#tabSubordinateEmployeeTravelRecord";
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getModuleApprovalTabUrl(){
|
||||||
|
return "g=modules&n=travel&m=module_Travel_Management#tabEmployeeTravelRecordApproval";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -89,9 +89,13 @@ if (!class_exists('EmployeeTravelRecord')) {
|
|||||||
var $notificationModuleName = "Travel Management";
|
var $notificationModuleName = "Travel Management";
|
||||||
var $notificationUnitName = "TravelRequest";
|
var $notificationUnitName = "TravelRequest";
|
||||||
var $notificationUnitPrefix = "A";
|
var $notificationUnitPrefix = "A";
|
||||||
var $notificationUnitAdminUrl = "g=admin&n=travel&m=admin_Employees";
|
var $notificationUnitAdminUrl = "g=modules&n=travel&m=module_Travel_Management#tabSubordinateEmployeeTravelRecord";
|
||||||
var $preApproveSettingName = "Travel: Pre-Approve Travel Request";
|
var $preApproveSettingName = "Travel: Pre-Approve Travel Request";
|
||||||
|
|
||||||
|
public function isMultiLevelApprovalsEnabled(){
|
||||||
|
return (SettingsManager::getInstance()->getSetting('Travel: Enable Multi Level Approvals') == '1');
|
||||||
|
}
|
||||||
|
|
||||||
public function getAdminAccess()
|
public function getAdminAccess()
|
||||||
{
|
{
|
||||||
return array("get", "element", "save", "delete");
|
return array("get", "element", "save", "delete");
|
||||||
@@ -124,5 +128,28 @@ if (!class_exists('EmployeeTravelRecord')) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getType(){
|
||||||
|
return 'EmployeeTravelRecord';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function allowIndirectMapping(){
|
||||||
|
if(SettingsManager::getInstance()->getSetting('Travel: Allow Indirect Admins to Approve') == '1'){
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (!class_exists('EmployeeTravelRecordApproval')) {
|
||||||
|
|
||||||
|
class EmployeeTravelRecordApproval extends EmployeeTravelRecord
|
||||||
|
{
|
||||||
|
|
||||||
|
public function Find($whereOrderBy,$bindarr=false,$pkeysArr=false,$extra=array()){
|
||||||
|
return $this->findApprovals(new EmployeeTravelRecord(), $whereOrderBy,$bindarr,$pkeysArr,$extra);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -3,17 +3,17 @@
|
|||||||
<div class="small-box bg-red">
|
<div class="small-box bg-red">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>
|
<h3>
|
||||||
Travel
|
<t>Travel</t>
|
||||||
</h3>
|
</h3>
|
||||||
<p id="numberOfTravel">
|
<p id="numberOfTravel">
|
||||||
Requests
|
<t>Requests</t>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-plane"></i>
|
<i class="ion ion-plane"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="travelLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="travelLink">
|
||||||
Manage Travel <i class="fa fa-arrow-circle-right"></i>
|
<t>Manage</t> <t>Travel</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -30,7 +30,7 @@ $options = array();
|
|||||||
$options['setRemoteTable'] = 'true';
|
$options['setRemoteTable'] = 'true';
|
||||||
|
|
||||||
$moduleBuilder = new ModuleBuilder();
|
$moduleBuilder = new ModuleBuilder();
|
||||||
$moduleBuilder->addModuleOrGroup(new ModuleTab('EmployeeTravelRecord','EmployeeTravelRecord','Travel Requests','EmployeeTravelRecordAdapter','','',true,$options));
|
$moduleBuilder->addModuleOrGroup(new ModuleTab('EmployeeTravelRecord','EmployeeTravelRecord','Travel Requests','EmployeeTravelRecordAdminAdapter','','',true,$options));
|
||||||
echo UIManager::getInstance()->renderModule($moduleBuilder);
|
echo UIManager::getInstance()->renderModule($moduleBuilder);
|
||||||
|
|
||||||
|
|
||||||
@@ -38,41 +38,4 @@ $itemName = 'TravelRequest';
|
|||||||
$moduleName = 'Travel Management';
|
$moduleName = 'Travel Management';
|
||||||
$itemNameLower = strtolower($itemName);
|
$itemNameLower = strtolower($itemName);
|
||||||
|
|
||||||
$statuses = array("Approved","Pending","Rejected","Cancelled");
|
|
||||||
|
|
||||||
?><div class="modal" id="<?=$itemNameLower?>StatusModel" tabindex="-1" role="dialog" aria-labelledby="messageModelLabel" aria-hidden="true">
|
|
||||||
<div class="modal-dialog">
|
|
||||||
<div class="modal-content">
|
|
||||||
<div class="modal-header">
|
|
||||||
<button type="button" class="close" data-dismiss="modal" aria-hidden="true"><li class="fa fa-times"/></button>
|
|
||||||
<h3 style="font-size: 17px;">Change <?=$itemName?> Status</h3>
|
|
||||||
</div>
|
|
||||||
<div class="modal-body">
|
|
||||||
<form id="expenseStatusForm">
|
|
||||||
<div class="control-group">
|
|
||||||
<label class="control-label" for="expense_status"><?=$itemName?> Status</label>
|
|
||||||
<div class="controls">
|
|
||||||
<select type="text" id="<?=$itemNameLower?>_status" class="form-control" name="<?=$itemNameLower?>_status" value="">
|
|
||||||
<?php foreach($statuses as $status){?>
|
|
||||||
<option value="<?=$status?>"><?=$status?></option>
|
|
||||||
<?php }?>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="control-group">
|
|
||||||
<label class="control-label" for="expense_status">Status Change Note</label>
|
|
||||||
<div class="controls">
|
|
||||||
<textarea id="<?=$itemNameLower?>_reason" class="form-control" name="<?=$itemNameLower?>_reason" maxlength="500"></textarea>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
<div class="modal-footer">
|
|
||||||
<button class="btn btn-primary" onclick="modJs.changeStatus();">Change <?=$itemName?> Status</button>
|
|
||||||
<button class="btn" onclick="modJs.closeDialog();">Not Now</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<?php
|
|
||||||
include APP_BASE_PATH.'footer.php';
|
include APP_BASE_PATH.'footer.php';
|
||||||
@@ -110,22 +110,22 @@ EmployeeImmigrationAdapter.method('getFilters', function() {
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* EmployeeTravelRecordAdapter
|
* EmployeeTravelRecordAdminAdapter
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
function EmployeeTravelRecordAdapter(endPoint,tab,filter,orderBy) {
|
function EmployeeTravelRecordAdminAdapter(endPoint,tab,filter,orderBy) {
|
||||||
this.initAdapter(endPoint,tab,filter,orderBy);
|
this.initAdapter(endPoint,tab,filter,orderBy);
|
||||||
this.itemName = 'TravelRequest';
|
this.itemName = 'TravelRequest';
|
||||||
this.itemNameLower = 'travelrequest';
|
this.itemNameLower = 'travelrequest';
|
||||||
this.modulePathName = 'travel';
|
this.modulePathName = 'travel';
|
||||||
}
|
}
|
||||||
|
|
||||||
EmployeeTravelRecordAdapter.inherits(ApproveAdminAdapter);
|
EmployeeTravelRecordAdminAdapter.inherits(ApproveAdminAdapter);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
EmployeeTravelRecordAdapter.method('getDataMapping', function() {
|
EmployeeTravelRecordAdminAdapter.method('getDataMapping', function() {
|
||||||
return [
|
return [
|
||||||
"id",
|
"id",
|
||||||
"employee",
|
"employee",
|
||||||
@@ -138,7 +138,7 @@ EmployeeTravelRecordAdapter.method('getDataMapping', function() {
|
|||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
EmployeeTravelRecordAdapter.method('getHeaders', function() {
|
EmployeeTravelRecordAdminAdapter.method('getHeaders', function() {
|
||||||
return [
|
return [
|
||||||
{ "sTitle": "ID" ,"bVisible":false},
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
{ "sTitle": "Employee" },
|
{ "sTitle": "Employee" },
|
||||||
@@ -151,7 +151,7 @@ EmployeeTravelRecordAdapter.method('getHeaders', function() {
|
|||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
EmployeeTravelRecordAdapter.method('getFormFields', function() {
|
EmployeeTravelRecordAdminAdapter.method('getFormFields', function() {
|
||||||
return [
|
return [
|
||||||
["id", {"label": "ID", "type": "hidden"}],
|
["id", {"label": "ID", "type": "hidden"}],
|
||||||
["employee", {
|
["employee", {
|
||||||
|
|||||||
@@ -23,8 +23,16 @@ Developer: Thilina Hasantha (thilina.hasantha[at]gmail.com / facebook.com/thilin
|
|||||||
|
|
||||||
class UsersActionManager extends SubActionManager{
|
class UsersActionManager extends SubActionManager{
|
||||||
public function changePassword($req){
|
public function changePassword($req){
|
||||||
if($this->user->user_level == 'Admin' || $this->user->id == $req->id){
|
if(defined('DEMO_MODE')){
|
||||||
$user = $this->baseService->getElement('User',$req->id);
|
return new IceResponse(IceResponse::ERROR,"You are not allowed to change the password in demo mode");
|
||||||
|
}
|
||||||
|
|
||||||
|
$user = new User();
|
||||||
|
$user->Load("id = ?",array($req->id));
|
||||||
|
LogManager::getInstance()->debug("Current User:".print_r($this->user,true));
|
||||||
|
LogManager::getInstance()->debug("Edit User:".print_r($user,true));
|
||||||
|
if($this->user->user_level == 'Admin' || $this->user->id == $user->id){
|
||||||
|
|
||||||
if(empty($user->id)){
|
if(empty($user->id)){
|
||||||
return new IceResponse(IceResponse::ERROR,"Please save the user first");
|
return new IceResponse(IceResponse::ERROR,"Please save the user first");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -54,11 +54,40 @@ if (!class_exists('User')) {
|
|||||||
if(count($users) > 0){
|
if(count($users) > 0){
|
||||||
return new IceResponse(IceResponse::ERROR,"A user with same authentication email already exist");
|
return new IceResponse(IceResponse::ERROR,"A user with same authentication email already exist");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Check if you are trying to change user level
|
||||||
|
$oldUser = new User();
|
||||||
|
$oldUser->Load("id = ?",array($obj->id));
|
||||||
|
if($oldUser->user_level != $obj->user_level && $oldUser->user_level == 'Admin'){
|
||||||
|
$adminUsers = $userTemp->Find("user_level = ?",array("Admin"));
|
||||||
|
if(count($adminUsers) == 1 && $adminUsers[0]->id == $obj->id){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"You are the only admin user for the application. You are not allowed to revoke your admin rights");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
//Check if the user have rights to the default module
|
||||||
|
if(!empty($obj->default_module)){
|
||||||
|
$module = new Module();
|
||||||
|
$module->Load("id = ?",array($obj->default_module));
|
||||||
|
if($module->mod_group == "user"){
|
||||||
|
$module->mod_group = "modules";
|
||||||
|
}
|
||||||
|
$moduleManager = BaseService::getInstance()->getModuleManager($module->mod_group, $module->name);
|
||||||
|
if(!BaseService::getInstance()->isModuleAllowedForGivenUser($moduleManager, $obj)){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"This module can not be set as the default module for the user since the user do not have access to this module");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return new IceResponse(IceResponse::SUCCESS,"");
|
return new IceResponse(IceResponse::SUCCESS,"");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
var $_table = 'Users';
|
var $_table = 'Users';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,16 +2,16 @@
|
|||||||
|
|
||||||
<div class="small-box bg-yellow">
|
<div class="small-box bg-yellow">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3>Users</h3>
|
<h3><t>Users</t></h3>
|
||||||
<p id="numberOfUsers">
|
<p id="numberOfUsers">
|
||||||
#_numberOfUsers_# Users
|
#_numberOfUsers_# <t>Users</t>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-person-add"></i>
|
<i class="ion ion-person-add"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="usersLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="usersLink">
|
||||||
Manage Users <i class="fa fa-arrow-circle-right"></i>
|
<t>Manage</t> <t>Users</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -29,8 +29,8 @@ include APP_BASE_PATH.'modulejslibs.inc.php';
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabUser" href="#tabPageUser">Users</a></li>
|
<li class="active"><a id="tabUser" href="#tabPageUser"><?=LanguageManager::tran('Users')?></a></li>
|
||||||
<li class=""><a id="tabUserRole" href="#tabPageUserRole">User Roles</a></li>
|
<li class=""><a id="tabUserRole" href="#tabPageUserRole"><?=LanguageManager::tran('User Roles')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
|
|||||||
@@ -37,6 +37,7 @@ UserAdapter.method('getFormFields', function() {
|
|||||||
[ "employee", {"label":"Employee","type":"select2","allow-null":true,"remote-source":["Employee","id","first_name+last_name"]}],
|
[ "employee", {"label":"Employee","type":"select2","allow-null":true,"remote-source":["Employee","id","first_name+last_name"]}],
|
||||||
[ "user_level", {"label":"User Level","type":"select","source":[["Admin","Admin"],["Manager","Manager"],["Employee","Employee"],["Other","Other"]]}],
|
[ "user_level", {"label":"User Level","type":"select","source":[["Admin","Admin"],["Manager","Manager"],["Employee","Employee"],["Other","Other"]]}],
|
||||||
[ "user_roles", {"label":"User Roles","type":"select2multi","remote-source":["UserRole","id","name"]}],
|
[ "user_roles", {"label":"User Roles","type":"select2multi","remote-source":["UserRole","id","name"]}],
|
||||||
|
[ "lang", {"label":"Language","type":"select2","allow-null":true,"remote-source":["SupportedLanguage","name","description"]}],
|
||||||
[ "default_module", {"label":"Default Module","type":"select2","null-label":"No Default Module","allow-null":true,"remote-source":["Module","id","menu+label"]}]
|
[ "default_module", {"label":"Default Module","type":"select2","null-label":"No Default Module","allow-null":true,"remote-source":["Module","id","menu+label"]}]
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
@@ -186,6 +187,11 @@ UserRoleAdapter.method('getHeaders', function() {
|
|||||||
];
|
];
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
UserRoleAdapter.method('postRenderForm', function(object, $tempDomObj) {
|
||||||
|
$tempDomObj.find("#changePasswordBtn").remove();
|
||||||
|
});
|
||||||
|
|
||||||
UserRoleAdapter.method('getFormFields', function() {
|
UserRoleAdapter.method('getFormFields', function() {
|
||||||
return [
|
return [
|
||||||
[ "id", {"label":"ID","type":"hidden"}],
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
|
|||||||
@@ -135,4 +135,44 @@ class AttendanceActionManager extends SubActionManager{
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function createPreviousAttendnaceSheet($req){
|
||||||
|
$employee = $this->baseService->getElement('Employee',$this->getCurrentProfileId(),null,true);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$timeSheet = new EmployeeAttendanceSheet();
|
||||||
|
$timeSheet->Load("id = ?",array($req->id));
|
||||||
|
if($timeSheet->id != $req->id){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Attendance Sheet not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
if($timeSheet->employee != $employee->id){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"You don't have permissions to add this Attendance Sheet");
|
||||||
|
}
|
||||||
|
|
||||||
|
$end = date("Y-m-d", strtotime("last Saturday", strtotime($timeSheet->date_start)));
|
||||||
|
$start = date("Y-m-d", strtotime("last Sunday", strtotime($end)));
|
||||||
|
|
||||||
|
$tempTimeSheet = new EmployeeTimeSheet();
|
||||||
|
$tempTimeSheet->Load("employee = ? and date_start = ?",array($employee->id, $start));
|
||||||
|
if($employee->id == $tempTimeSheet->employee){
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Attendance Sheet already exists");
|
||||||
|
}
|
||||||
|
|
||||||
|
$newTimeSheet = new EmployeeTimeSheet();
|
||||||
|
$newTimeSheet->employee = $employee->id;
|
||||||
|
$newTimeSheet->date_start = $start;
|
||||||
|
$newTimeSheet->date_end = $end;
|
||||||
|
$newTimeSheet->status = "Pending";
|
||||||
|
$ok = $newTimeSheet->Save();
|
||||||
|
if(!$ok){
|
||||||
|
LogManager::getInstance()->info("Error creating time sheet : ".$newTimeSheet->ErrorMsg());
|
||||||
|
return new IceResponse(IceResponse::ERROR,"Error creating Attendance Sheet");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return new IceResponse(IceResponse::SUCCESS,"");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -3,15 +3,15 @@
|
|||||||
<div class="small-box bg-aqua">
|
<div class="small-box bg-aqua">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<h3 id="lastPunchTime">
|
<h3 id="lastPunchTime">
|
||||||
Punch In
|
<t>Punch In</t>
|
||||||
</h3>
|
</h3>
|
||||||
<p>or punch out</p>
|
<p><t>or</t> <t>Punch Out</t></p>
|
||||||
</div>
|
</div>
|
||||||
<div class="icon">
|
<div class="icon">
|
||||||
<i class="ion ion-ios7-alarm-outline"></i>
|
<i class="ion ion-ios7-alarm-outline"></i>
|
||||||
</div>
|
</div>
|
||||||
<a href="#_moduleLink_#" class="small-box-footer" id="atteandanceLink">
|
<a href="#_moduleLink_#" class="small-box-footer" id="atteandanceLink">
|
||||||
Record Attendance <i class="fa fa-arrow-circle-right"></i>
|
<t>Record Attendance</t> <i class="fa fa-arrow-circle-right"></i>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -33,7 +33,7 @@ if(empty($currentEmployeeTimeZone)){
|
|||||||
?><div class="span9">
|
?><div class="span9">
|
||||||
|
|
||||||
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
<ul class="nav nav-tabs" id="modTab" style="margin-bottom:0px;margin-left:5px;border-bottom: none;">
|
||||||
<li class="active"><a id="tabAttendance" href="#tabPageAttendance">Attendance</a></li>
|
<li class="active"><a id="tabAttendance" href="#tabPageAttendance"><?=LanguageManager::tran('Attendance')?></a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
|
|||||||
@@ -247,3 +247,212 @@ AttendanceAdapter.method('getClientGMTOffset', function () {
|
|||||||
return std_time_offset;
|
return std_time_offset;
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function EmployeeAttendanceSheetAdapter(endPoint,tab,filter,orderBy) {
|
||||||
|
this.initAdapter(endPoint,tab,filter,orderBy);
|
||||||
|
}
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.inherits(AdapterBase);
|
||||||
|
|
||||||
|
this.currentTimesheetId = null;
|
||||||
|
this.currentTimesheet = null;
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('getDataMapping', function() {
|
||||||
|
return [
|
||||||
|
"id",
|
||||||
|
"date_start",
|
||||||
|
"date_end",
|
||||||
|
"total_time",
|
||||||
|
"status"
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('getHeaders', function() {
|
||||||
|
return [
|
||||||
|
{ "sTitle": "ID" ,"bVisible":false},
|
||||||
|
{ "sTitle": "Start Date"},
|
||||||
|
{ "sTitle": "End Date"},
|
||||||
|
{ "sTitle": "Total Time"},
|
||||||
|
{ "sTitle": "Status"}
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('getFormFields', function() {
|
||||||
|
return [
|
||||||
|
[ "id", {"label":"ID","type":"hidden"}],
|
||||||
|
[ "date_start", {"label":"TimeSheet Start Date","type":"date","validation":""}],
|
||||||
|
[ "date_end", {"label":"TimeSheet End Date","type":"date","validation":""}],
|
||||||
|
[ "details", {"label":"Reason","type":"textarea","validation":"none"}]
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('preProcessTableData', function(row) {
|
||||||
|
row[1] = Date.parse(row[1]).toString('MMM d, yyyy (dddd)');
|
||||||
|
row[2] = Date.parse(row[2]).toString('MMM d, yyyy (dddd)');
|
||||||
|
return row;
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('renderForm', function(object) {
|
||||||
|
var formHtml = this.templates['formTemplate'];
|
||||||
|
var html = "";
|
||||||
|
|
||||||
|
$("#"+this.getTableName()+'Form').html(formHtml);
|
||||||
|
$("#"+this.getTableName()+'Form').show();
|
||||||
|
$("#"+this.getTableName()).hide();
|
||||||
|
|
||||||
|
$('#attendnacesheet_start').html(Date.parse(object.date_start).toString('MMM d, yyyy (dddd)'));
|
||||||
|
$('#attendnacesheet_end').html(Date.parse(object.date_end).toString('MMM d, yyyy (dddd)'));
|
||||||
|
|
||||||
|
this.currentTimesheet = object;
|
||||||
|
|
||||||
|
this.getTimeEntries();
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('getTimeEntries', function() {
|
||||||
|
timesheetId = this.currentId;
|
||||||
|
var sourceMappingJson = JSON.stringify(modJsList['tabEmployeeTimeEntry'].getSourceMapping());
|
||||||
|
object = {"id":timesheetId,"sm":sourceMappingJson};
|
||||||
|
|
||||||
|
var reqJson = JSON.stringify(object);
|
||||||
|
|
||||||
|
var callBackData = [];
|
||||||
|
callBackData['callBackData'] = [];
|
||||||
|
callBackData['callBackSuccess'] = 'getTimeEntriesSuccessCallBack';
|
||||||
|
callBackData['callBackFail'] = 'getTimeEntriesFailCallBack';
|
||||||
|
|
||||||
|
this.customAction('getTimeEntries','modules=time_sheets',reqJson,callBackData);
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('getTimeEntriesSuccessCallBack', function(callBackData) {
|
||||||
|
var entries = callBackData;
|
||||||
|
var html = "";
|
||||||
|
var temp = '<tr><td><img class="tableActionButton" src="_BASE_images/delete.png" style="cursor:pointer;" rel="tooltip" title="Delete" onclick="modJsList[\'tabEmployeeTimeEntry\'].deleteRow(_id_);return false;"></img></td><td>_start_</td><td>_end_</td><td>_duration_</td><td>_project_</td><td>_details_</td>';
|
||||||
|
|
||||||
|
for(var i=0;i<entries.length;i++){
|
||||||
|
try{
|
||||||
|
var t = temp;
|
||||||
|
t = t.replace(/_start_/g,Date.parse(entries[i].date_start).toString('MMM d, yyyy [hh:mm tt]'));
|
||||||
|
t = t.replace(/_end_/g,Date.parse(entries[i].date_end).toString('MMM d, yyyy [hh:mm tt]'));
|
||||||
|
|
||||||
|
var mili = Date.parse(entries[i].date_end) - Date.parse(entries[i].date_start);
|
||||||
|
var minutes = Math.round(mili/60000);
|
||||||
|
var hourMinutes = (minutes % 60);
|
||||||
|
var hours = (minutes-hourMinutes)/60;
|
||||||
|
|
||||||
|
t = t.replace(/_duration_/g,"Hours ("+hours+") - Min ("+hourMinutes+")");
|
||||||
|
if(entries[i].project == 'null' || entries[i].project == null || entries[i].project == undefined){
|
||||||
|
t = t.replace(/_project_/g,"None");
|
||||||
|
}else{
|
||||||
|
t = t.replace(/_project_/g,entries[i].project);
|
||||||
|
}
|
||||||
|
t = t.replace(/_project_/g,entries[i].project);
|
||||||
|
t = t.replace(/_details_/g,entries[i].details);
|
||||||
|
t = t.replace(/_id_/g,entries[i].id);
|
||||||
|
t = t.replace(/_BASE_/g,this.baseUrl);
|
||||||
|
html += t;
|
||||||
|
}catch(e){}
|
||||||
|
}
|
||||||
|
|
||||||
|
$('.timesheet_entries_table_body').html(html);
|
||||||
|
if(modJs.getTableName() == 'SubEmployeeTimeSheetAll'){
|
||||||
|
$('#submit_sheet').hide();
|
||||||
|
$('#add_time_sheet_entry').hide();
|
||||||
|
}else{
|
||||||
|
if(this.currentElement.status == 'Approved'){
|
||||||
|
$('#submit_sheet').hide();
|
||||||
|
$('#add_time_sheet_entry').hide();
|
||||||
|
}else{
|
||||||
|
$('#submit_sheet').show();
|
||||||
|
$('#add_time_sheet_entry').show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('getTimeEntriesFailCallBack', function(callBackData) {
|
||||||
|
this.showMessage("Error", "Error occured while getting timesheet entries");
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('createPreviousAttendnacesheet', function(id) {
|
||||||
|
object = {"id":id};
|
||||||
|
|
||||||
|
var reqJson = JSON.stringify(object);
|
||||||
|
|
||||||
|
var callBackData = [];
|
||||||
|
callBackData['callBackData'] = [];
|
||||||
|
callBackData['callBackSuccess'] = 'createPreviousAttendnacesheetSuccessCallBack';
|
||||||
|
callBackData['callBackFail'] = 'createPreviousAttendnacesheetFailCallBack';
|
||||||
|
|
||||||
|
this.customAction('createPreviousAttendnaceSheet','modules=attendnace',reqJson,callBackData);
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('createPreviousAttendnacesheetSuccessCallBack', function(callBackData) {
|
||||||
|
$('.tooltip').css("display","none");
|
||||||
|
$('.tooltip').remove();
|
||||||
|
//this.showMessage("Success", "Previous Timesheet created");
|
||||||
|
this.get([]);
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('createPreviousAttendnacesheetFailCallBack', function(callBackData) {
|
||||||
|
this.showMessage("Error", callBackData);
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('getActionButtonsHtml', function(id,data) {
|
||||||
|
var html = '';
|
||||||
|
if(this.getTableName() == "EmployeeTimeSheetAll"){
|
||||||
|
html = '<div style="width:80px;"><img class="tableActionButton" src="_BASE_images/view.png" style="cursor:pointer;" rel="tooltip" title="Edit Timesheet Entries" onclick="modJs.edit(_id_);return false;"></img><img class="tableActionButton" src="_BASE_images/redo.png" style="cursor:pointer;margin-left:15px;" rel="tooltip" title="Create previous time sheet" onclick="modJs.createPreviousAttendnacesheet(_id_);return false;"></img></div>';
|
||||||
|
}else{
|
||||||
|
html = '<div style="width:80px;"><img class="tableActionButton" src="_BASE_images/view.png" style="cursor:pointer;" rel="tooltip" title="Edit Timesheet Entries" onclick="modJs.edit(_id_);return false;"></img></div>';
|
||||||
|
}
|
||||||
|
html = html.replace(/_id_/g,id);
|
||||||
|
html = html.replace(/_BASE_/g,this.baseUrl);
|
||||||
|
return html;
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('getCustomTableParams', function() {
|
||||||
|
var that = this;
|
||||||
|
var dataTableParams = {
|
||||||
|
"aoColumnDefs": [
|
||||||
|
{
|
||||||
|
"fnRender": function(data, cell){
|
||||||
|
return that.preProcessRemoteTableData(data, cell, 1)
|
||||||
|
} ,
|
||||||
|
"aTargets": [1]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fnRender": function(data, cell){
|
||||||
|
return that.preProcessRemoteTableData(data, cell, 2)
|
||||||
|
} ,
|
||||||
|
"aTargets": [2]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fnRender": that.getActionButtons,
|
||||||
|
"aTargets": [that.getDataMapping().length]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
return dataTableParams;
|
||||||
|
});
|
||||||
|
|
||||||
|
EmployeeAttendanceSheetAdapter.method('preProcessRemoteTableData', function(data, cell, id) {
|
||||||
|
return Date.parse(cell).toString('MMM d, yyyy (dddd)');
|
||||||
|
});
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user