Compare commits

..

No commits in common. "BiFacePro2.0.1" and "BiFacePro2.1" have entirely different histories.

37 changed files with 241 additions and 1467 deletions

3
.gitignore vendored
View File

@ -2,5 +2,4 @@
/web/assets
/web/data
/vendor/
/nbproject/private/
/db
/nbproject/private/

View File

@ -1,23 +0,0 @@
<?php
namespace app\assets;
use yii\web\AssetBundle;
class FaceComparisonAsset extends AssetBundle {
public $basePath = '@webroot';
public $baseUrl = '@web';
public $css = [
];
public $js = [
'js/face-comparison.js'
];
public $depends = [
'yii\web\YiiAsset',
'app\assets\AppAsset',
'yii\jui\JuiAsset',
'yii\bootstrap\BootstrapAsset',
];
}

View File

@ -2,10 +2,7 @@
return [
'adminEmail' => 'admin@example.com',
"type" => "BiFace", // BiFace, BiTable
"maxLogs" => 50000,
"maxLogs" => 100000,
"maxPicture" => 9999,
"version" => "1.0.7",
"autoSyncLog" => false,
"timeoutRequestServer" => 4
"version" => "1.0.7"
];

View File

@ -9,7 +9,6 @@ use yii\helpers\FileHelper;
use app\models\CaptureLogs;
use app\models\ListManagement;
use app\models\common;
use app\models\Schedule;
/**
* CardController implements the CRUD actions for Card model.
@ -58,7 +57,6 @@ class ApiController extends Controller {
public function actionGetLogs() {
if (Yii::$app->request->post()) {
Yii::$app->response->format = "json";
$post = Yii::$app->request->bodyParams;
$time = date_format(date_create_from_format('Y-m-d H:i:s', $post['time']), 'U');
$key = common::generateRandomString();
@ -71,14 +69,9 @@ class ApiController extends Controller {
$totalsLogs = CaptureLogs::find()->count();
if ($totalsLogs >= \Yii::$app->params['maxLogs']) {
$lastLogs = CaptureLogs::find()->orderBy(["id" => SORT_ASC])->limit(1)->one();
@unlink("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $lastLogs->image);
unlink("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $lastLogs->image);
$lastLogs->delete();
}
$lastLogs = CaptureLogs::find()->andWhere(["staff_id" => $post['id']])->orderBy(["time" => SORT_DESC])->limit(1)->one();
if ($lastLogs && ($time - $lastLogs->time) < 1) {
file_put_contents("log_connect_server.txt", "\n[" . date("H:i:s d/m/Y") . "] duplicate face " . $post["id"], FILE_APPEND);
return ["status" => "success"];
}
$model = new CaptureLogs();
$logs = $model->create([
@ -91,10 +84,7 @@ class ApiController extends Controller {
$ip = "https://dev-dc.beetai.com";
if ($server_ip)
$ip = $server_ip->data;
$parseUrl = parse_url($ip);
$host = $parseUrl['host'];
$port = isset($parseUrl['port']) ? $parseUrl['port'] : 80;
if ($this->is_connected($host, $port) && $logs) {
if ($this->is_connected() && $logs) {
$device_id = \app\models\SyncUrl::findOne(['key_config' => 'device_id']);
$id_camera = 0;
if ($device_id)
@ -113,25 +103,22 @@ class ApiController extends Controller {
$data[] = "123"; //person_id
$data[] = "+7"; //timezone
$text = implode("|", $data);
$res = json_decode(@file_get_contents($ip . "/api/box/face_recognition_auth_v2?token=" . $tk, false, stream_context_create([
'http' => [
'timeout' => Yii::$app->params['timeoutRequestServer'],
'header' => "Content-Type: application/json",
'method' => "POST",
'content' => json_encode([
'image' => base64_encode(file_get_contents("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $fileName)),
'data' => common::rsaEncode($text),
'confidence' => isset($post["confidence"]["percent1"]) ? $post["confidence"]["percent1"] : 0
])
]
$res = json_decode(file_get_contents($ip . "/api/box/face_recognition_auth_v2?token=" . $tk, false, stream_context_create([
'http' => [
'header' => "Content-Type: application/json",
'method' => "POST",
'content' => json_encode([
'image' => base64_encode(file_get_contents("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $fileName)),
'data' => common::rsaEncode($text)
])
]
])), true);
if ($res && $res['status'] == 10000) {
if ($res['status'] == 10000) {
$logsInfo->sync_status = 1;
$logsInfo->save();
} else {
file_put_contents("log_connect_server.txt", "\n[" . date("H:i:s d/m/Y") . "] /api/box/face_recognition_auth_v2 timeout " . $ip, FILE_APPEND);
}
}
Yii::$app->response->format = "json";
return ["status" => "success"];
}
}
@ -162,7 +149,6 @@ class ApiController extends Controller {
}
$allFeatures[] = [
"id" => $value->id,
"object_id" => $value->staff_id,
"name" => $this->convert_vi_to_en($value->name),
"feature1" => $feature1,
"feature2" => $feature2
@ -283,18 +269,18 @@ class ApiController extends Controller {
$updating->data = "false";
$updating->save();
$txt = "\n" . date("H:i:s d/m/Y") . " " . "success";
// file_put_contents(date('Ymd') . "_logs.txt", $txt, FILE_APPEND);
file_put_contents(date('Ymd') . "_logs.txt", $txt, FILE_APPEND);
return ["status" => false];
} else {
$txt = "\n" . date("H:i:s d/m/Y") . " " . "updating";
// file_put_contents(date('Ymd') . "_logs.txt", $txt, FILE_APPEND);
file_put_contents(date('Ymd') . "_logs.txt", $txt, FILE_APPEND);
return ["status" => false];
}
}
if ($currentCache['n_128'] == $currentCache['n_512']) {
$txt = "\n" . date("H:i:s d/m/Y") . " " . "success";
// file_put_contents(date('Ymd') . "_logs.txt", $txt, FILE_APPEND);
file_put_contents(date('Ymd') . "_logs.txt", $txt, FILE_APPEND);
return ["status" => false];
}
@ -336,7 +322,7 @@ class ApiController extends Controller {
$finish = $this->getCurrentTime();
$processTime["updateDB"] = round(($finish - $start), 4);
$txt = "\n" . json_encode($processTime);
// file_put_contents(date('Ymd') . ".txt", $txt, FILE_APPEND);
file_put_contents(date('Ymd') . ".txt", $txt, FILE_APPEND);
}
}
@ -348,19 +334,17 @@ class ApiController extends Controller {
public function actionSync() {
Yii::$app->response->format = "json";
$server_ip = \app\models\SyncUrl::findOne(['key_config' => 'server_api']);
$ip = "https://dev-dc.beetai.com";
if ($server_ip)
$ip = $server_ip->data;
$parseUrl = parse_url($ip);
$host = $parseUrl['host'];
$port = isset($parseUrl['port']) ? $parseUrl['port'] : 80;
if ($this->is_connected($host, $port)) {
if ($this->is_connected()) {
$server_ip = \app\models\SyncUrl::findOne(['key_config' => 'server_api']);
$ip = "https://dev-dc.beetai.com";
if ($server_ip)
$ip = $server_ip->data;
$device_id = \app\models\SyncUrl::findOne(['key_config' => 'device_id']);
$id_camera = 0;
if ($device_id)
$id_camera = intval($device_id->data);
$ls = CaptureLogs::find()->andWhere(['sync_status' => null])->all();
$tk = "";
$token = \app\models\SyncUrl::findOne(['key_config' => 'token']);
if ($token)
@ -368,32 +352,24 @@ class ApiController extends Controller {
foreach ($ls as $key => $value) {
if (file_exists("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $value->image)) {
$staffInfo = ListManagement::findOne($value->staff_id);
$confidence = json_decode($value->confidence, true);
$data = [];
$data[] = strval($id_camera); //camera_id
$data[] = date("Y-m-d H:i:s", $value->time); //frametime
$data[] = $staffInfo ? strval($staffInfo->code) : "0"; //idCard
$data[] = $staffInfo ? $staffInfo->staff_id : ""; //idObject
$data[] = "123"; //person_id
$data[] = "+7"; //timezone
$text = implode("|", $data);
$res = json_decode(@file_get_contents($ip . "/api/box/face_recognition_auth_v2?token=" . $tk, false, stream_context_create([
'http' => [
'timeout' => Yii::$app->params['timeoutRequestServer'],
'header' => "Content-Type: application/json",
'method' => "POST",
'content' => json_encode([
'image' => base64_encode(file_get_contents("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $value->image)),
'data' => common::rsaEncode($text),
'confidence' => isset($confidence['percent1']) ? floatval($confidence['percent1']) : 0
])
]
$res = json_decode(file_get_contents($ip . "/api/oem/face_recognition?token=" . $tk, false, stream_context_create([
'http' => [
'header' => "Content-Type: application/json",
'method' => "POST",
'content' => json_encode([
'image' => base64_encode(file_get_contents("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $value->image)),
'camera_id' => strval($id_camera),
'frametime' => date("Y-m-d H:i:s", $value->time),
'idCard' => $staffInfo ? strval($staffInfo->code) : "0",
'idObject' => $staffInfo ? $staffInfo->staff_id : "",
"person_id" => "123",
"timezone" => "+7"
])
]
])), true);
if ($res && $res['status'] == 10000) {
if ($res['status'] == 10000) {
$value->sync_status = 1;
$value->save();
} else {
file_put_contents("log_connect_server.txt", "\n[" . date("H:i:s d/m/Y") . "][SYNC] face_recognition_auth_v2 timeout " . $ip, FILE_APPEND);
}
} else {
$value->delete();
@ -403,16 +379,14 @@ class ApiController extends Controller {
return ["status" => true];
}
function is_connected($host, $port) {
$connected = @fsockopen($host, $port);
//website, port (try 80 or 443)
function is_connected($ip = "google.com") {
$connected = @fsockopen($ip, 80);
//website, port (try 80 or 443)
if ($connected) {
$is_conn = true; //action when connected
fclose($connected);
// file_put_contents("log_connect_server.txt", "\n" . date("H:i:s d/m/Y") . " connected " . $host . ":" . $port, FILE_APPEND);
} else {
$is_conn = false; //action in connection failure
file_put_contents("log_connect_server.txt", "\n[" . date("H:i:s d/m/Y") . "] disconnected " . $host . ":" . $port, FILE_APPEND);
}
return $is_conn;
}
@ -507,18 +481,15 @@ class ApiController extends Controller {
}
public function actionTest() {
$server_ip = \app\models\SyncUrl::findOne(['key_config' => 'server_api']);
$ip = "https://dev-dc.beetai.com";
if ($server_ip)
$ip = $server_ip->data;
$parseUrl = parse_url($ip);
$host = $parseUrl['host'];
$port = isset($parseUrl['port']) ? $parseUrl['port'] : 80;
$this->is_connected($host, $port);
// $updating = \app\models\SyncUrl::findOne(['key_config' => 'token']);
$updating = \app\models\SyncUrl::find()->all();
foreach ($updating as $key => $value) {
echo $value->key_config . " " . $value->data . "<br>";
}
exit();
}
public function actionReGenFeature() {
\app\models\SyncUrl::deleteAll(['key_config' => 'log_process_status']);
$updating = \app\models\SyncUrl::findOne(['key_config' => 'updating']);
if (!$updating) {
$model = new \app\models\SyncUrl();
@ -543,27 +514,7 @@ class ApiController extends Controller {
}
public function actionCheckLogs() {
set_time_limit(5000);
Yii::$app->response->format = "json";
$logProcessStatus = \app\models\SyncUrl::findOne(['key_config' => 'log_process_status']);
if (!$logProcessStatus) {
$model = new \app\models\SyncUrl();
$model->create(['key_config' => 'log_process_status', 'data' => json_encode(["status" => true, "time" => time()])]);
$logProcessStatus = \app\models\SyncUrl::findOne(['key_config' => 'log_process_status']);
} else {
$processStatus = json_decode($logProcessStatus->data, true);
if ($processStatus['status']) {
if (time() - $processStatus['time'] < 60 * 3) {
if (Yii::$app->params['autoSyncLog'])
file_put_contents("logs.txt", "CHECK LOGS PROCESSING\n", FILE_APPEND);
return ["data" => "check logs processing"];
}
} else {
$logProcessStatus->data = json_encode(["status" => true, "time" => time()]);
$logProcessStatus->save();
}
}
$server_ip = \app\models\SyncUrl::findOne(['key_config' => 'server_api']);
$ip = "https://dev-dc.beetai.com";
if ($server_ip)
@ -583,83 +534,53 @@ class ApiController extends Controller {
])
]
])), true);
if (Yii::$app->params['autoSyncLog'])
file_put_contents("logs.txt", "START CHECK LOGS\n", FILE_APPEND);
if ($datas['status'] == 10000) {
$logs = $datas['data'];
$infomation = [];
$fault_information = [];
$count = 0;
foreach ($logs as $key => $value) {
$count++;
$start = $this->getCurrentTime();
$result = true;
if ($value['action'] == "insert_image")
$result = $this->insertImage($value['images'][0], $value['id'], $value['files_name'][0]);
$this->insertImage($value['images'][0], $value['id'], $value['files_name'][0]);
if ($value['action'] == "remove_image")
$result = $this->removeImage($value['id'], $value['files_name'][0]);
$this->removeImage($value['id'], $value['files_name'][0]);
if ($value['action'] == "insert_info")
$result = $this->insertInfo($value);
$this->insertInfo($value);
if ($value['action'] == "remove_info")
$result = $this->removeInfo($value);
if ($value['action'] == "insert_door_open")
$result = $this->insertSchedule($value);
if ($value['action'] == "remove_door_open")
$result = $this->removeSchedule($value);
$this->removeInfo($value);
if ($value['action'] == "reset_all") {
\Yii::$app->db->createCommand()->truncateTable('capture_logs')->execute();
\Yii::$app->db->createCommand()->truncateTable('list_management')->execute();
array_map('unlink', glob("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/*.*"));
}
$finish = $this->getCurrentTime();
$processTime = round(($finish - $start), 4);
if (Yii::$app->params['autoSyncLog'])
file_put_contents("logs.txt", $count . "\t" . $value['action'] . "\t" . $value['files_name'][0] . "\t" . ($result ? "true" : "false") . "\t" . $processTime . "\t" . $value['name'] . "\n", FILE_APPEND);
if (in_array($value['action'], ['insert_image', 'remove_image', 'insert_info', 'remove_info', 'reset_all', 'insert_door_open', 'remove_door_open'])) {
if ($result)
$infomation[] = [
"obj_Log" => $value['obj_Log'],
"action" => $value['action'],
"idCamera" => $id_camera
];
else
$fault_information[] = [
"obj_Log" => $value['obj_Log'],
"action" => $value['action'],
"idCamera" => $id_camera
];
if (in_array($value['action'], ['insert_image', 'remove_image', 'insert_info', 'remove_info', 'reset_all'])) {
$infomation[] = [
"obj_Log" => $value['obj_Log'],
"action" => $value['action'],
"idCamera" => $id_camera
];
}
}
if (count($infomation) > 0 || count($fault_information) > 0) {
if (count($infomation) > 0)
file_get_contents($ip . "/api/model/set_log_model", false, stream_context_create([
'http' => [
'header' => "Content-Type: application/json",
'method' => "POST",
'content' => json_encode([
"infomation" => $infomation,
"fault_information" => $fault_information
"infomation" => $infomation
])
]
]));
@file_get_contents("http://localhost:2305/update-feature?total=" . ListManagement::find()->count());
}
@file_get_contents("http://localhost:2305/update-feature?total=" . ListManagement::find()->count());
}
$logProcessStatus->data = json_encode(["status" => false, "time" => time()]);
$logProcessStatus->save();
return ["data" => "check logs"];
}
public function insertImage($image, $staff_id, $files_name) {
$model = ListManagement::findOne(['staff_id' => $staff_id]);
if (!$model)
return false;
$RootFolder = Yii::getAlias('@webroot') . "/data/uploads";
$targetPath = $RootFolder . "/face";
@ -693,11 +614,8 @@ class ApiController extends Controller {
],
"type" => "128"
]);
if (!$features['status']) {
if (Yii::$app->params['autoSyncLog'])
file_put_contents("logs.txt", "[ERROR] extract feature " . json_encode($features) . "\n", FILE_APPEND);
if (!$features['status'])
return false;
}
$features = json_decode($features['data'], true);
$ft[] = [
"serverKey" => $files_name,
@ -708,34 +626,24 @@ class ApiController extends Controller {
];
$model->image = json_encode($ft);
$model->last_modified = time();
return $model->save();
} else {
if (Yii::$app->params['autoSyncLog'])
file_put_contents("logs.txt", "[ERROR] image error" . $image . "\n", FILE_APPEND);
return false;
$model->save();
}
} else {
if (Yii::$app->params['autoSyncLog'])
file_put_contents("logs.txt", "[ERROR] file exists" . $files_name . "\n", FILE_APPEND);
return false;
}
}
public function removeImage($staff_id, $files_name) {
$model = ListManagement::findOne(['staff_id' => $staff_id]);
if (!$model)
return false;
$images = json_decode($model->image, true);
$ft = [];
foreach ($images as $key => $value) {
if (isset($value['serverKey']) && $value['serverKey'] !== $files_name)
if ($value['serverKey'] !== $files_name)
$ft[] = $value;
else
@unlink("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $value['url']);
unlink("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $value['url']);
}
$model->image = json_encode($ft);
$model->last_modified = time();
return $model->save();
$model->save();
}
public function insertInfo($data) {
@ -762,7 +670,6 @@ class ApiController extends Controller {
'abbreviated_name' => $data['abbreviated_name'],
]);
}
return true;
}
public function removeInfo($data) {
@ -770,11 +677,11 @@ class ApiController extends Controller {
if ($model) {
$images = json_decode($model->image, true);
foreach ($images as $k => $v) {
@unlink("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $v['url']);
unlink("/var/www/html/BiFace_Server_Lite/web/data/uploads/face/" . $v['url']);
}
$model->delete();
}
return true;
return;
}
public function resizeImg($img, $fileTarget) {
@ -794,92 +701,4 @@ class ApiController extends Controller {
return false;
}
public function insertSchedule($data) {
$model = new Schedule();
$info = ListManagement::findOne(['staff_id' => $data['id']]);
$schedule = Schedule::findOne(['staff_id' => $info->id, 'id_door_calendar' => $data['id_door_calendar']]);
if ($schedule) {
$schedule->from_time = $data['time_in'];
$schedule->to_time = $data['time_out'];
$schedule->from_date = $this->formatDateSchedule($data['day_in']);
$schedule->to_date = $this->formatDateSchedule($data['day_out']);
$schedule->date_of_week = $this->formatDayOfWeekSchedule($data['day_of_week']);
return $schedule->save();
} else {
return $model->create([
'staff_id' => $info->id,
'from_time' => $data['time_in'],
'to_time' => $data['time_out'],
'from_date' => $this->formatDateSchedule($data['day_in']),
'to_date' => $this->formatDateSchedule($data['day_out']),
'date_of_week' => $this->formatDayOfWeekSchedule($data['day_of_week']),
'id_door_calendar' => $data['id_door_calendar']
]);
}
}
public function removeSchedule($data) {
$info = ListManagement::findOne(['staff_id' => $data['id']]);
if ($info) {
$schedule = \app\models\Schedule::findOne([
'id_door_calendar' => $data['id_door_calendar'],
'staff_id' => $info->id
]);
if ($schedule)
$schedule->delete();
}
return true;
}
public function formatDateSchedule($date) {
$temp = explode(" ", $date);
$parse = explode("-", $temp[0]);
return $parse[2] . "/" . $parse[1] . "/" . $parse[0];
}
public function formatDayOfWeekSchedule($dayOfWeek) {
$days = [];
$temp = explode("|", $dayOfWeek);
foreach ($temp as $key => $value) {
if ($value != "")
$days[] = intval($value) + 2;
}
return implode(",", $days);
}
public function actionCheckOpenDoor() {
if (Yii::$app->request->post()) {
$post = Yii::$app->request->bodyParams;
$info = ListManagement::findOne(["staff_id" => $post["object_id"]]);
$timeGet = date_format(date_create_from_format('Y-m-d H:i:s', $post['timeget']), 'U');
$openDoor = 0;
if ($info) {
$schedules = Schedule::find()->andWhere(["staff_id" => $info->id])->all();
foreach ($schedules as $key => $value) {
$fromDate = date_format(date_create_from_format('H:i:s d/m/Y', "00:00:00 " . $value->from_date), 'U');
$toDate = date_format(date_create_from_format('H:i:s d/m/Y', "23:59:59 " . $value->to_date), 'U');
if ($timeGet > $fromDate && $timeGet < $toDate) {
$dateOfWeek = explode(",", $value->date_of_week);
$weekDay = intval(date("w", $timeGet)) + 1;
if ($weekDay == 1)
$weekDay = 8;
if (in_array($weekDay, $dateOfWeek)) {
$fromTime = date_format(date_create_from_format('H:i:s d/m/Y', $value->from_time . ":00 " . date("d/m/Y", $timeGet)), 'U');
$toTime = date_format(date_create_from_format('H:i:s d/m/Y', $value->to_time . ":59 " . date("d/m/Y", $timeGet)), 'U');
if ($timeGet > $fromTime && $timeGet < $toTime)
$openDoor = 1;
}
}
}
}
Yii::$app->response->format = "json";
return [
"status" => 10000,
"data" => [
"open_door" => $openDoor
]
];
}
}
}

View File

@ -117,39 +117,4 @@ class CaptureLogsController extends Controller {
throw new NotFoundHttpException(Yii::t("app", "KHONG_TIM_THAY_THONG_TIN"));
}
public function actionFaceComparison() {
if (Yii::$app->request->post()) {
$post = Yii::$app->request->post();
Yii::$app->response->format = "json";
$results = json_decode(file_get_contents("http://192.168.1.43:2305/compare", false, stream_context_create([
'http' => [
'header' => "Content-Type: application/json",
'method' => "POST",
'content' => json_encode([
"type" => "base64",
"img0" => base64_encode(file_get_contents("/var/www/html/BiFace_Server_Lite/web" . $post['face1'])),
"img1" => base64_encode(file_get_contents("/var/www/html/BiFace_Server_Lite/web" . $post['face2']))
])
]
])), true);
return [
"type1" => number_format($results['type1']['percent'] * 100, 2),
"type2" => number_format($results['type2']['percent'] * 100, 2)
];
} else {
$this->view->title = Yii::t("app", "SO_SANH_MAT");
return $this->render('face-comparison', [
]);
}
}
public function actionUploadFace() {
if (Yii::$app->request->post()) {
$post = Yii::$app->request->post();
$model = new \app\models\UploadForm();
$url = $model->UploadGlobal("image" . $post['imageIndex'], ["PNG", "JPG", "JPEG", "GIF"], "comparison");
return $url;
}
}
}

View File

@ -159,8 +159,6 @@ class ConfigController extends Controller {
public function actionIndex() {
$this->view->title = Yii::t("app", "CAU_HINH_MAY_CHU");
if (Yii::$app->params['type'] != "BiFace")
return $this->redirect(['cau-hinh-ip']);
$options = [
'http' => [
'header' => "Content-Type: application/json",
@ -176,8 +174,7 @@ class ConfigController extends Controller {
}
return $this->render('index', [
"servermqtt" => $servermqtt === "" ? $ip . ":1883" : $servermqtt,
"url" => isset($temp[2]) ? $temp[2] : $ip . ":5001",
"menu" => $this->renderPartial("menu", ["tab" => "server_config"])
"url" => isset($temp[2]) ? $temp[2] : $ip . ":5001"
]);
}
@ -262,8 +259,6 @@ class ConfigController extends Controller {
return true;
} else {
$this->view->title = Yii::t("app", "CAU_HINH_NHAN_DIEN");
if (Yii::$app->params['type'] != "BiFace")
return $this->redirect(['cau-hinh-ip']);
$tempConfig = json_decode(file_get_contents("http://localhost:4004/ReadEngineConfig", false, stream_context_create([
'http' => [
'header' => "Content-Type: application/json",
@ -295,8 +290,7 @@ class ConfigController extends Controller {
$config_json = json_decode($checkConfig['data'], true);
return $this->render('config', [
"config_json" => \app\widgets\ConfigTree::widget(['configLists' => $config_json, 'isRoot' => true, 'parent_id' => 'node', 'parent_key' => '']),
"menu" => $this->renderPartial("menu", ["tab" => "engine_config"])
"config_json" => \app\widgets\ConfigTree::widget(['configLists' => $config_json, 'isRoot' => true, 'parent_id' => 'node', 'parent_key' => ''])
]);
}
}
@ -313,7 +307,6 @@ class ConfigController extends Controller {
} catch (\Exception $exc) {
}
\app\models\SyncUrl::deleteAll(['key_config' => 'log_process_status']);
$server_ip = \app\models\SyncUrl::findOne(['key_config' => 'server_api']);
$ip = "https://dev-dc.beetai.com";
if ($server_ip)
@ -428,8 +421,6 @@ class ConfigController extends Controller {
public function actionCauHinhThietBi() {
$this->view->title = Yii::t("app", "CAU_HINH_THIET_BI");
if (Yii::$app->params['type'] != "BiFace")
return $this->redirect(['cau-hinh-ip']);
$tempConfig = json_decode(file_get_contents("http://localhost:4004/ReadEngineConfig", false, stream_context_create([
'http' => [
@ -460,8 +451,7 @@ class ConfigController extends Controller {
}
return $this->render('device', [
"server_api" => \app\models\SyncUrl::findOne(['key_config' => 'server_api']),
"device_id" => \app\models\SyncUrl::findOne(['key_config' => 'device_id']),
"menu" => $this->renderPartial("menu", ["tab" => "device_config"])
"device_id" => \app\models\SyncUrl::findOne(['key_config' => 'device_id'])
]);
}
@ -495,72 +485,4 @@ class ConfigController extends Controller {
}
}
public $subnet = [
"0.0.0.0" => "/0",
"128.0.0.0" => "/1",
"192.0.0.0" => "/2",
"224.0.0.0" => "/3",
"240.0.0.0" => "/4",
"248.0.0.0" => "/5",
"252.0.0.0" => "/6",
"254.0.0.0" => "/7",
"255.0.0.0" => "/8",
"255.128.0.0" => "/9",
"255.192.0.0" => "/10",
"255.224.0.0" => "/11",
"255.240.0.0" => "/12",
"255.248.0.0" => "/13",
"255.252.0.0" => "/14",
"255.254.0.0" => "/15",
"255.255.0.0" => "/16",
"255.255.128.0" => "/17",
"255.255.192.0" => "/18",
"255.255.224.0" => "/19",
"255.255.240.0" => "/20",
"255.255.248.0" => "/21",
"255.255.252.0" => "/22",
"255.255.254.0" => "/23",
"255.255.255.0" => "/24",
"255.255.255.128" => "/25",
"255.255.255.192" => "/26",
"255.255.255.224" => "/27",
"255.255.255.240" => "/28",
"255.255.255.248" => "/29",
"255.255.255.252" => "/30",
"255.255.255.254" => "/31",
"255.255.255.255" => "/32"
];
public function actionCauHinhIp() {
if (Yii::$app->request->post()) {
Yii::$app->response->format = "json";
$post = Yii::$app->request->post();
if (!$post['dhcp'] && !isset($this->subnet[$post['subnet_mask']]))
return ["status" => false];
$post['subnet_mask'] = isset($this->subnet[$post['subnet_mask']]) ? $this->subnet[$post['subnet_mask']] : "";
$options = [
'http' => [
'header' => "Content-Type: application/json",
'method' => "POST",
'content' => json_encode($post),
]
];
json_decode(@file_get_contents("http://localhost:4004/SetIP", false, stream_context_create($options)), true);
return ["status" => true, "url" => "http://" . $post['device_ip']];
} else {
$this->view->title = Yii::t("app", "CAU_HINH_IP");
$options = [
'http' => [
'header' => "Content-Type: application/json",
'method' => "POST"
]
];
$network = json_decode(@file_get_contents("http://localhost:4004/Network", false, stream_context_create($options)), true);
return $this->render('ip', [
"menu" => $this->renderPartial("menu", ["tab" => "ip_config"]),
"network" => $network
]);
}
}
}

View File

@ -120,7 +120,6 @@ class ControlLogsController extends Controller {
common::updateFeature([
"cmd" => "update",
"id" => $listManagement->id,
"object_id" => $listManagement->staff_id,
"name" => common::convert_vi_to_en($listManagement->name),
"features" => $listManagement->allFeatures
]);

View File

@ -76,10 +76,6 @@ class ListManagementController extends Controller {
]);
$updating = \app\models\SyncUrl::findOne(['key_config' => 'updating']);
}
$dataProvider->pagination->pageSize = 20;
if (Yii::$app->request->get("per-page"))
$dataProvider->pagination->pageSize = Yii::$app->request->get("per-page");
return $this->render('index', [
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
@ -98,7 +94,7 @@ class ListManagementController extends Controller {
Yii::$app->response->format = "json";
if (Yii::$app->request->post()) {
$data = Yii::$app->request->post();
$check = ListManagement::findOne(['id' => $data['code']]);
$check = ListManagement::findOne(['code' => $data['code']]);
if ($check)
return ["status" => false];
$features = common::requestToEngine("/get-feature", [
@ -127,7 +123,7 @@ class ListManagementController extends Controller {
Yii::$app->response->format = "json";
if (Yii::$app->request->post()) {
$data = Yii::$app->request->post();
$listManagement = ListManagement::findOne(['id' => $data['code']]);
$listManagement = ListManagement::findOne(['code' => $data['code']]);
$url = CaptureLogs::findOne($data['id'])->image;
if ($listManagement) {
$images = json_decode($listManagement->image, true);
@ -175,7 +171,6 @@ class ListManagementController extends Controller {
common::updateFeature([
"cmd" => "update",
"id" => $listManagement->id,
"object_id" => $listManagement->staff_id,
"name" => common::convert_vi_to_en($listManagement->name),
"features" => $listManagement->allFeatures
]);
@ -283,7 +278,6 @@ class ListManagementController extends Controller {
common::updateFeature([
"cmd" => "update",
"id" => $model->id,
"object_id" => $model->staff_id,
"name" => common::convert_vi_to_en($model->name),
"features" => $model->allFeatures
]);
@ -302,7 +296,6 @@ class ListManagementController extends Controller {
common::updateFeature([
"cmd" => "delete",
"id" => $model->id,
"object_id" => $model->staff_id,
"name" => common::convert_vi_to_en($model->name),
"features" => []
]);
@ -329,7 +322,6 @@ class ListManagementController extends Controller {
common::updateFeature([
"cmd" => "update",
"id" => $model->id,
"object_id" => $model->staff_id,
"name" => common::convert_vi_to_en($model->name),
"features" => $model->allFeatures
]);
@ -360,7 +352,6 @@ class ListManagementController extends Controller {
common::updateFeature([
"cmd" => "delete",
"id" => $staff->id,
"object_id" => $staff->staff_id,
"name" => common::convert_vi_to_en($staff->name),
"features" => []
]);
@ -454,15 +445,13 @@ class ListManagementController extends Controller {
foreach ($datas['data'] as $key => $value) {
$filters[$value['id']] = $value['code'] . " - " . $value['name'] . " - " . $value['department'];
}
$deviceDatas = ListManagement::getAllID();
Yii::$app->response->format = "json";
return [
"title" => "<i class='fa fa-download'></i> " . Yii::t("app", "DONG_BO_TU_MAY_CHU"),
"form" => $this->renderPartial("list-server", [
"datas" => $datas['data'],
"filters" => $filters,
"personImage" => $deviceDatas["imgCountArr"],
"allID" => $deviceDatas["idArr"]
"allID" => ListManagement::getAllID()
])
];
}
@ -566,14 +555,13 @@ class ListManagementController extends Controller {
$model->image = json_encode($ft);
$model->last_modified = time();
$model->save();
if ($totals <= 10)
common::updateFeature([
"cmd" => "update",
"id" => $model->id,
"object_id" => $model->staff_id,
"name" => common::convert_vi_to_en($model->name),
"features" => $model->allFeatures
]);
// if ($totals <= 10)
// common::updateFeature([
// "cmd" => "update",
// "id" => $model->id,
// "name" => common::convert_vi_to_en($model->name),
// "features" => $model->allFeatures
// ]);
} else {
if (isset($data['images'])) {
$extractFeature = $this->extractFeature($data['images'], $data['files_name'], $data['id']);
@ -599,14 +587,13 @@ class ListManagementController extends Controller {
]);
$finish = $this->getCurrentTime();
$processTime["insertDB"] = round(($finish - $start), 4);
if ($totals <= 10)
common::updateFeature([
"cmd" => "create",
"id" => $model->id,
"object_id" => $model->staff_id,
"name" => common::convert_vi_to_en($model->name),
"features" => $model->allFeatures
]);
// if ($totals <= 10)
// common::updateFeature([
// "cmd" => "create",
// "id" => $model->id,
// "name" => common::convert_vi_to_en($model->name),
// "features" => $model->allFeatures
// ]);
}
$totalFinish = $this->getCurrentTime();
$processTime["total"] = round(($totalFinish - $totalStart), 4);
@ -660,7 +647,6 @@ class ListManagementController extends Controller {
common::updateFeature([
"cmd" => "update",
"id" => $model->id,
"object_id" => $model->staff_id,
"name" => common::convert_vi_to_en($model->name),
"features" => $model->allFeatures
]);
@ -681,7 +667,6 @@ class ListManagementController extends Controller {
common::updateFeature([
"cmd" => "create",
"id" => $model->id,
"object_id" => $model->staff_id,
"name" => common::convert_vi_to_en($model->name),
"features" => $model->allFeatures
]);
@ -702,7 +687,7 @@ class ListManagementController extends Controller {
public function actionChooseStaff() {
if (Yii::$app->request->post()) {
$post = Yii::$app->request->post();
$staff = ListManagement::findOne(['id' => $post['code']]);
$staff = ListManagement::findOne(['code' => $post['code']]);
Yii::$app->response->format = "json";
return [
"name" => $staff->name,
@ -821,110 +806,4 @@ class ListManagementController extends Controller {
return file_get_contents("http://minio1.beetai.com/biface-school/origin/385/454_20201126101221879048.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=minioadmin%2F20201230%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Date=20201230T081350Z&X-Amz-Expires=604800&X-Amz-SignedHeaders=host&X-Amz-Signature=df7586a01bb128c0585edd87d1024b1ddb33483fd335e81238103fd2467b4772");
}
public function actionSchedule() {
Yii::$app->response->format = "json";
if (Yii::$app->request->post()) {
$post = Yii::$app->request->post();
$model = new \app\models\Schedule();
$datas = [];
foreach ($post['lists'] as $key => $value) {
$datas[] = [$value, $post['fromTime'], $post['toTime'], $post['fromDate'], $post['toDate'], implode(",", $post['dateOfWeek'])];
}
$model->multiCreate($datas);
return ["status" => true];
} else {
return [
"title" => Yii::t("app", "GAN_LICH_TRINH"),
"form" => $this->renderPartial("schedule", ["type" => "create"])
];
}
}
public function actionEditSchedule($id) {
Yii::$app->response->format = "json";
$model = \app\models\Schedule::findOne($id);
if (Yii::$app->request->post()) {
$post = Yii::$app->request->post();
$dateOfWeek = implode(",", $post['dateOfWeek']);
if ($post['editAll'] == "true" && isset($post['lists'])) {
foreach ($post['lists'] as $key => $value) {
$schedule = \app\models\Schedule::findOne([
'from_time' => $model->from_time,
'to_time' => $model->to_time,
'from_date' => $model->from_date,
'to_date' => $model->to_date,
'date_of_week' => $model->date_of_week,
'staff_id' => $value
]);
if ($schedule) {
$schedule->from_time = $post['fromTime'];
$schedule->to_time = $post['toTime'];
$schedule->from_date = $post['fromDate'];
$schedule->to_date = $post['toDate'];
$schedule->date_of_week = $dateOfWeek;
$schedule->save();
} else {
$modelSchedule = new \app\models\Schedule();
$modelSchedule->create([
'staff_id' => $value,
'from_time' => $post['fromTime'],
'to_time' => $post['toTime'],
'from_date' => $post['fromDate'],
'to_date' => $post['toDate'],
'date_of_week' => $dateOfWeek
]);
}
}
} else {
$model->from_time = $post['fromTime'];
$model->to_time = $post['toTime'];
$model->from_date = $post['fromDate'];
$model->to_date = $post['toDate'];
$model->date_of_week = $dateOfWeek;
$model->save();
}
return ["status" => true];
} else {
return [
"title" => Yii::t("app", "SUA_LICH_TRINH"),
"form" => $this->renderPartial("schedule", [
"type" => "edit",
"model" => $model
])
];
}
}
public function actionDeleteSchedule($id) {
Yii::$app->response->format = "json";
$model = \app\models\Schedule::findOne($id);
if (Yii::$app->request->post()) {
$post = Yii::$app->request->post();
if ($post['editAll'] == "true" && isset($post['lists'])) {
foreach ($post['lists'] as $key => $value) {
$schedule = \app\models\Schedule::findOne([
'from_time' => $model->from_time,
'to_time' => $model->to_time,
'from_date' => $model->from_date,
'to_date' => $model->to_date,
'date_of_week' => $model->date_of_week,
'staff_id' => $value
]);
if ($schedule)
$schedule->delete();
}
} else
$model->delete();
return ["status" => true];
} else {
return [
"title" => Yii::t("app", "XOA_LICH_TRINH"),
"form" => $this->renderPartial("schedule-delete", [
"model" => $model
])
];
}
}
}

BIN
db/app.db

Binary file not shown.

View File

@ -20,24 +20,6 @@ class ListManagementGrid {
};
}
public static function layout($default = 20, $hiddenText = false) {
$pageSize = [10, 20, 50, 100];
$options = [];
foreach ($pageSize as $key => $value) {
$selected = "";
if (Yii::$app->request->get("per-page") && Yii::$app->request->get("per-page") == $value)
$selected = "selected";
if (!Yii::$app->request->get("per-page") && $value == $default)
$selected = "selected";
$options[] = "<option value='" . $value . "' {$selected}>" . $value . "</options>";
}
$select = "<select style='width:80px;' onchange='common.changePerPage(this);'>" . implode("", $options) . "</select>";
$text = "";
if (!$hiddenText)
$text = "Hiển thị&nbsp;&nbsp;&nbsp;";
return "{items}<div class='row'><div class='col-md-6'>{summary}</div><div class='col-md-6'><div class='row'><div class='col-md-9 text-right'>{pager}</div><div class='col-md-3'>" . $text . $select . "</div></div></div></div>";
}
public static function getLayout() {
return "{items}<div class='row'><div class='col-md-4'>{summary}</div><div class='col-md-8 text-right'>{pager}</div></div>";
}
@ -104,25 +86,4 @@ class ListManagementGrid {
};
}
public static function schedule() {
return function($model) {
$schedules = $model->schedule;
$html = "<ul style='padding-left:10px;'>";
foreach ($schedules as $key => $value) {
$btnEdit = "<i class='fa fa-edit text-green' onclick='formEditSchedule(this);' data-href='" . Url::to(['/list-management/edit-schedule', 'id' => $value->id]) . "'></i>";
$btnDelete = "<i class='fa fa-remove text-red' onclick='formDeleteSchedule(this);' data-href='" . Url::to(['/list-management/delete-schedule', 'id' => $value->id]) . "'></i>";
$btn = "<span class='btn-schedule'>" . $btnEdit . " " . $btnDelete . "</span>";
$html .= "<li class='schedule-item'>[" . $value->from_time . "-" . $value->to_time . "] " . $value->from_date . " - " . $value->to_date . " [" . $value->date_of_week . "] " . $btn . "</li>";
}
$html .= "</ul>";
return $html;
};
}
public static function check() {
return function($model) {
return "<input type='checkbox' value='' name='' onclick='choose(this);'>";
};
}
}

View File

@ -11,11 +11,9 @@ return [
"CAU_HINH_THIET_BI" => "Device Configuration",
"CAU_HINH_MAY_CHU" => "Server Configuration",
"CAU_HINH_NHAN_DIEN" => "Recognition Configuration",
"CAU_HINH_IP" => "IP Configuration",
"DEVICE_CONFIG" => "",
"SERVER_CONFIG" => "",
"ENGINE_CONFIG" => "",
"IP_CONFIG" => "",
"SERVER_MQTT" => "server_mqtt",
"URL" => "url",
"LUU_LAI" => "Save",
@ -59,7 +57,7 @@ return [
"TIM_KIEM_DU_LIEU" => "Search the data",
"TAT_CA" => "All",
"TIM_KIEM" => "Search",
"XOA_NHIEU_DU_LIEU" => "Choose multiple data",
"XOA_NHIEU_DU_LIEU" => "Delete multiple data",
"CHON_TOAN_BO_TRANG" => "Select all data",
"BO_CHON" => "Unselect",
"XAC_NHAN_XOA" => "Deletion Confirm",
@ -138,27 +136,5 @@ return [
"MAT_KHAU" => "Password",
"RESET_THIET_BI_LOI" => "Error connecting to the server. Please check your internet connection and try again.",
"THU_LAI" => "Try again",
"TEN_DANG_NHAP_HOAC_MAT_KHAU_KHONG_DUNG" => "Incorrect username or password.",
"DOI_TUONG_CHUA_DU_ANH_MAU" => "Object does not have enough images",
"LICH_TRINH" => "Schedule",
"HAY_CHON_DOI_TUONG_DE_GAN_LICH_TRINH" => "Please select the object to assign the schedule",
"GAN_LICH_TRINH" => "Assign schedule",
"THOI_GIAN_VAO" => "Time in",
"THOI_GIAN_RA" => "Time out",
"NGAY_BAT_DAU" => "Start date",
"NGAY_KET_THUC" => "End date",
"NGAY_TRONG_TUAN" => "Day of the week",
"THU_HAI" => "Monday",
"THU_BA" => "Tuesday",
"THU_TU" => "Wednesday",
"THU_NAM" => "Thursday",
"THU_SAU" => "Friday",
"THU_BAY" => "Saturday",
"CHU_NHAT" => "Sunday",
"SUA_LICH_TRINH" => "Edit schedule",
"AP_DUNG_CHO_TAT_CA_DOI_TUONG_DA_CHON" => "Apply to all selected objects",
"XOA_LICH_TRINH" => "Delete schedule",
"BAN_CO_CHAC_CHAN_MUON_XOA_LICH_TRINH_NAY_KHONG" => "Are you sure you want to delete this schedule?",
"SO_SANH_MAT" => "Face comparison",
"BAN_CO_CHAC_CHAN_MUON_DOI_IP_KHONG" => "Are you sure you want to change the device's IP address?"
"TEN_DANG_NHAP_HOAC_MAT_KHAU_KHONG_DUNG" => "Incorrect username or password."
];

View File

@ -11,11 +11,9 @@ return [
"CAU_HINH_THIET_BI" => "デバイス構成",
"CAU_HINH_MAY_CHU" => " サーバ構成",
"CAU_HINH_NHAN_DIEN" => "認識構成",
"CAU_HINH_IP" => "IP 構成",
"DEVICE_CONFIG" => "Device config",
"SERVER_CONFIG" => "Server config",
"ENGINE_CONFIG" => "Engine config",
"IP_CONFIG" => "IP config",
"SERVER_MQTT" => "server_mqtt",
"URL" => "url",
"LUU_LAI" => "保存する",
@ -59,7 +57,7 @@ return [
"TIM_KIEM_DU_LIEU" => "データ検索",
"TAT_CA" => "全部",
"TIM_KIEM" => "検索",
"XOA_NHIEU_DU_LIEU" => "複数のデータを選択",
"XOA_NHIEU_DU_LIEU" => "大量のデータを削除する",
"CHON_TOAN_BO_TRANG" => "ページ全体を選択",
"BO_CHON" => "取り消し",
"XAC_NHAN_XOA" => "削除の確認",
@ -138,27 +136,5 @@ return [
"MAT_KHAU" => "パスワード",
"RESET_THIET_BI_LOI" => "サーバーへの接続中にエラーが発生しました。インターネット接続を確認して、もう一度お試しください",
"THU_LAI" => "再試行",
"TEN_DANG_NHAP_HOAC_MAT_KHAU_KHONG_DUNG" => "ユーザーネームまたはパスワードが違います",
"DOI_TUONG_CHUA_DU_ANH_MAU" => "オブジェクトに十分な画像がありません",
"LICH_TRINH" => "スケジュール",
"HAY_CHON_DOI_TUONG_DE_GAN_LICH_TRINH" => "スケジュールを割り当てるオブジェクトを選択してください",
"GAN_LICH_TRINH" => "スケジュールを割り当てる",
"THOI_GIAN_VAO" => "の時間",
"THOI_GIAN_RA" => "タイムアウト",
"NGAY_BAT_DAU" => "開始日",
"NGAY_KET_THUC" => "終了日",
"NGAY_TRONG_TUAN" => "曜日",
"THU_HAI" => "月曜日",
"THU_BA" => "火曜日",
"THU_TU" => "水曜日",
"THU_NAM" => "木曜日",
"THU_SAU" => "金曜日",
"THU_BAY" => "土曜日",
"CHU_NHAT" => "日曜日",
"SUA_LICH_TRINH" => "スケジュールを編集",
"AP_DUNG_CHO_TAT_CA_DOI_TUONG_DA_CHON" => "選択したすべてのオブジェクトに適用",
"XOA_LICH_TRINH" => "スケジュールを削除",
"BAN_CO_CHAC_CHAN_MUON_XOA_LICH_TRINH_NAY_KHONG" => "このスケジュールを削除してもよろしいですか?",
"SO_SANH_MAT" => "顔比較",
"BAN_CO_CHAC_CHAN_MUON_DOI_IP_KHONG" => "デバイスの IP アドレスを変更してもよろしいですか?"
"TEN_DANG_NHAP_HOAC_MAT_KHAU_KHONG_DUNG" => "ユーザーネームまたはパスワードが違います"
];

View File

@ -11,11 +11,9 @@ return [
"CAU_HINH_THIET_BI" => "Cấu hình thiết bị",
"CAU_HINH_MAY_CHU" => "Cấu hình máy chủ",
"CAU_HINH_NHAN_DIEN" => "Cấu hình nhận diện",
"CAU_HINH_IP" => "Cấu hình IP",
"DEVICE_CONFIG" => "Device config",
"SERVER_CONFIG" => "Server config",
"ENGINE_CONFIG" => "Engine config",
"IP_CONFIG" => "IP config",
"SERVER_MQTT" => "server_mqtt",
"URL" => "url",
"LUU_LAI" => "Lưu lại",
@ -59,7 +57,7 @@ return [
"TIM_KIEM_DU_LIEU" => "Tìm kiếm dữ liệu",
"TAT_CA" => "Tất cả",
"TIM_KIEM" => "Tìm kiếm",
"XOA_NHIEU_DU_LIEU" => "Chọn nhiều dữ liệu",
"XOA_NHIEU_DU_LIEU" => "Xóa nhiều dữ liệu",
"CHON_TOAN_BO_TRANG" => "Chọn toàn bộ trang",
"BO_CHON" => "Bỏ chọn",
"XAC_NHAN_XOA" => "Xác nhận xóa",
@ -138,27 +136,5 @@ return [
"MAT_KHAU" => "Mật khẩu",
"RESET_THIET_BI_LOI" => "Lỗi kết nối đến server. Hãy kiểm tra lại kết nối internet và thử lại.",
"THU_LAI" => "Thử lại",
"TEN_DANG_NHAP_HOAC_MAT_KHAU_KHONG_DUNG" => "Tên đăng nhập hoặc mật khẩu không đúng.",
"DOI_TUONG_CHUA_DU_ANH_MAU" => "Đối tượng chưa đủ ảnh mẫu",
"LICH_TRINH" => "Lịch trình",
"HAY_CHON_DOI_TUONG_DE_GAN_LICH_TRINH" => "Hãy chọn đối tượng để gán lịch trình",
"GAN_LICH_TRINH" => "Gán lịch trình",
"THOI_GIAN_VAO" => "Thời gian vào",
"THOI_GIAN_RA" => "Thời gian ra",
"NGAY_BAT_DAU" => "Ngày bắt đầu",
"NGAY_KET_THUC" => "Ngày kết thúc",
"NGAY_TRONG_TUAN" => "Ngày trong tuần",
"THU_HAI" => "Thứ hai",
"THU_BA" => "Thứ ba",
"THU_TU" => "Thứ tư",
"THU_NAM" => "Thứ năm",
"THU_SAU" => "Thứ sáu",
"THU_BAY" => "Thứ bảy",
"CHU_NHAT" => "Chủ nhật",
"SUA_LICH_TRINH" => "Sửa lịch trình",
"AP_DUNG_CHO_TAT_CA_DOI_TUONG_DA_CHON" => "Áp dụng cho tất cả đối tượng đã chọn",
"XOA_LICH_TRINH" => "Xóa lịch trình",
"BAN_CO_CHAC_CHAN_MUON_XOA_LICH_TRINH_NAY_KHONG" => "Bạn có chắc chắn muốn xóa lịch trình này không?",
"SO_SANH_MAT" => "So sánh mặt",
"BAN_CO_CHAC_CHAN_MUON_DOI_IP_KHONG" => "Bạn có chắc chắn muốn thay đổi địa chỉ IP của thiết bị không?"
"TEN_DANG_NHAP_HOAC_MAT_KHAU_KHONG_DUNG" => "Tên đăng nhập hoặc mật khẩu không đúng."
];

View File

@ -48,7 +48,7 @@ class ListManagement extends \yii\db\ActiveRecord {
'id' => Yii::t("app", "ID"),
'code' => Yii::t("app", "ID"),
'type' => Yii::t("app", "LOAI"),
'name' => Yii::t("app", "TEN_HIEN_THI"),
'name' => Yii::t("app", "TEN"),
'image' => Yii::t("app", "HINH_ANH_DANG_KI"),
'gender' => Yii::t("app", "GIOI_TINH"),
'birthday' => Yii::t("app", "NGAY_SINH"),
@ -56,7 +56,7 @@ class ListManagement extends \yii\db\ActiveRecord {
'address' => Yii::t("app", "DON_VI"),
'time' => Yii::t("app", "THOI_GIAN_DANG_KI"),
'last_modified' => 'Last Modified',
'abbreviated_name' => Yii::t("app", "TEN"),
'abbreviated_name' => Yii::t("app", "TEN_HIEN_THI"),
'staff_id' => Yii::t("app", "ID"),
];
}
@ -110,25 +110,19 @@ class ListManagement extends \yii\db\ActiveRecord {
}
public static function getAllID() {
$idArr = [];
$imgCountArr = [];
$res = [];
$ls = self::find()->all();
foreach ($ls as $key => $value) {
$idArr[] = $value->staff_id;
$images = json_decode($value->image, true);
$imgCountArr[$value->staff_id] = count($images);
$res[] = $value->staff_id;
}
return [
"idArr" => $idArr,
"imgCountArr" => $imgCountArr
];
return $res;
}
public static function staffArray() {
$res = [];
$ls = self::find()->all();
foreach ($ls as $key => $value) {
$res[$value->id] = $value->code . " - " . $value->name;
$res[$value->code] = $value->code . " - " . $value->name;
}
return $res;
}
@ -179,8 +173,4 @@ class ListManagement extends \yii\db\ActiveRecord {
];
}
public function getSchedule() {
return Schedule::find()->andWhere(['staff_id' => $this->id])->all();
}
}

View File

@ -1,80 +0,0 @@
<?php
namespace app\models;
use Yii;
/**
* This is the model class for table "schedule".
*
* @property int $id
* @property string $staff_id
* @property string $from_time
* @property string $to_time
* @property string $from_date
* @property string $to_date
* @property string $date_of_week
* @property int $id_door_calendar
*/
class Schedule extends \yii\db\ActiveRecord {
/**
* {@inheritdoc}
*/
public static function tableName() {
return 'schedule';
}
/**
* {@inheritdoc}
*/
public function rules() {
return [
[['staff_id', 'from_time', 'to_time', 'from_date', 'to_date', 'date_of_week'], 'string'],
[['id_door_calendar'], 'integer'],
];
}
/**
* {@inheritdoc}
*/
public function attributeLabels() {
return [
'id' => 'ID',
'staff_id' => 'Staff ID',
'from_time' => 'From Time',
'to_time' => 'To Time',
'from_date' => 'From Date',
'to_date' => 'To Date',
'date_of_week' => 'Date Of Week',
'id_door_calendar' => 'id_door_calendar'
];
}
public function multiCreate($datas) {
$field = ['staff_id', 'from_time', 'to_time', 'from_date', 'to_date', 'date_of_week'];
static::getDb()->createCommand()->batchInsert($this->tableName(), $field, $datas)->execute();
return;
}
public function create($data) {
$r = $this->load([
'staff_id' => strval($data['staff_id']),
'from_time' => $data['from_time'],
'to_time' => $data['to_time'],
'from_date' => $data['from_date'],
'to_date' => $data['to_date'],
'date_of_week' => $data['date_of_week'],
'id_door_calendar' => $data['id_door_calendar']
], '');
if ($r) {
try {
$this->save();
return $this->id;
} catch (\Exception $ex) {
return false;
}
}
}
}

View File

@ -41,28 +41,26 @@ use yii\widgets\ActiveForm;
<i class="fa fa-cogs"></i> <?php echo Yii::t("app", "CAU_HINH"); ?>
</a>
</li>
<?php if (Yii::$app->params['type'] === "BiFace") { ?>
<li>
<a href="<?php echo yii\helpers\Url::to(['/config/reset']); ?>" onclick="common.resetForm(this);return false;">
<i class="fa fa-refresh"></i> <?php echo Yii::t("app", "RESET_THIET_BI"); ?>
</a>
</li>
<li class="<?php if (Yii::$app->controller->id == "list-management") echo "active"; ?>">
<a href="<?php echo yii\helpers\Url::to(['/list-management']); ?>">
<i class="fa fa-list"></i> <?php echo Yii::t("app", "QUAN_LY_MAU"); ?>
</a>
</li>
<li class="dropdown <?php if (in_array(Yii::$app->controller->id, ['capture-logs', 'control-logs'])) echo "active"; ?>">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" aria-expanded="false">
<i class="fa fa-list-alt"></i> <?php echo Yii::t("app", "LICH_SU_HE_THONG"); ?>
</a>
<ul class="dropdown-menu" role="menu">
<li><a href="<?php echo \yii\helpers\Url::to(['/capture-logs']); ?>"><i class="fa fa-camera"></i> <?php echo Yii::t("app", "LICH_SU_HE_THONG"); ?></a></li>
<li><a href="<?php echo \yii\helpers\Url::to(['/control-logs']); ?>"><i class="fa fa-database"></i> <?php echo Yii::t("app", "DANH_SACH_NHAN_DIEN"); ?></a></li>
<li><a href="<?php echo \yii\helpers\Url::to(['/capture-logs/face-comparison']); ?>"><i class="fa fa-users"></i> <?php echo Yii::t("app", "SO_SANH_MAT"); ?></a></li>
</ul>
</li>
<?php } ?>
<li>
<a href="<?php echo yii\helpers\Url::to(['/config/reset']); ?>" onclick="common.resetForm(this);return false;">
<i class="fa fa-refresh"></i> <?php echo Yii::t("app", "RESET_THIET_BI"); ?>
</a>
</li>
<li class="<?php if (Yii::$app->controller->id == "list-management") echo "active"; ?>">
<a href="<?php echo yii\helpers\Url::to(['/list-management']); ?>">
<i class="fa fa-list"></i> <?php echo Yii::t("app", "QUAN_LY_MAU"); ?>
</a>
</li>
<li class="<?php if (Yii::$app->controller->id == "capture-logs") echo "active"; ?>">
<a href="<?php echo yii\helpers\Url::to(['/capture-logs']); ?>">
<i class="fa fa-camera"></i> <?php echo Yii::t("app", "LICH_SU_HE_THONG"); ?>
</a>
</li>
<li class="<?php if (Yii::$app->controller->id == "control-logs") echo "active"; ?>">
<a href="<?php echo yii\helpers\Url::to(['/control-logs']); ?>">
<i class="fa fa-database"></i> <?php echo Yii::t("app", "DANH_SACH_NHAN_DIEN"); ?>
</a>
</li>
</ul>
</div>
<div class="navbar-custom-menu">
@ -96,12 +94,12 @@ use yii\widgets\ActiveForm;
<li class="dropdown user user-menu">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">
<img src="<?php
if (Yii::$app->user->isGuest) {
echo $directoryAsset . "/img/user2-160x160.jpg";
} else {
echo Yii::$app->user->identity->user_image == null ? $directoryAsset . "/img/user2-160x160.jpg" : Yii::getAlias("@images_folder") . Yii::$app->user->identity->user_image;
}
?>" class="user-image user-avatar" alt="User Image"/>
if (Yii::$app->user->isGuest) {
echo $directoryAsset . "/img/user2-160x160.jpg";
} else {
echo Yii::$app->user->identity->user_image == null ? $directoryAsset . "/img/user2-160x160.jpg" : Yii::getAlias("@images_folder") . Yii::$app->user->identity->user_image;
}
?>" class="user-image user-avatar" alt="User Image"/>
<span class="hidden-xs user-profiles-name">
<?php
if (Yii::$app->user->isGuest) {
@ -118,12 +116,12 @@ use yii\widgets\ActiveForm;
<div class="user-panel">
<div class="pull-left image">
<img src="<?php
if (Yii::$app->user->isGuest) {
echo $directoryAsset . "/img/user2-160x160.jpg";
} else {
echo Yii::$app->user->identity->user_image == null ? $directoryAsset . "/img/user2-160x160.jpg" : Yii::getAlias("@images_folder") . Yii::$app->user->identity->user_image;
}
?>" class="img-circle user-avatar">
if (Yii::$app->user->isGuest) {
echo $directoryAsset . "/img/user2-160x160.jpg";
} else {
echo Yii::$app->user->identity->user_image == null ? $directoryAsset . "/img/user2-160x160.jpg" : Yii::getAlias("@images_folder") . Yii::$app->user->identity->user_image;
}
?>" class="img-circle user-avatar">
</div>
<div class="pull-left info">
<p style="color: #fff;" class="user-profiles-name"><?= Yii::$app->user->isGuest ? "" : \Yii::$app->user->identity->first_name; ?></p>

View File

@ -1,27 +0,0 @@
{extends file=$smarty.current_dir|cat:'/../extends.tpl'}
{use class="yii\helpers\Url"}
{use class="app\assets\FaceComparisonAsset"}
{FaceComparisonAsset::register($this)|void}
{block name='content'}<br>
<input type="hidden" name="url_upload_face" value="{Url::to(['/capture-logs/upload-face'])}">
<input type="hidden" name="url_face_comparison" value="{Url::to(['/capture-logs/face-comparison'])}">
<div class="row">
<div class="col-md-3 col-md-push-2 text-center">
<img src="/images/user2-160x160.jpg" class="img-thumbnail" id="face1" style="width: 70%;cursor: pointer;" onclick="$('#image1').trigger('click');">
<div class="hidden">
<input type="file" name="image1" id="image1">
</div>
</div>
<div class="col-md-2 col-md-push-2 text-center">
<div style="padding-top: 100px;">
<b class="text-red" style="font-size: 40px;" id="percent">0.00%</b>
</div>
</div>
<div class="col-md-3 col-md-push-2 text-center">
<img src="/images/user2-160x160.jpg" class="img-thumbnail" id="face2" style="width: 70%;cursor: pointer;" onclick="$('#image2').trigger('click');">
<div class="hidden">
<input type="file" name="image2" id="image2">
</div>
</div>
</div>
{/block}

View File

@ -98,7 +98,7 @@
<div class="col-md-4 text-center">
<img src="" class="img-thumbnail" id="FaceImage" style="width: 150px;height: 150px;">
<div class='feature-img'>
<img src="/images/user2-160x160.jpg" class="img-thumbnail" id="closest-img" style="width: 100px;height:100px;">
<img src="" class="img-thumbnail" id="closest-img" style="width: 100px;height:100px;">
<br>
<i id="closest-name"></i>
</div>

View File

@ -142,8 +142,32 @@
<div class="container-fluid">
<br>
<div class="row">
<div class="col-md-10">
{$menu}
<div class="col-md-8">
<div class="mt-element-step">
<div class="row step-thin">
<div class="col-md-4 bg-grey mt-step-col">
<div class="mt-step-number bg-white font-grey">1</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-thiet-bi'])}';">
{Yii::t("app", "CAU_HINH_THIET_BI")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "DEVICE_CONFIG")}</div>
</div>
<div class="col-md-4 bg-grey mt-step-col">
<div class="mt-step-number bg-white font-grey">2</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config'])}';">
{Yii::t("app", "CAU_HINH_MAY_CHU")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "SERVER_CONFIG")}</div>
</div>
<div class="col-md-4 bg-grey mt-step-col active">
<div class="mt-step-number bg-white font-grey">3</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-nhan-dien'])}';">
{Yii::t("app", "CAU_HINH_NHAN_DIEN")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "ENGINE_CONFIG")}</div>
</div>
</div>
</div>
</div>
</div>
<br>

View File

@ -16,8 +16,32 @@
<div class="container-fluid">
<br>
<div class="row">
<div class="col-md-10">
{$menu}
<div class="col-md-8">
<div class="mt-element-step">
<div class="row step-thin">
<div class="col-md-4 bg-grey mt-step-col active">
<div class="mt-step-number bg-white font-grey">1</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-thiet-bi'])}';">
{Yii::t("app", "CAU_HINH_THIET_BI")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "DEVICE_CONFIG")}</div>
</div>
<div class="col-md-4 bg-grey mt-step-col">
<div class="mt-step-number bg-white font-grey">2</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config'])}';">
{Yii::t("app", "CAU_HINH_MAY_CHU")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "SERVER_CONFIG")}</div>
</div>
<div class="col-md-4 bg-grey mt-step-col">
<div class="mt-step-number bg-white font-grey">3</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-nhan-dien'])}';">
{Yii::t("app", "CAU_HINH_NHAN_DIEN")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "ENGINE_CONFIG")}</div>
</div>
</div>
</div>
</div>
</div>
<br>

View File

@ -16,8 +16,32 @@
<div class="container-fluid">
<br>
<div class="row">
<div class="col-md-10">
{$menu}
<div class="col-md-8">
<div class="mt-element-step">
<div class="row step-thin">
<div class="col-md-4 bg-grey mt-step-col">
<div class="mt-step-number bg-white font-grey">1</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-thiet-bi'])}';">
{Yii::t("app", "CAU_HINH_THIET_BI")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "DEVICE_CONFIG")}</div>
</div>
<div class="col-md-4 bg-grey mt-step-col active">
<div class="mt-step-number bg-white font-grey">2</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config'])}';">
{Yii::t("app", "CAU_HINH_MAY_CHU")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "SERVER_CONFIG")}</div>
</div>
<div class="col-md-4 bg-grey mt-step-col">
<div class="mt-step-number bg-white font-grey">3</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-nhan-dien'])}';">
{Yii::t("app", "CAU_HINH_NHAN_DIEN")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "ENGINE_CONFIG")}</div>
</div>
</div>
</div>
</div>
</div>
<br>

View File

@ -1,68 +0,0 @@
{extends file=$smarty.current_dir|cat:'/../extends.tpl'}
{use class="yii\helpers\Url"}
{use class="yii\grid\GridView"}
{use class="app\assets\ConfigAsset"}
{ConfigAsset::register($this)|void}
{block name='content'}
<style>
.input-group-addon{
width: 120px;
font-weight: bold;
}
.input-group{
width: 100%;
}
</style>
<div class="container-fluid">
<br>
<div class="row">
<div class="col-md-10">
{$menu}
</div>
</div>
<br>
<div class="row">
<div class="col-md-3">
<div class="form-group" id="dhcp">
<input type='checkbox' name='dhcp' id='dhcp_check' value="" {if $network.dhcp=="yes"}checked=""{/if}> DHCP
</div>
<div class="form-group" id="device_ip">
<div class="input-group">
<div class="input-group-addon">{Yii::t("app", "IP Address")}</div>
<input type="input" class="form-control" name="device_ip" value="{$network.ip_address|default:""}">
</div>
</div>
<div class="form-group" id="subnet_mask">
<div class="input-group">
<div class="input-group-addon">{Yii::t("app", "Subnet Mask")}</div>
<input type="input" class="form-control" name="subnet_mask" value="{$network.subnet_mask|default:""}">
</div>
</div>
<div class="form-group" id="gateway">
<div class="input-group">
<div class="input-group-addon">{Yii::t("app", "Gateway")}</div>
<input type="input" class="form-control" name="gateway" value="{$network.gateway|default:""}">
</div>
</div>
<div class="form-group" id="dns1">
<div class="input-group">
<div class="input-group-addon">{Yii::t("app", "DNS1")}</div>
<input type="input" class="form-control" name="dns1" value="{$network.dns1|default:""}">
</div>
</div>
<div class="form-group" id="dns2">
<div class="input-group">
<div class="input-group-addon">{Yii::t("app", "DNS2")}</div>
<input type="input" class="form-control" name="dns2" value="{$network.dns2|default:""}">
</div>
</div>
<div class="text-center">
<button class="btn btn-primary" onclick="changeIP(this);" data-href="{Url::to(['/config/cau-hinh-ip'])}">
<i class="fa fa-floppy-o"></i> {Yii::t("app", "LUU_LAI")}
</button>
</div>
</div>
</div>
</div>
</div>
{/block}

View File

@ -1,35 +0,0 @@
{use class="yii\helpers\Url"}
{if Yii::$app->params["type"]==="BiFace"}
<div class="mt-element-step">
<div class="row step-thin">
<div class="col-md-3 bg-grey mt-step-col {if $tab=="device_config"}active{/if}">
<div class="mt-step-number bg-white font-grey">1</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-thiet-bi'])}';">
{Yii::t("app", "CAU_HINH_THIET_BI")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "DEVICE_CONFIG")}</div>
</div>
<div class="col-md-3 bg-grey mt-step-col {if $tab=="server_config"}active{/if}">
<div class="mt-step-number bg-white font-grey">2</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config'])}';">
{Yii::t("app", "CAU_HINH_MAY_CHU")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "SERVER_CONFIG")}</div>
</div>
<div class="col-md-3 bg-grey mt-step-col {if $tab=="engine_config"}active{/if}">
<div class="mt-step-number bg-white font-grey">3</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-nhan-dien'])}';">
{Yii::t("app", "CAU_HINH_NHAN_DIEN")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "ENGINE_CONFIG")}</div>
</div>
<div class="col-md-3 bg-grey mt-step-col {if $tab=="ip_config"}active{/if}">
<div class="mt-step-number bg-white font-grey">4</div>
<div class="mt-step-title uppercase font-grey-cascade" style="cursor: pointer;" onclick="window.location = '{Url::to(['/config/cau-hinh-ip'])}';">
{Yii::t("app", "CAU_HINH_IP")}
</div>
<div class="mt-step-content font-grey-cascade">{Yii::t("app", "IP_CONFIG")}</div>
</div>
</div>
</div>
{/if}

View File

@ -2,9 +2,9 @@
<i class="fa fa-info-circle"></i> {Yii::t("app", "RESET_THIET_BI_LOI")}
</div>
<div class="text-left">
<input type="checkbox" name="DeleteDatabase" style="width: inherit;"> {Yii::t("app", "XOA_DU_LIEU_LUU_TRU_TRONG_THIET_BI")}
<input type="checkbox" name="DeleteDatabase" checked="" style="width: inherit;"> {Yii::t("app", "XOA_DU_LIEU_LUU_TRU_TRONG_THIET_BI")}
<br>
<input type="checkbox" name="ResetDevice" style="width: inherit;"> {Yii::t("app", "RESET_CAU_HINH_THIET_BI")}
<input type="checkbox" name="ResetDevice" checked="" style="width: inherit;"> {Yii::t("app", "RESET_CAU_HINH_THIET_BI")}
</div>
<div class="text-center">
<button class="btn btn-danger" onclick="common.reset(this);" data-href="{yii\helpers\Url::to(['/config/reset'])}" id="reset-accept">

View File

@ -30,9 +30,6 @@
<input type="hidden" name="DA_THEM_HINH_ANH_MAU" value="{Yii::t("app", "DA_THEM_HINH_ANH_MAU")}">
<input type="hidden" name="CO_LOI_XAY_RA_HAY_THU_LAI" value="{Yii::t("app", "CO_LOI_XAY_RA_HAY_THU_LAI")}">
<input type="hidden" name="ENGINE_KHONG_HOAT_DONG" value="{Yii::t("app", "ENGINE_KHONG_HOAT_DONG")}">
<input type="hidden" name="HAY_CHON_DOI_TUONG_DE_GAN_LICH_TRINH" value="{Yii::t("app", "HAY_CHON_DOI_TUONG_DE_GAN_LICH_TRINH")}">
<input type="hidden" name="BAN_CO_CHAC_CHAN_MUON_XOA_LICH_TRINH_NAY_KHONG" value="{Yii::t("app", "BAN_CO_CHAC_CHAN_MUON_XOA_LICH_TRINH_NAY_KHONG")}">
<input type="hidden" name="BAN_CO_CHAC_CHAN_MUON_DOI_IP_KHONG" value="{Yii::t("app", "BAN_CO_CHAC_CHAN_MUON_DOI_IP_KHONG")}">
<div id="blocking" class="fade modal" role="dialog" tabindex="-1">
<div class="modal-dialog" style="top: 50%;margin-top: -45px;">

View File

@ -8,9 +8,9 @@
.row{
margin-bottom: 5px;
}
{*input{
width: 100%;
}*}
input{
width: 100%;
}
.table-striped > tbody > tr:nth-of-type(odd){
background-color: rgb(210, 210, 210);
}
@ -21,21 +21,13 @@
.feature-img:hover .btn{
visibility: visible !important;
}
.btn-schedule{
visibility: hidden;
}
.schedule-item:hover .btn-schedule{
visibility: visible !important;
}
.table > tbody > tr.delete-choose > td{
background-color: #F7D3D2;
background-color: red;
color: #fff;
}
#filters-face .select2-container {
.select2-container {
width: 100% !important;
}
.pagination {
margin: 0;
}
#form-add-staff .select2-container--default .select2-selection--single, .select2-selection .select2-selection--single{
border-color: green;
}
@ -51,10 +43,10 @@
<input type="hidden" value="{Url::to(["/list-management/update-feature"])}" name="update_feature_url">
<input type="hidden" value="{Url::to(["/api/get-total-feature"])}" name="get_total_feature_url">
<div class="row">
<div class="col-md-10" id="list-face" style="max-height: 850px;overflow-y: auto;">
<div class="col-md-10" style="max-height: 850px;overflow-y: auto;">
{GridView::widget([
'dataProvider' => $dataProvider,
'layout'=> \app\helpers\ListManagementGrid::layout(20),
'layout'=> \app\helpers\ListManagementGrid::getLayout(),
'tableOptions' => [
'class' => 'table table-striped table-bordered',
'style' => 'background:#fff;min-width:700px;'
@ -66,12 +58,6 @@
'contentOptions' => ['class' => 'text-center'],
'headerOptions' => ['class' => 'text-center']
],
[
'contentOptions' => ['class' => 'text-center hidden checkbox-column'],
'headerOptions' => ['style' => 'width:3%', 'class' => 'hidden checkbox-column'],
'format' => "raw",
'value' => \app\helpers\ListManagementGrid::check()
],
[
'attribute' => 'type',
'contentOptions' => ['class' => 'text-center'],
@ -98,10 +84,10 @@
'value' => \app\helpers\ListManagementGrid::image()
],
[
'label' => Yii::t("app", "LICH_TRINH"),
'attribute' => 'time',
'contentOptions' => ['class' => 'text-center'],
'headerOptions' => ['class' => 'text-center'],
'format' => "raw",
'value' => \app\helpers\ListManagementGrid::schedule()
'value' => \app\helpers\ListManagementGrid::time()
],
[
'attribute' => 'telephone',
@ -172,7 +158,6 @@
<br>
<div class="text-center">
<button class="btn btn-danger" onclick="batchDelete(this);" data-href="{Url::to(['/list-management/batch-delete'])}">{Yii::t("app", "XAC_NHAN_XOA")}</button>
<button class="btn btn-success" onclick="scheduleForm(this);" data-href="{Url::to(['/list-management/schedule'])}">{Yii::t("app", "LICH_TRINH")}</button>
</div>
</div>
</div>

View File

@ -1,4 +1,4 @@
<div class="row" id="filters-face">
<div class="row">
<div class="col-md-4">
<div class="form-group">
<div class="input-group">
@ -15,35 +15,22 @@
</div>
</div>
</div>
<div class="col-md-8 text-right">
<button class="btn btn-default btn-select" id="btnCheckLossImage" onclick="filtersLossImage(this);">
{Yii::t("app", "DOI_TUONG_CHUA_DU_ANH_MAU")}
</button>
</div>
</div>
<div style="max-height: 750px;overflow-y: auto;">
<table class="table table-bordered table-striped">
<thead>
<tr>
<th>{Yii::t("app", "ID")}</th>
<th>{Yii::t("app", "TEN_HIEN_THI")}</th>
<th>{Yii::t("app", "TEN")}</th>
<th>{Yii::t("app", "TEN_HIEN_THI")}</th>
<th>{Yii::t("app", "DON_VI")}</th>
<th>{Yii::t("app", "HINH_ANH_DANG_KI")}</th>
<th>{Yii::t("app", "COMPANY_ID")}</th>
</tr>
</thead>
<tbody id="sync-lists">
{$totalDevice=0}
{$totalCloud=0}
{foreach from=$datas item=arr}
{$totalImg=0}
{if isset($personImage[$arr.id])}
{$totalImg=$personImage[$arr.id]}
{/if}
{$totalDevice=$totalDevice+$totalImg}
{$totalCloud=$totalCloud+count($arr.images)}
<tr id="filters-{$arr.id}" onclick="choooseToSync(this);" style="cursor: pointer;" class="filters {if $totalImg!==count($arr.images)}loss-image{/if} {if !in_array($arr.id,$allID)}not-in-list{/if}" data-stt="false" data-id="{trim($arr.id)}">
<tr id="filters-{$arr.id}" onclick="choooseToSync(this);" style="cursor: pointer;" class="filters {if !in_array($arr.id,$allID)}not-in-list{/if}" data-stt="false" data-id="{trim($arr.id)}">
<td>
<div id="full-data-{trim($arr.id)}" class="hidden">{json_encode($arr)}</div>
{$arr.code}
@ -51,11 +38,7 @@
<i class="fa fa-check-circle text-green"></i>
{/if}
</td>
<td>
<b class="text-green">[{$totalImg}]</b>
<b class="text-red">[{count($arr.images)}]</b>
{$arr.name}
</td>
<td>{$arr.name}</td>
<td>{$arr.abbreviated_name}</td>
<td>{$arr.department}</td>
<td>
@ -73,8 +56,6 @@
</tbody>
</table>
</div>
<b class="text-green" id="totalDevice">[{$totalDevice}]</b>
<b class="text-red" id="totalCloud">[{$totalCloud}]</b>
<br>
<div class="row">
<div class="col-md-2">

View File

@ -1,4 +1,4 @@
<div class="row" id="filters-face">
<div class="row">
<div class="col-md-4">
<div class="form-group">
<div class="input-group">
@ -21,8 +21,8 @@
<thead>
<tr>
<th>{Yii::t("app", "ID")}<</th>
<th>{Yii::t("app", "TEN_HIEN_THI")}</th>
<th>{Yii::t("app", "TEN")}<</th>
<th>{Yii::t("app", "TEN_HIEN_THI")}</th>
<th>{Yii::t("app", "GIOI_TINH")}</th>
<th>{Yii::t("app", "HINH_ANH_DANG_KI")}</th>
<th>{Yii::t("app", "NGAY_SINH")}</th>

View File

@ -1,4 +1,4 @@
<div class="row" id="filters-face">
<div class="row">
<div class="col-md-4">
<div class="form-group">
<div class="input-group">

View File

@ -1,71 +0,0 @@
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label class="control-label">{Yii::t("app", "THOI_GIAN_VAO")}</label>
<input type="text" value="{$model->from_time|default:"00:00"}" class="form-control" id="fromTime" disabled="" name="FromTime">
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label class="control-label">{Yii::t("app", "THOI_GIAN_RA")}</label>
<input type="text" value="{$model->to_time|default:"23:59"}" class="form-control" id="toTime" disabled=" name="ToTime">
</div>
</div>
</div>
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label class="control-label">{Yii::t("app", "NGAY_BAT_DAU")}</label>
<input type="text" value="{$model->from_date|default:date("d/m/Y")}" class="form-control" disabled=" id="fromDate" name="FromDate">
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label class="control-label">{Yii::t("app", "NGAY_KET_THUC")}</label>
<input type="text" value="{$model->to_date|default:date("d/m/Y")}" class="form-control" disabled=" id="toDate" name="ToDate">
</div>
</div>
</div>
<div class="row">
<div class="col-md-12">
<div class="form-group">
<label class="control-label">{Yii::t("app", "NGAY_TRONG_TUAN")}</label>
{$dateOfWeek=["1","2","3","4","5","6","7","8"]}
{$dateOfWeek=explode(",",$model->date_of_week)}
<div class="row">
<div class="col-md-3">
{if in_array("2",$dateOfWeek)}<i class="fa fa-check text-green"></i>{else}<i class="fa fa-remove text-red"></i>{/if} {Yii::t("app", "THU_HAI")}
</div>
<div class="col-md-3">
{if in_array("3",$dateOfWeek)}<i class="fa fa-check text-green"></i>{else}<i class="fa fa-remove text-red"></i>{/if} {Yii::t("app", "THU_BA")}
</div>
<div class="col-md-3">
{if in_array("4",$dateOfWeek)}<i class="fa fa-check text-green"></i>{else}<i class="fa fa-remove text-red"></i>{/if} {Yii::t("app", "THU_TU")}
</div>
<div class="col-md-3">
{if in_array("5",$dateOfWeek)}<i class="fa fa-check text-green"></i>{else}<i class="fa fa-remove text-red"></i>{/if} {Yii::t("app", "THU_NAM")}
</div>
<div class="col-md-3">
{if in_array("6",$dateOfWeek)}<i class="fa fa-check text-green"></i>{else}<i class="fa fa-remove text-red"></i>{/if} {Yii::t("app", "THU_SAU")}
</div>
<div class="col-md-3">
{if in_array("7",$dateOfWeek)}<i class="fa fa-check text-green"></i>{else}<i class="fa fa-remove text-red"></i>{/if} {Yii::t("app", "THU_BAY")}
</div>
<div class="col-md-3">
{if in_array("8",$dateOfWeek)}<i class="fa fa-check text-green"></i>{else}<i class="fa fa-remove text-red"></i>{/if} {Yii::t("app", "CHU_NHAT")}
</div>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-md-6">
<input type='checkbox' value='1' name='editAll' checked=""> {Yii::t("app","AP_DUNG_CHO_TAT_CA_DOI_TUONG_DA_CHON")}
</div>
<div class="col-md-6 text-right">
<button class="btn btn-danger" onclick="deleteSchedule(this);" data-href="{yii\helpers\Url::to(["/list-management/delete-schedule","id"=>$model->id])}">
<i class="fa fa-remove"></i> {Yii::t("app","XOA_LICH_TRINH")}
</button>
<button type="button" class="btn btn-default" data-dismiss="modal"><span class="fa fa-remove"></span> {Yii::t("app", "DONG_LAI")}</button>
</div>
</div>

View File

@ -1,80 +0,0 @@
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label class="control-label">{Yii::t("app", "THOI_GIAN_VAO")}</label>
<input type="text" value="{$model->from_time|default:"00:00"}" class="form-control" id="fromTime" name="FromTime">
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label class="control-label">{Yii::t("app", "THOI_GIAN_RA")}</label>
<input type="text" value="{$model->to_time|default:"23:59"}" class="form-control" id="toTime" name="ToTime">
</div>
</div>
</div>
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label class="control-label">{Yii::t("app", "NGAY_BAT_DAU")}</label>
<input type="text" value="{$model->from_date|default:date("d/m/Y")}" class="form-control" id="fromDate" name="FromDate">
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label class="control-label">{Yii::t("app", "NGAY_KET_THUC")}</label>
<input type="text" value="{$model->to_date|default:date("d/m/Y")}" class="form-control" id="toDate" name="ToDate">
</div>
</div>
</div>
<div class="row">
<div class="col-md-12">
<div class="form-group">
<label class="control-label">{Yii::t("app", "NGAY_TRONG_TUAN")}</label>
{$dateOfWeek=["1","2","3","4","5","6","7","8"]}
{if $type=="edit"}
{$dateOfWeek=explode(",",$model->date_of_week)}
{/if}
<div class="row">
<div class="col-md-3">
<input type='checkbox' value='2' name="checkbox-date" {if in_array("2",$dateOfWeek)}checked=""{/if}> {Yii::t("app", "THU_HAI")}
</div>
<div class="col-md-3">
<input type='checkbox' value='3' name="checkbox-date" {if in_array("3",$dateOfWeek)}checked=""{/if}> {Yii::t("app", "THU_BA")}
</div>
<div class="col-md-3">
<input type='checkbox' value='4' name="checkbox-date" {if in_array("4",$dateOfWeek)}checked=""{/if}> {Yii::t("app", "THU_TU")}
</div>
<div class="col-md-3">
<input type='checkbox' value='5' name="checkbox-date" {if in_array("5",$dateOfWeek)}checked=""{/if}> {Yii::t("app", "THU_NAM")}
</div>
<div class="col-md-3">
<input type='checkbox' value='6' name="checkbox-date" {if in_array("6",$dateOfWeek)}checked=""{/if}> {Yii::t("app", "THU_SAU")}
</div>
<div class="col-md-3">
<input type='checkbox' value='7' name="checkbox-date" {if in_array("7",$dateOfWeek)}checked=""{/if}> {Yii::t("app", "THU_BAY")}
</div>
<div class="col-md-3">
<input type='checkbox' value='8' name="checkbox-date" {if in_array("8",$dateOfWeek)}checked=""{/if}> {Yii::t("app", "CHU_NHAT")}
</div>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-md-6">
{if $type=="edit"}
<input type='checkbox' value='1' name='editAll' checked=""> {Yii::t("app","AP_DUNG_CHO_TAT_CA_DOI_TUONG_DA_CHON")}
{/if}
</div>
<div class="col-md-6 text-right">
{if $type=="edit"}
<button class="btn btn-primary" onclick="editSchedule(this);" data-href="{yii\helpers\Url::to(["/list-management/edit-schedule",'id'=>$model->id])}">
<i class="fa fa-floppy-o"></i> {Yii::t("app","LUU_LAI")}
</button>
{else}
<button class="btn btn-primary" onclick="addSchedule(this);" data-href="{yii\helpers\Url::to(["/list-management/schedule"])}">
<i class="fa fa-floppy-o"></i> {Yii::t("app","LUU_LAI")}
</button>
{/if}
</div>
</div>

View File

@ -24,7 +24,7 @@ function _form(e) {
$("input[name='CaptureLogsID']").val($(e).attr("data-id"));
$("#FaceImage").attr("src", $(e).attr("data-img"));
var confidence = JSON.parse($(e).attr("data-confidence"));
$("#closest-img").attr("src", confidence.img != "" ? confidence.img : "/images/user2-160x160.jpg");
$("#closest-img").attr("src", confidence.img);
$("#closest-name").html(confidence.name + " [" + confidence.score + "]");
}

View File

@ -49,7 +49,6 @@ $(document).on('focusin', function (e) {
/**
* Các hàm sử dụng chung
*/
$('select').select2();
var common = {};
common.csrf = $('meta[name="csrf-token"]').attr("content");
common.csrfParam = $('meta[name="csrf-param"]').attr("content");
@ -361,26 +360,7 @@ common.changeLanguage = function (e) {
error: function (jqXHR, textStatus, errorThrown) {
}
});
};
common.changePerPage = function (e) {
if (window.location.search !== "") {
var perPage = common.getUrlParameter("per-page");
if (perPage) {
var sPageURL = decodeURIComponent(window.location.search.substring(1));
var sURLVariables = sPageURL.split('&');
var newUrl = [];
for (var i = 0; i < sURLVariables.length; i++) {
var temp = sURLVariables[i].split('=');
if (temp[0] !== "per-page")
newUrl.push(sURLVariables[i]);
}
newUrl.push("per-page=" + $(e).val());
window.location = window.location.origin + window.location.pathname + "?" + newUrl.join("&");
} else
window.location = window.location + "&per-page=" + $(e).val();
} else
window.location = window.location + "?per-page=" + $(e).val();
};
}
/**
* =========================
*/

View File

@ -115,66 +115,4 @@ function SaveConfigDevice(e) {
common.ajaxError();
}
});
}
function ValidateIPaddress(ipaddress) {
if (/^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/.test(ipaddress))
return true;
return false;
}
function validData(inputName) {
var ip = $("input[name='" + inputName + "']").val();
if (ip == "" && document.getElementById('dhcp_check').checked)
return true;
if (!ValidateIPaddress(ip)) {
common.error(inputName, "");
return false;
} else {
common.success(inputName);
return true;
}
}
function validDNS(inputName) {
var dns = $("input[name='" + inputName + "']").val();
if (dns == "")
return true;
return validData(inputName);
}
function changeIP(e) {
var valid = validData("device_ip");
valid = validData("subnet_mask");
valid = validData("gateway");
valid = validDNS("dns1");
valid = validDNS("dns2");
if (!valid)
return;
if (confirm($("input[name='BAN_CO_CHAC_CHAN_MUON_DOI_IP_KHONG']").val())) {
common.modalBlock(true);
$.ajax({
url: $(e).attr("data-href"),
type: 'POST',
data: {
device_ip: $("input[name='device_ip']").val(),
subnet_mask: $("input[name='subnet_mask']").val(),
gateway: $("input[name='gateway']").val(),
dns1: $("input[name='dns1']").val(),
dns2: $("input[name='dns2']").val(),
dhcp: document.getElementById('dhcp_check').checked
},
success: function (data) {
common.modalBlock(false);
if (!data.status)
common.error("subnet_mask", "");
else
window.location = data.url;
},
error: function (jqXHR, textStatus, errorThrown) {
common.modalBlock(false);
common.ajaxError();
}
});
}
}

View File

@ -1,53 +0,0 @@
$(function () {
btnFace("1");
btnFace("2");
});
function btnFace(imageIndex) {
var fData = {
UploadImage: true,
imageIndex: imageIndex
};
fData[common.csrfParam] = common.csrf;
new afuButton({
uploadURI: $("input[name='url_upload_face']").val(),
formData: fData,
wrap: {
tagName: 'div',
classes: ''
},
fileExtension: '.png,.jpg,.jpeg,.gif',
fileSizeLimit: 1,
classes: 'btn btn-default',
fakeInputContent: '<span class=\'fa fa-file-image-o\'></span> Chọn hình ảnh',
onUploaded: function (data) {
$("#face" + imageIndex).attr("src", "/data/uploads" + data);
common.uploadBlock(false);
compareFace();
}
}).addInstance('image' + imageIndex);
}
function compareFace() {
var face1 = $("#face1").attr("src");
var face2 = $("#face2").attr("src");
if (face1 == "/images/user2-160x160.jpg" || face2 == "/images/user2-160x160.jpg")
return;
common.modalBlock(true);
$.ajax({
url: $("input[name='url_face_comparison']").val(),
type: 'POST',
data: {
face1: face1,
face2: face2
},
success: function (data) {
common.modalBlock(false);
$("#percent").html(data.type1 + "%<br>[" + data.type2 + "%]");
},
error: function (jqXHR, textStatus, errorThrown) {
common.modalBlock(false);
common.ajaxError();
}
});
}

View File

@ -1,5 +1,4 @@
var x = 0, y = 0;
var multiChoose = false;
$(function () {
common.dateTimePickerByClass("datepicker", "HH:mm DD/MM/YYYY");
common.dateTimePickerDay("birthday");
@ -10,13 +9,9 @@ $(function () {
$("input[name='BatchDelete']").change(function () {
if (this.checked) {
$("#delete-btn-group").removeClass("hidden");
multiChoose = true;
$(".checkbox-column").removeClass("hidden");
} else {
$("tr").removeClass("delete-choose");
$("#delete-btn-group").addClass("hidden");
multiChoose = false;
$(".checkbox-column").addClass("hidden");
}
});
btnImage();
@ -186,22 +181,10 @@ function _deleteFeature(e) {
}
function checkAll(status) {
if (status) {
$("#list-face").find("tr").addClass("delete-choose");
$(".checkbox-column").find("input").prop('checked', true);
} else {
$("#list-face").find("tr").removeClass("delete-choose");
$(".checkbox-column").find("input").prop('checked', false);
}
}
function choose(e) {
if (!multiChoose)
return false;
if ($(e).closest("tr").hasClass("delete-choose"))
$(e).closest("tr").removeClass("delete-choose");
if (status)
$("tr").addClass("delete-choose");
else
$(e).closest("tr").addClass("delete-choose");
$("tr").removeClass("delete-choose");
}
function batchDelete(e) {
@ -378,8 +361,6 @@ function checkAllSync(stt) {
}
function checkAllNotInList() {
$(".filters").addClass("hidden");
$(".not-in-list").removeClass("hidden");
$("#sync-lists").find("tr").removeClass("success").attr("data-stt", "false");
$(".not-in-list").addClass("success").attr("data-stt", "true");
$("#totals-choose").html($(".not-in-list").length);
@ -450,8 +431,6 @@ function _syncFromServerForm(e) {
$("#filter-from-server").select2({
placeholder: $("input[name='TIM_KIEM_THEO_ID_HOAC_TEN']").val()
});
if ($("#totalDevice").html() === $("#totalCloud").html())
$("#btnCheckLossImage").addClass("hidden");
},
error: function (jqXHR, textStatus, errorThrown) {
common.modalBlock(false);
@ -670,182 +649,4 @@ function reGenFeature(e) {
error: function (jqXHR, textStatus, errorThrown) {
}
});
}
function filtersLossImage(e) {
if ($(e).hasClass("btn-danger")) {
$(e).addClass("btn-default").removeClass("btn-danger");
$(".filters").removeClass("hidden");
$("#sync-lists").find("tr").removeClass("success").attr("data-stt", "false");
$("#totals-choose").html("0");
} else {
$(e).removeClass("btn-default").addClass("btn-danger");
$(".filters").addClass("hidden");
$(".loss-image").removeClass("hidden");
$("#sync-lists").find("tr").removeClass("success").attr("data-stt", "false");
$(".loss-image").addClass("success").attr("data-stt", "true");
$("#totals-choose").html($(".loss-image").length);
}
}
function scheduleForm(e) {
var check = $(".delete-choose");
if (check.length == 0) {
alert($("input[name='HAY_CHON_DOI_TUONG_DE_GAN_LICH_TRINH']").val());
return;
}
common.modalBlock(true);
$.ajax({
url: $(e).attr("data-href"),
type: 'POST',
success: function (data) {
common.modalBlock(false);
common.modalOpen(data.form, false, data.title);
common.dateTimePickerDay("fromDate");
common.dateTimePickerDay("toDate");
common.dateTimePickerHour("fromTime");
common.dateTimePickerHour("toTime");
},
error: function (jqXHR, textStatus, errorThrown) {
common.modalBlock(false);
common.ajaxError();
}
});
}
function addSchedule(e) {
var lists = [];
$.each($(".delete-choose"), function () {
if ($(this).attr("data-id") !== "")
lists.push($(this).attr("data-id"));
});
if (lists.length == 0) {
alert($("input[name='HAY_CHON_DOI_TUONG_DE_GAN_LICH_TRINH']").val());
return;
}
var dateOfWeek = [];
$.each($("input[name='checkbox-date']:checked"), function () {
dateOfWeek.push($(this).val());
});
common.modalBlock(true);
$.ajax({
url: $(e).attr("data-href"),
type: 'POST',
data: {
fromTime: $("input[name='FromTime']").val(),
toTime: $("input[name='ToTime']").val(),
fromDate: $("input[name='FromDate']").val(),
toDate: $("input[name='ToDate']").val(),
dateOfWeek: dateOfWeek,
lists: lists
},
success: function (data) {
common.modalBlock(false);
window.location.reload(true);
},
error: function (jqXHR, textStatus, errorThrown) {
console.log(errorThrown);
common.modalBlock(false);
common.ajaxError();
}
});
}
function formEditSchedule(e) {
common.modalBlock(true);
$.ajax({
url: $(e).attr("data-href"),
type: 'POST',
success: function (data) {
common.modalBlock(false);
common.modalOpen(data.form, false, data.title);
common.dateTimePickerDay("fromDate");
common.dateTimePickerDay("toDate");
common.dateTimePickerHour("fromTime");
common.dateTimePickerHour("toTime");
},
error: function (jqXHR, textStatus, errorThrown) {
common.modalBlock(false);
common.ajaxError();
}
});
}
function editSchedule(e) {
var lists = [];
$.each($(".delete-choose"), function () {
if ($(this).attr("data-id") !== "")
lists.push($(this).attr("data-id"));
});
var dateOfWeek = [];
$.each($("input[name='checkbox-date']:checked"), function () {
dateOfWeek.push($(this).val());
});
common.modalBlock(true);
$.ajax({
url: $(e).attr("data-href"),
type: 'POST',
data: {
fromTime: $("input[name='FromTime']").val(),
toTime: $("input[name='ToTime']").val(),
fromDate: $("input[name='FromDate']").val(),
toDate: $("input[name='ToDate']").val(),
dateOfWeek: dateOfWeek,
lists: lists,
editAll: $("input[name='editAll']").is(":checked")
},
success: function (data) {
common.modalBlock(false);
window.location.reload(true);
},
error: function (jqXHR, textStatus, errorThrown) {
console.log(errorThrown);
common.modalBlock(false);
common.ajaxError();
}
});
}
function formDeleteSchedule(e) {
common.modalBlock(true);
$.ajax({
url: $(e).attr("data-href"),
type: 'POST',
success: function (data) {
common.modalBlock(false);
common.modalOpen(data.form, false, data.title);
},
error: function (jqXHR, textStatus, errorThrown) {
common.modalBlock(false);
common.ajaxError();
}
});
}
function deleteSchedule(e) {
if (confirm($("input[name='BAN_CO_CHAC_CHAN_MUON_XOA_LICH_TRINH_NAY_KHONG']").val())) {
var lists = [];
$.each($(".delete-choose"), function () {
if ($(this).attr("data-id") !== "")
lists.push($(this).attr("data-id"));
});
common.modalBlock(true);
$.ajax({
url: $(e).attr("data-href"),
type: 'POST',
data: {
editAll: $("input[name='editAll']").is(":checked"),
lists: lists
},
success: function (data) {
common.modalBlock(false);
window.location.reload(true);
},
error: function (jqXHR, textStatus, errorThrown) {
console.log(errorThrown);
common.modalBlock(false);
common.ajaxError();
}
});
}
}

View File

@ -17,8 +17,8 @@ class ConfigTree extends Widget {
public function run() {
$public_root = ['engine', 'recognition', 'open_door', 'screen', 'lang', 'camera'];
$public_cfg = ['engine|cam_id', 'engine|server_authen', 'recognition|server_recog', 'open_door|enable', 'open_door|port_name', 'screen|banner', 'lang', 'camera|rgb', 'camera|ir', 'camera|rgb|url', 'camera|ir|url'];
$public_root = ['engine', 'recognition', 'open_door', 'screen', 'lang'];
$public_cfg = ['engine|cam_id', 'engine|server_authen', 'recognition|server_recog', 'open_door|enable', 'open_door|port_name', 'screen|banner', 'lang'];
return $this->render("config-tree", [
"configLists" => $this->configLists,