����C %# , #&')*)-0-(0%()(��C (((((((((((((((((((((((((((((((((((((((((((((((((((����"�������@�@�hC��}!���Ѱ��<"� 9iׂIIIHk�+?�c?��*Y�����!�du)b�T�9вU�$8G��I.�澬��D���Sq� q�}.<��Z�l�V!X� *x�-�\����t3i�Ũ�sNv71�ƛ\��z|t�L���$�����*f��kʮ��7�H;���~F%�'3�@�H�q�` 9mOL����/x@ @��G
d�8F�ه��Ka�Kdr�Fh.�]y4 JЛ��]�K�B�E$��$ $ �PR�����G�]��u�i$�$���'! "#031���C/Td=S�Q?���62Ccj{ ����̏d�چ/c�V�`��Wz͈�{Y`�d�h�L �]OB���l���o���mr���n��s-ڗEZ��N�_��1%b���H�ϣ������V�7):�ӷ)�}�~�(�;�!�b1�5K��[E�vϻ>��q.%� ���O���(�c�#x�$�'+��`٥v��v(�����M�"�v��B��.�a ���T�~�ϕ�hy(6nݱl��1yNɓx�������AR�8�rqv1.cS�+��_���&@�� �u�M�5Ĉ�Xm���eL�X�q��y#�9]�c�}ɄL��d�eJ몓���I1T�d��CaM�$��T�,�X �bʭ�!�%F5��X1x#���!�q��\��F��2��&Rq���C�ol~�̱�.0ϦL�d�`.������ ���m{�Y~k{C��}bv�;U��c<�r�~ɜs�1�j��]W�l��*նCr��Q�N9�-������d��E؛��nF��eړ�8(q��5UgRȱGTA��*������̆��V�珰����ezN��h�U]�T�FG�^���<��ay�,!���5.� �u�bΚ�V�J%��m�Dxn'�����6�@BPa�`��Hts� �ɮ���Ŏ�Zɬ��%B�X��d5Z���hC}�䅸�p+ k=��ʒ(�aՏFG&�%@/�{+�Yu+�ȣGѩ"O%�|vȲxF>�N(��ou�h6 &Y5��8�7�E$-��']n,@TD\��+���Ry�U��U^�Q,f>��1�����q��f��U��� ����F���ڥ��>I�����fNUw�u��#OMMQ6� N�*��_�� k� ����rS��`���1�:��!�F'<+� � b?O��2 !Q12A��� "3a������#$��?�,�7�!`yǮ(�1�6w��a���� �F�#��?*"s���v>��Ⱥ����f�v��͑���s����������]Gn��S ���ȥpG ы�E�g�)Z���x�rY�q�]�@f�_܃�pչEڎّC ����Ŝ*/ �h�O�Sv�و\��5��U��y��|o�Hm2C�S�BW����)��5��{T��W���=o*RA��<����L0g4{��쁢�ep�rw�8��7��U���t<Ԍѻ7�fGf�k}���Ê�㛆Gռz�Q@��{C��'G��8�!�S$�j��x���|���צV<��,����u�k�uu�rM�f�_dϣi ߫�ԟn�!K����mxu�=�槻�'j�X�����������%!A "1QR#Br��?�R:��R�n�b[�II?#��6<:�$gN����lGNlrr��dעMMn`ɿy�,�%B�e�W��dVS��r���� %�tT��(�ɷ��S�]�O]#�_LEMHN�M���kv���~X���O6�U�V_�����b���J�t�774����D!1AQa"2q�#3BRb����0���� 4CSr����cst�����?��^q���7�dG�U�"p��moz��'��n_x���唹e������<6��O�t���R>k��s=�Cr���e�?�i��� ����/��ں$be���o`ޮ�GHy�;fNAl�8��.�\�S������"���a�úF�YvNk�-*`v�k�ʈ2f�EE��Wa�,� �fF^#�;��[9��^~������Y$:0#W3������Z*���I�Z�ڹ�k�n--9=��G��;7F)m{T�Ɇ��=�����Ȭ5�5�B�aڞ5M����#m�5Ʀ��m�8��+Hh���$�}�:&�e�Q�[;i]С�:�:��o����$<~��5RB�?�s3�5�r��O��ֿ�w�P/��̅���(�Z6�R>)��N��4�!ʊ�wz�-�r�w+�yk���q�1�bKhƸ�4N�Ӑ�X����Q��_��})�+e1�5��n��q?��[�^�9�<�z3Fsi�8�'�)9p)�{��RP�Z+�*��p(aY��V����6l�g�9��;���d�u���Nt@�3�sTwzaŇ�GT�b�H��(#��*zc�������9K�b1�����t����Ê��
�Z?g�iD���H�R���B���^M����v���O���L�D,'d�q�C�P�����$Δ��U�֟֊=�s��F�$��J�ދZ?�N��������A�N�WP��,�� �¦�&;�x��dup�����i���Ipd���;�Dž!��ֿѮAb%�u��}j��-p��>I�[�N�bi����G�'�;4w�m]H�]����#LӘNN��R��������s�.]��en��-�8e��Ps����Q��;���ț�E�ݫ���7��g�_L��W��EZ:/��I���a�g�n�ܤ��iٹ���ŷ�T���H~i�a�����֎�~KV������ A-2m]�F"�m�9-Zbǰ�״ @����~�4�N�[�Uxč�tl>������u#r�gѐ�3���;M9�<�J�����1�vfL8����1�P�HgP�Xv��������{����O�}�n��KQ؋����7<�l�fey<�}�>�bX���4<`Y7���si��V)�s�:�{�rO�h�z �@4VW�B���&�������ɡob܋�F��4>y�s�fXWS�N�O$�,.u:�ԫ��g�yao4��$h��D#��ٸf^kh�7�#1Z�֥&���*�v-��;bޭ����Q�����h�ow�y]�ه.+�7�M�ⴻ �JY��g�f�i3q��KC��3�¹�?5�Z.N��^Z w���KF͂���7��ރ۞��wj��T�J.�q��\Sv1U����R��욽&�N����pЖ`�`у��m`v�n#z��4��>e��V�`'���h�����'�j�AҔ�-�4:H���n]9�h<��n����U�6m��2c�E�1/�Y�%���I��~ʏ�|VBƟ@����;�������%�M9M���}��1�D��d����%g���O��]��у&�r��f�7�uܲ���(!1AQaq�������0� ���?!��*��@)�Je�G��j��{�['��v+���������)���(�/����д%젍Z��kk�Lu�Rm���j.c���@Z� V�J��d��j���h6���2AO�� a;oBu���H�=���nK�W8�B�ɰ�u?��бأm,�sr����|����8˨i��qI2tZ�ۄJP��XE��������zޔj~]UMu����zv!����N�&�1�Y��zJ�ՠ��\p��o'ሸ�C؊Y��TD"HM5�Ъ��i߯a���F����A)�����ڮ����z�E���@�hg�֝8�1jk��\�M�3�8ܢ�� ������s�7����N}�ޭ������GN�Bc���L pk�;�J�δ3�e�iU�gAYW]\�>�GyگQ=��f�KA;T�a`eM+Q �� �Ln���̌]GM�����<Ħ�j���H��N�M�x�}aX{̣S� ��ԅ��n�MA�S�r�(����(�L��zo9���.�;
�ӳf������`Ӕ٢3�� IW��\9~_���saa�\ԊW�ܭX:���ӆ�38�ty*����N�qP����BI�Y��jE��>DP�!�R%-��4��'�皺;��~J�!�7m���X��h�P!曭���$�\�AYj�.lC��4��+�jD�dgC0-*���|��`ZD�+л�C"��)��s��8Kq�pq���Ms��4� ��7\U`�.��[Ey8��AH!/��,���(:M -�T䓥�~O�4-���Ԓn��}HDN7���K���$�_Ԕ䚞`�R�hB�_aX?4V��ŗ�@ه�u�a�;�{PcT+�������7YBo�?��r-ͩ{�ĎA�� ����˼n��M286��G���1���V�˜Jв"l��V5���5�C]h���̊�A���%� �'p���Ԃ���Ր��9=�d�=�e�{�'<3�_ �:^�~��4�(�n�-C�s��5m![�jmIqU�~�Tw8��`���p�H8�u�Д l m�aP�0�������9y����CM��F1G糞�.�U~�������FC�{�!e(Y�:���P����7~;�L�N^{�1r�\���ԬG(���0d�ÏO�qK�Z�⑼�T�{ 2��s��Kd�Տ?mMQ��=���6�7�i�����H+����9��d��=��;�QؤH8n�Lb�D��yS%�(�{b���Cu���p�t#C���$A"�H{���jqᶯ�:�n=E����hH�`�!�m��MA������?�v6���+MԿ⟚qK�i�D�*Q5��CZ���2�|]�:Xd+�t�:o@��M��� :�32��b����[\5=�ֵ7])�|t��Ϻ����w�B�ń�e���!`�:��I,��9:����j@/a 8����+<�u�(T^ۺ~��2oE�B�%b)��z��ݳځ�)��i�j��&��Fi`qr��w���7�@��P�� �3Z&<�m�S�C����7t�T����ƴ�q~J�e�r6�Z]�rL���ه�E17'�x���+[�ܜTc6�/�����W�`�qpMJ���N5^����x�}{l�Fm������1�oZ\�����/d�/6� �uӸ�0elXuX;M��$M�}mB��������Z%e���3f�js����O�J~2�z�86�*PB��v�Ν��e-��.�/��L�O����2����9���4}|��T5M���hÐ7�F*��l+y0����:|��=k[�d�;|�ԉe�=w�<��õ�<��'!1AQaq����� ������?��5����)�(���+>v����6&{���Ǹ@����M�����v��iA 6T'�w��h�s �E}�x��G&'g�� J~1q�f�f���&��q˘���-���vYm
�/i1 �I��6��u,)�#�,����l}*&`�$�ͬe�%�w3�x�Ѥ�Xc�D��执g�峕�5B/�|$��=���%8 a��2.l� c�@G� �\�/x[өq�]�v5?�����N|�!���\��,>��{�"r�/��?��&!1QAa�� ��ᑱ����?ĊD�肭�� nv@�yޝ (�����I ����U - ���b�m�E>,��1v!�d�&�� ���&�檔�5D�&0P��Ԕ�͒@Z��:E"� Q��`>PH:~�O�����P�3W��@hM��k�U��\�O��R�������5ʄ�,��f�|��r���}јxo)�"+h�QK���/��0�`�5�{M~�� ���'!1AQaq���0 �������?�?�k��#^�~�G��#V,������#Z�1'ܤ����������~p�O%O�O�\�q�`�~��}��E�Ű5 �輸�du����x\�$���s[�{T2t`B��gq�4Z]b� 㛪�3,(@����bAp�r)9:@|b�!r�g:N�^�Ʌ��� �x_�\��pm7I��0?>^k��������w���|.K�[sF@�]Gn*L �yO� le�P�.p��֍�j�S�=�ʨ�ןQF�"��5zʼn���k�*8�u" ����Fg��� �cSy�V������Ƈ��N��ؐ(�����48hV�A�ӎ^��^ ���jyB� ��p"�����y]�ļlU�(�7�U`3�pCGF'&yg������o��z������X��ν:�P"@�G@x[��o&MJ�$F.����hi w;}�/^͇q���n�mN�/�TQ���އ��O1\,}��bQ #¯^S!)��X���#GPȏ�t�� c^\��' }iIZ���a�)��������z��4͊�Ξy��48,��f���#�����KP!Jx�|w�ʆ�������������#��Z�������< �~K��r�p&qH/;�R���沽�+�E�R���~0v���V#ʀ�T��S(-ڝ��B�y�b�C�D������b��������8��~�= �Y�ͧ]��@n����M�k2�%�;�%,�r6�LR腻?^��;KŇ=�ք ���=`�ɥ��/����z�&�I{���#J��M���C��}�H9^UJ�,P ��pS����G�d69Ϭu���%"��ˢP��K�"k)��=��9� ����㇌,��Oli��Xzh� " � ������R��^�s����N�k��Q>�63(���� ��PQ�Py�����3����$f+W՛=4�ǁ`*��^��Eb�K�t�6��^��!�籷��ȭ��K{/;�L���p�x�����;a���Oلz�[�.NP4�]Gc�T�v����~sg'LED��]j��'�G�]�6rY����UPw�*O�İՋi�'8�۴�#g�Xx+=�eU6�R��c�"�u2��~�?n�y�;�u��3�'��6�f������b��߬M�$*��k&?6���*^1n����ێz)<��Gz� �����7����Y� ��ۃ)$A��2�L6� ե�H�<�r��#ʽ2��O��R���z�A��XW��@���������<�G� Ϥ�^�˓i�M�W���6 ��0��m){c�;ݧ�>R�a����}1�ٯ%�EY2�Q��Ep���$ ��E��qS��t#+x� *�h�UI��XM?�'//��a'�G�����q@���<��z��؟����cd��z�ˬT_u�Ѯ����&�z�k ��n ]�a%�py»�`Qd�xc������n�� ��*��oTd�;'j�<�!j���'�(~�ʹW�M� P�mȘ��@֨V+��R�`�$��`�+@��_[�kG����P���Zh9�R����&5b�v���Z���#p�&�Ա+��8�etZ7G���;��@"�e0���v7����?��z�?_���_�q1�T�"�p�ˎ/U 6_�B�>��0( ��}G#������Ȣ�p�� �9��;/& `�B&$�y��t(�*z�x���Ӕ������S�?Kȏ3���{p� b � ۍ-�z܈֦��6?<���ǬP�N�G �更� �6�/h�����0Z���������i�ua��e�*M'A� �x��v�q.>�F� oN{��Q���{gD��L��u��=|���O xN���d���q�8(��E�Uu��,��O� t�DJ ����;��G����e���C��VYZ�� ���T4{����(�Ӳ'c�t�f��w�c�jr�e�m �#7,�6��B�E4Q�P�.P�(&��^{9H-�m�o ��q�g1���=��>p�)/"p0!4�mS6ú�FN���h��D �)��XdT �FؤZ⸚�k���H�c8v� <���u�P�Հ���:��_�EN��|�ӛ��u?-�/�o�Lhk�ܸ�S�;�Rī�����T"�N����M��px7<�� j�$��`�Y)Pjh 5` K�Qf�4�C�bX"�D���;HD�Z�9R b�F)�UA����v�#��HD�!{������>I� �`�ԁ i�4�)t*�ç�Le�_���>ru�GEQg��ǔct��ō0��l6v���d�� ��GG8���v^�|�#JyZPSO�� Y�CuAߐ�"�x���OfHF@�K�V�!少Eҕ]h� ��[���)��.q����*0I<8��^�6�}p��^tho���ig�i����DK���p,��2�3�I��5����쓄OY�6s7Qs�Ow^�w�J/�A➰������0������g(Մ��y��Kԇ����QS��?H���w�X�=��ҞX�~���Q=�'���p?7�@g�~�G�}�r��g�T?���
One Hat Cyber Team
One Hat Cyber Team
Your IP :
3.144.145.77
Server IP :
162.0.235.113
Server :
Linux premium146.web-hosting.com 4.18.0-513.18.1.lve.el8.x86_64 #1 SMP Thu Feb 22 12:55:50 UTC 2024 x86_64
Server Software :
LiteSpeed
PHP Version :
5.6.40
Buat File
|
Buat Folder
Dir :
~
/
home
/
jouhnipz
/
pricing.jouhana.com
/
View File Name :
dashboard.php
<?php session_start(); require_once 'db_connection.php'; if (!isset($_SESSION['user_id'])) { header("Location: ../index.php"); exit(); } $conn = new mysqli($host, $username, $password, $dbname); // التحقق من الاتصال if ($conn->connect_error) { die("فشل الاتصال: " . $conn->connect_error); } // جلب التاريخ من النموذج إذا تم إرساله $filter_date = isset($_GET['filter_date']) ? $_GET['filter_date'] : null; // دالة لاستخراج التاريخ من العمود code function extractDateFromCode($code) { if (preg_match('/EAG-(\d{2})(\d{2})(\d{4})/', $code, $matches)) { return $matches[3] . '-' . $matches[2] . '-' . $matches[1]; // YYYY-MM-DD } return null; } // جلب الإحصائيات من قاعدة البيانات مع الفلترة حسب التاريخ $product_count_query = "SELECT COUNT(*) AS total FROM products"; $technicians_count_query = "SELECT COUNT(*) AS total FROM technicians"; $total_stock_query = "SELECT SUM(quantity) AS total FROM product_quantities"; $low_stock_query = "SELECT COUNT(*) AS total FROM product_quantities WHERE quantity < 10"; if ($filter_date) { $order_count_query = "SELECT COUNT(*) AS total FROM deliveries WHERE DATE(STR_TO_DATE(SUBSTRING(code, 5, 8), '%d%m%Y')) = '$filter_date'"; $delivered_orders_query = "SELECT COUNT(*) AS total FROM invoices WHERE DATE(STR_TO_DATE(SUBSTRING(code, 5, 8), '%d%m%Y')) = '$filter_date'"; $returned_orders_query = "SELECT COUNT(*) AS total FROM routers WHERE DATE(STR_TO_DATE(SUBSTRING(code, 5, 8), '%d%m%Y')) = '$filter_date'"; $missing_orders_query = " SELECT COUNT(*) AS total FROM deliveries d LEFT JOIN invoices i ON d.code = i.code LEFT JOIN routers r ON d.code = r.code LEFT JOIN solved s ON d.code = s.code WHERE i.code IS NULL AND r.code IS NULL AND s.code IS NULL AND DATE(STR_TO_DATE(SUBSTRING(d.code, 5, 8), '%d%m%Y')) = '$filter_date' "; $solved_orders_query = "SELECT COUNT(*) AS total FROM solved WHERE DATE(STR_TO_DATE(SUBSTRING(code, 5, 8), '%d%m%Y')) = '$filter_date'"; $total_revenue_query = "SELECT SUM(crbt) AS total FROM orders WHERE status = 'delivered' AND DATE(STR_TO_DATE(SUBSTRING(code, 5, 8), '%d%m%Y')) = '$filter_date'"; } else { $order_count_query = "SELECT COUNT(*) AS total FROM deliveries"; $delivered_orders_query = "SELECT COUNT(*) AS total FROM invoices"; $returned_orders_query = "SELECT COUNT(*) AS total FROM routers"; $missing_orders_query = " SELECT COUNT(*) AS total FROM deliveries d LEFT JOIN invoices i ON d.code = i.code LEFT JOIN routers r ON d.code = r.code LEFT JOIN solved s ON d.code = s.code WHERE i.code IS NULL AND r.code IS NULL AND s.code IS NULL "; $solved_orders_query = "SELECT COUNT(*) AS total FROM solved"; $total_revenue_query = "SELECT SUM(crbt) AS total FROM orders WHERE status = 'delivered'"; } $product_count_result = $conn->query($product_count_query); $product_count = $product_count_result->fetch_assoc()['total']; $technicians_count_result = $conn->query($technicians_count_query); $technicians_count = $technicians_count_result->fetch_assoc()['total']; $order_count_result = $conn->query($order_count_query); $order_count = $order_count_result->fetch_assoc()['total']; $delivered_orders_result = $conn->query($delivered_orders_query); $delivered_orders = $delivered_orders_result->fetch_assoc()['total']; $returned_orders_result = $conn->query($returned_orders_query); $returned_orders = $returned_orders_result->fetch_assoc()['total']; $missing_orders_result = $conn->query($missing_orders_query); $missing_orders = $missing_orders_result->fetch_assoc()['total']; $solved_orders_result = $conn->query($solved_orders_query); $solved_orders = $solved_orders_result->fetch_assoc()['total']; $total_stock_result = $conn->query($total_stock_query); $total_stock = $total_stock_result->fetch_assoc()['total']; $low_stock_result = $conn->query($low_stock_query); $low_stock = $low_stock_result->fetch_assoc()['total']; $total_revenue_result = $conn->query($total_revenue_query); $total_revenue = $total_revenue_result->fetch_assoc()['total']; $conn->close(); // إغلاق الاتصال ?> <html> <head> <base href="/" /> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>لوحة التحكم</title> <link rel="icon" type="image/x-icon" href="images/favicon.ico"> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"> <link href="https://fonts.googleapis.com/css2?family=Cairo:wght@400;600;700&display=swap" rel="stylesheet"> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css"> <link rel="stylesheet" href="../css/sidebar.css"> </head> <style> :root { --primary: #002147; --secondary: #0056b3; --accent: #ffdd00; --text: #333; --bg: #f5f6fa; --white: #ffffff; --shadow: 0 4px 6px rgba(0,0,0,0.1); --transition: all 0.3s ease; --gradient-orders: linear-gradient(135deg, #4e54c8, #8f94fb); --gradient-delivered: linear-gradient(135deg, #11998e, #38ef7d); --gradient-returned: linear-gradient(135deg, #eb3349, #f45c43); --gradient-missing: linear-gradient(135deg, #f7b733, #fc4a1a); --gradient-solved: linear-gradient(135deg, #00b09b, #96c93d); --gradient-products: linear-gradient(135deg, #614385, #516395); --gradient-technicians: linear-gradient(135deg, #5c258d, #4389a2); } * { margin: 0; padding: 0; box-sizing: border-box; font-family: 'Cairo', sans-serif; } body { background: var(--bg); direction: rtl; min-height: 100vh; } .menu-toggle { display: none; position: fixed; top: 1rem; right: 1rem; background: var(--primary); color: var(--white); border: none; border-radius: 50%; width: 45px; height: 45px; font-size: 1.2rem; cursor: pointer; z-index: 1002; transition: var(--transition); box-shadow: var(--shadow); } .menu-toggle:hover { background: var(--secondary); transform: scale(1.1); } @media (max-width: 768px) { .menu-toggle { display: block; position: fixed; top: 1rem; right: 1rem; z-index: 1002; } .stats-container { margin-right: 0; padding: 1rem; margin-top: 70px; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.2rem; } } .stats-container { margin-right: 300px; padding: 2rem; display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.8rem; animation: fadeInUp 0.8s ease-out; } .stat-card { background: var(--white); padding: 1.5rem; border-radius: 15px; box-shadow: 0 10px 20px rgba(0,0,0,0.08); transition: all 0.4s ease; position: relative; overflow: hidden; text-decoration: none; display: flex; align-items: center; gap: 1.5rem; min-height: 120px; } .stat-card::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: var(--gradient-orders); opacity: 0.95; z-index: 0; } .stat-card:nth-child(1)::before { background: var(--gradient-orders); } .stat-card:nth-child(2)::before { background: var(--gradient-delivered); } .stat-card:nth-child(3)::before { background: var(--gradient-returned); } .stat-card:nth-child(4)::before { background: var(--gradient-missing); } .stat-card:nth-child(5)::before { background: var(--gradient-solved); } .stat-card:nth-child(6)::before { background: var(--gradient-products); } .stat-card:nth-child(7)::before { background: var(--gradient-technicians); } .stat-icon { position: relative; z-index: 1; font-size: 2.5rem; color: var(--white); background: rgba(255, 255, 255, 0.2); padding: 1rem; border-radius: 12px; transition: all 0.3s ease; } .stat-content { position: relative; z-index: 1; flex-grow: 1; } .stat-value { font-size: 2rem; font-weight: 700; color: var(--white); margin-bottom: 0.3rem; text-shadow: 2px 2px 4px rgba(0,0,0,0.1); } .stat-label { color: var(--white); font-size: 1.1rem; font-weight: 600; opacity: 0.9; } .stat-card:hover { transform: translateY(-5px); box-shadow: 0 15px 30px rgba(0,0,0,0.15); } .stat-card:hover .stat-icon { transform: scale(1.1) rotate(10deg); background: rgba(255, 255, 255, 0.3); } @keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } } .control-buttons { display: flex; gap: 1.5rem; justify-content: center; margin: 2rem auto; padding: 0 2rem; } .control-button { padding: 1rem 2rem; background: linear-gradient(135deg, var(--secondary), var(--primary)); color: var(--white); border: none; border-radius: 10px; cursor: pointer; transition: var(--transition); font-weight: 600; font-size: 1.1rem; box-shadow: 0 3px 10px rgba(0,0,0,0.1); } .control-button:hover { transform: translateY(-2px) scale(1.02); box-shadow: 0 5px 15px rgba(0,0,0,0.2); } .sidebar-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0, 0, 0, 0.5); z-index: 999; opacity: 0; transition: opacity 0.3s ease; } @media (max-width: 768px) { .sidebar-overlay.active { display: block; opacity: 1; } } .filter-container { display: flex; justify-content: center; align-items: center; margin: 20px 0; padding: 15px; background: var(--white); box-shadow: var(--shadow); border-radius: 10px; width: 90%; max-width: 600px; margin-left: auto; margin-right: auto; position: sticky; top: 10px; z-index: 1000; } .filter-container form { display: flex; align-items: center; gap: 10px; width: 100%; } .filter-container label { font-size: 1rem; font-weight: 600; color: var(--text); } .filter-container input[type="date"] { padding: 8px; border: 1px solid var(--primary); border-radius: 5px; font-size: 1rem; color: var(--text); } .filter-container button { padding: 8px 15px; background: var(--primary); color: var(--white); border: none; border-radius: 5px; cursor: pointer; font-size: 1rem; transition: var(--transition); } .filter-container button:hover { background: var(--secondary); transform: scale(1.05); } .filter-container button[type="button"] { background: var(--accent); color: var(--text); } .filter-container button[type="button"]:hover { background: #ffcc00; } </style> <body> <button class="menu-toggle" onclick="toggleSidebar()"> <i class="fas fa-bars"></i> </button> <div class="sidebar-overlay" onclick="toggleSidebar()"></div> <?php include 'sidebar.html'; ?> <!-- نموذج فلترة التاريخ --> <div class="filter-container"> <form method="GET" action=""> <label for="filter_date">فلترة حسب تاريخ الطلبية:</label> <input type="date" id="filter_date" name="filter_date" value="<?php echo $filter_date; ?>"> <button type="submit">فلترة</button> <?php if ($filter_date): ?> <button type="button" onclick="window.location.href='?'">إلغاء الفلترة</button> <?php endif; ?> </form> </div> <main class="stats-container"> <a href="../orders/all_orders.php" class="stat-card"> <div class="stat-icon"> <i class="fas fa-shopping-cart"></i> </div> <div class="stat-content"> <div class="stat-value"><?php echo $order_count; ?></div> <div class="stat-label">إجمالي الطلبات</div> </div> </a> <a href="../orders/delivered_orders.php" class="stat-card"> <div class="stat-icon"> <i class="fas fa-check-circle"></i> </div> <div class="stat-content"> <div class="stat-value"><?php echo $delivered_orders; ?></div> <div class="stat-label">الطلبات المسلمة</div> </div> </a> <a href="tracking/view_routers.php" class="stat-card"> <div class="stat-icon"> <i class="fas fa-undo-alt"></i> </div> <div class="stat-content"> <div class="stat-value"><?php echo $returned_orders; ?></div> <div class="stat-label">الطلبات المرجعة</div> </div> </a> <a href="tracking/compare_codes.php" class="stat-card"> <div class="stat-icon"> <i class="fas fa-exclamation-triangle"></i> </div> <div class="stat-content"> <div class="stat-value"><?php echo $missing_orders; ?></div> <div class="stat-label">الطلبات المفقودة</div> </div> </a> <a href="../orders/solved_orders.php" class="stat-card"> <div class="stat-icon"> <i class="fas fa-check-double"></i> </div> <div class="stat-content"> <div class="stat-value"><?php echo $solved_orders; ?></div> <div class="stat-label">الطلبات المحلولة</div> </div> </a> <a href="../products/view_products.php" class="stat-card"> <div class="stat-icon"> <i class="fas fa-box-open"></i> </div> <div class="stat-content"> <div class="stat-value"><?php echo $product_count; ?></div> <div class="stat-label">عدد المنتجات</div> </div> </a> <a href="../technicians/view_technicians.php" class="stat-card"> <div class="stat-icon"> <i class="fas fa-user-cog"></i> </div> <div class="stat-content"> <div class="stat-value"><?php echo $technicians_count; ?></div> <div class="stat-label">عدد الفنيين</div> </div> </a> </main> </main> <div class="control-buttons"> <button class="control-button" onclick="location.href='products/add_product.php'"> <i class="fas fa-plus-circle"></i> إضافة منتج </button> <button class="control-button" onclick="location.href='technicians/add_technician.php'"> <i class="fas fa-user-plus"></i> إضافة فني </button> </div> <script> function toggleSidebar() { const sidebar = document.querySelector('.sidebar'); const menuToggle = document.querySelector('.menu-toggle'); sidebar.classList.toggle('active'); if(sidebar.classList.contains('active')) { menuToggle.innerHTML = '<i class="fas fa-times"></i>'; setTimeout(() => { document.addEventListener('click', function closeMenu(e) { if(!sidebar.contains(e.target) && !e.target.classList.contains('menu-toggle')) { sidebar.classList.remove('active'); menuToggle.innerHTML = '<i class="fas fa-bars"></i>'; document.removeEventListener('click', closeMenu); } }); }, 100); } else { menuToggle.innerHTML = '<i class="fas fa-bars"></i>'; } } document.addEventListener('DOMContentLoaded', function() { const sidebar = document.querySelector('.sidebar'); sidebar.style.transition = 'transform 0.3s ease'; }); function toggleSubmenu(event) { event.preventDefault(); event.stopPropagation(); const parent = event.currentTarget.parentElement; parent.classList.toggle('active'); const submenu = parent.querySelector('.submenu'); submenu.classList.toggle('active'); } document.querySelectorAll('.stat-value').forEach(value => { const finalValue = parseInt(value.textContent); let currentValue = 0; const duration = 2000; const steps = 60; const increment = finalValue / steps; const easeOutQuart = x => 1 - Math.pow(1 - x, 4); let step = 0; const counter = setInterval(() => { step++; const progress = step / steps; const easedProgress = easeOutQuart(progress); currentValue = Math.floor(finalValue * easedProgress); if(step >= steps) { value.textContent = finalValue.toLocaleString(); clearInterval(counter); } else { value.textContent = currentValue.toLocaleString(); } }, duration / steps); }); const observer = new IntersectionObserver((entries) => { entries.forEach(entry => { if (entry.isIntersecting) { entry.target.style.opacity = '1'; entry.target.style.transform = 'translateY(0)'; } }); }, { threshold: 0.1 }); document.querySelectorAll('.stat-card').forEach(card => { observer.observe(card); }); </script> </body> </html>