����JFIFXX�����    $.' ",#(7),01444'9=82<.342  2!!22222222222222222222222222222222222222222222222222����"��4�� ���,�PG"Z_�4�˷����kjز�Z�,F+��_z�,�© �����zh6�٨�ic�fu���#ډb���_�N�?��wQ���5-�~�I���8����TK<5o�Iv-�����k�_U_�����~b�M��d����Ӝ�U�Hh��?]��E�w��Q���k�{��_}qFW7HTՑ��Y��F�?_�'ϔ��_�Ջt��=||I ��6�έ"�����D���/[�k�9���Y�8ds|\���Ҿp6�Ҵ���]��.����6�z<�v��@]�i%��$j��~�g��J>��no����pM[me�i$[����s�o�ᘨ�˸ nɜG-�ĨU�ycP�3.DB�li�;��hj���x7Z^�N�h������N3u{�:j�x�힞��#M&��jL P@_���� P��&��o8������9�����@Sz6�t7#O�ߋ �s}Yf�T���lmr����Z)'N��k�۞p����w\�Tȯ?�8`�O��i{wﭹW�[�r�� ��Q4F�׊���3m&L�=��h3����z~��#�\�l :�F,j@�� ʱ�wQT����8�"kJO���6�֚l����}���R�>ډK���]��y����&����p�}b��;N�1�m�r$�|��7�>e�@B�TM*-iH��g�D�)� E�m�|�ؘbҗ�a��Ҿ����t4���o���G��*oCN�rP���Q��@z,|?W[0�����:�n,jWiE��W��$~/�hp\��?��{(�0���+�Y8rΟ�+����>S-S����VN;�}�s?.����� w�9��˟<���Mq4�Wv'��{)0�1mB��V����W[�����8�/<� �%���wT^�5���b��)iM� pg�N�&ݝ��VO~�q���u���9� ����!��J27����$O-���! �:�%H��� ـ����y�ΠM=t{!S�� oK8������t<����è:a������[�����ա�H���~��w��Qz`�po�^ ����Q��n� �,uu�C�$ ^���,������8�#��:�6��e�|~���!�3�3.�\0��q��o�4`.|� ����y�Q�`~;�d�ׯ,��O�Zw�������`73�v�܋�<���Ȏ�� ـ4k��5�K�a�u�=9Yd��$>x�A�&�� j0� ���vF��� Y�|�y��� ~�6�@c��1vOp�Ig����4��l�OD���L����� R���c���j�_�uX6��3?nk��Wy�f;^*B� ��@�~a�`��Eu������+���6�L��.ü>��}y���}_�O�6�͐�:�YrG�X��kG�����l^w���~㒶sy��Iu�!� W ��X��N�7BV��O��!X�2����wvG�R�f�T#�����t�/?���%8�^�W�aT��G�cL�M���I��(J����1~�8�?aT ���]����AS�E��(��*E}� 2��#I/�׍qz��^t�̔���b�Yz4x���t�){ OH��+(E��A&�N�������XT��o��"�XC��'���)}�J�z�p� ��~5�}�^����+�6����w��c��Q�|Lp�d�H��}�(�.|����k��c4^�"�����Z?ȕ ��a<�L�!039C� �Eu�C�F�Ew�ç ;�n?�*o���B�8�bʝ���'#Rqf���M}7����]����s2tcS{�\icTx;�\��7K���P���ʇ Z O-��~��c>"��?�������P��E��O�8��@�8��G��Q�g�a�Վ���󁶠�䧘��_%#r�>�1�z�a��eb��qcPѵ��n���#L��� =��׀t� L�7�`��V���A{�C:�g���e@�w1 Xp3�c3�ġ����p��M"'-�@n4���fG��B3�DJ�8[Jo�ߐ���gK)ƛ��$���� ���8�3�����+���� �����6�ʻ���� ���S�kI�*KZlT _`���?��K����QK�d����B`�s}�>���`��*�>��,*@J�d�oF*����弝��O}�k��s��]��y�ߘ��c1G�V���<=�7��7����6�q�PT��tXԀ�!9*4�4Tހ3XΛex�46���Y��D ����� �BdemDa����\�_l,��G�/���֌7���Y�](�xTt^%�GE�����4�}bT���ڹ�����;Y)���B�Q��u��>J/J �⮶.�XԄ��j�ݳ�+E��d ��r�5�_D�1 ��o�� �B�x�΢�#���<��W�����8���R6�@g�M�.��� dr�D��>(otU��@x=��~v���2� ӣ�d�oBd��3�eO�6�㣷�����ݜ6��6Y��Qz`��S��{���\P�~z m5{J/L��1������<�e�ͅPu�b�]�ϔ���'������f�b� Zpw��c`"��i���BD@:)ִ�:�]��hv�E�w���T�l��P���"Ju�}��وV J��G6��. J/�Qgl߭�e�����@�z�Zev2u�)]կ�����7x���s�M�-<ɯ�c��r�v�����@��$�ޮ}lk���a���'����>x��O\�ZFu>�����ck#��&:��`�$�ai�>2Δ����l���oF[h��lE�ܺ�Πk:)���`�� $[6�����9�����kOw�\|���8}������ބ:��񶐕��I�A1/�=�2[�,�!��.}gN#�u����b��� ~��݊��}34q����d�E��Lc��$��"�[q�U�硬g^��%B �z���r�pJ�ru%v\h1Y�ne`ǥ:g���pQM~�^�Xi� ��`S�:V29.�P���V�?B�k�� AEvw%�_�9C�Q����wKekPؠ�\�;Io d�{ ߞo�c1eP����\� `����E=���@K<�Y���eڼ�J���w����{av�F�'�M�@/J��+9p���|]�����Iw &`��8���&M�hg��[�{��Xj��%��Ӓ�$��(����ʹN���<>�I���RY���K2�NPlL�ɀ)��&e����B+ь����( � �JTx���_?EZ� }@ 6�U���뙢ط�z��dWI�n` D����噥�[��uV��"�G&Ú����2g�}&m��?ċ�"����Om#��������� ��{�ON��"S�X��Ne��ysQ���@Fn��Vg���dX�~nj�]J�<�K]:��FW��b�������62�=��5f����JKw��bf�X�55��~J �%^����:�-�QIE��P��v�nZum� z � ~ə ���� ���ة����;�f��\v���g�8�1��f24;�V���ǔ�)����9���1\��c��v�/'Ƞ�w�������$�4�R-��t���� e�6�/�ġ �̕Ecy�J���u�B���<�W�ַ~�w[B1L۲�-JS΂�{���΃������A��20�c#��@ 0!1@AP"#2Q`$3V�%45a6�FRUq��� ����^7ׅ,$n�������+��F�`��2X'��0vM��p�L=������5��8������u�p~���.�`r�����\���O��,ư�0oS ��_�M�����l���4�kv\JSd���x���SW�<��Ae�IX����������$I���w�:S���y���›R��9�Q[���,�5�;�@]�%���u�@ *ro�lbI �� ��+���%m:�͇ZV�����u�̉����θau<�fc�.����{�4Ա� �Q����*�Sm��8\ujqs]{kN���)qO�y�_*dJ�b�7���yQqI&9�ԌK!�M}�R�;������S�T���1���i[U�ɵz�]��U)V�S6���3$K{�ߊ<�(� E]Զ[ǼENg�����'�\?#)Dkf��J���o��v���'�%ƞ�&K�u�!��b�35LX�Ϸ��63$K�a�;�9>,R��W��3�3� d�JeTYE.Mϧ��-�o�j3+y��y^�c�������VO�9NV\nd�1 ��!͕_)a�v;����թ�M�lWR1��)El��P;��yوÏ�u 3�k�5Pr6<�⒲l�!˞*��u־�n�!�l:����UNW ��%��Chx8vL'��X�@��*��)���̮��ˍ��� ���D-M�+J�U�kvK����+�x8��cY������?�Ԡ��~3mo��|�u@[XeY�C�\Kp�x8�oC�C�&����N�~3-H���� ��MX�s�u<`���~"WL��$8ξ��3���a�)|:@�m�\���^�`�@ҷ)�5p+��6���p�%i)P M���ngc�����#0Aruz���RL+xSS?���ʮ}()#�t��mˇ!��0}}y����<�e� �-ή�Ԩ��X������ MF���ԙ~l L.3���}�V뽺�v�����멬��Nl�)�2����^�Iq��a��M��qG��T�����c3#������3U�Ǎ���}��לS�|qa��ڃ�+���-��2�f����/��bz��ڐ�� �ݼ[2�ç����k�X�2�* �Z�d���J�G����M*9W���s{��w���T��x��y,�in�O�v��]���n����P�$�JB@=4�OTI�n��e�22a\����q�d���%�$��(���:���: /*�K[PR�fr\nڙdN���F�n�$�4�[�� U�zƶ����� �mʋ���,�ao�u 3�z� �x��Kn����\[��VFmbE;�_U��&V�Gg�]L�۪&#n%�$ɯ�dG���D�TI=�%+AB�Ru#��b4�1�»x�cs�YzڙJG��f��Il��d�eF'T� iA��T���uC�$����Y��H?����[!G`}���ͪ� �纤Hv\������j�Ex�K���!���OiƸ�Yj�+u-<���'q����uN�*�r\��+�]���<�wOZ.fp�ێ��,-*)V?j-kÊ#�`�r��dV����(�ݽBk�����G�ƛk�QmUڗe��Z���f}|����8�8��a���i��3'J�����~G_�^���d�8w������ R�`(�~�.��u���l�s+g�bv���W���lGc}��u���afE~1�Ue������Z�0�8�=e�� f@/�jqEKQQ�J��oN��J���W5~M>$6�Lt�;$ʳ{���^��6�{����v6���ķܰg�V�cnn �~z�x�«�,2�u�?cE+Ș�H؎�%�Za�)���X>uW�Tz�Nyo����s���FQƤ��$��*�&�LLXL)�1�" L��eO��ɟ�9=���:t��Z���c��Ž���Y?�ӭV�wv�~,Y��r�ۗ�|�y��GaF�����C�����.�+� ���v1���fήJ�����]�S��T��B��n5sW}y�$��~z�'�c ��8 ��� ,! �p��VN�S��N�N�q��y8z˱�A��4��*��'������2n<�s���^ǧ˭P�Jޮɏ�U�G�L�J�*#��<�V��t7�8����TĜ>��i}K%,���)[��z�21z ?�N�i�n1?T�I�R#��m-�����������������1����lA�`��fT5+��ܐ�c�q՝��ʐ��,���3�f2U�եmab��#ŠdQ�y>\��)�SLY����w#��.���ʑ�f��� ,"+�w�~�N�'�c�O�3F�������N<���)j��&��,-� �љ���֊�_�zS���TǦ����w�>��?�������n��U仆�V���e�����0���$�C�d���rP �m�׈e�Xm�Vu� �L��.�bֹ��� �[Դaզ���*��\y�8�Է:�Ez\�0�Kq�C b��̘��cө���Q��=0Y��s�N��S.���3.���O�o:���#���v7�[#߫ ��5�܎�L���Er4���9n��COWlG�^��0k�%<���ZB���aB_���������'=��{i�v�l�$�uC���mƎҝ{�c㱼�y]���W�i ��ߧc��m�H� m�"�"�����;Y�ߝ�Z�Ǔ�����:S#��|}�y�,/k�Ld� TA�(�AI$+I3��;Y*���Z��}|��ӧO��d�v��..#:n��f>�>���ȶI�TX��� 8��y����"d�R�|�)0���=���n4��6ⲑ�+��r<�O�܂~zh�z����7ܓ�HH�Ga롏���nCo�>������a ���~]���R���̲c?�6(�q�;5%� |�uj�~z8R=X��I�V=�|{v�Gj\gc��q����z�؋%M�ߍ����1y��#��@f^���^�>N�����#x#۹��6�Y~�?�dfPO��{��P�4��V��u1E1J �*|���%���JN��`eWu�zk M6���q t[�� ��g�G���v��WIG��u_ft����5�j�"�Y�:T��ɐ���*�;� e5���4����q$C��2d�}���� _S�L#m�Yp��O�.�C�;��c����Hi#֩%+) �Ӎ��ƲV���SYź��g |���tj��3�8���r|���V��1#;.SQ�A[���S������#���`n�+���$��$I �P\[�@�s��(�ED�z���P��])8�G#��0B��[ى��X�II�q<��9�~[Z멜�Z�⊔IWU&A>�P~�#��dp<�?����7���c��'~���5 ��+$���lx@�M�dm��n<=e�dyX��?{�|Aef ,|n3�<~z�ƃ�uۧ�����P��Y,�ӥQ�*g�#먙R�\���;T��i,��[9Qi歉����c>]9�� ��"�c��P�� �Md?٥��If�ت�u��k��/����F��9�c*9��Ǎ:�ØF���z�n*�@|I�ށ9����N3{'��[�'ͬ�Ҳ4��#}��!�V� Fu��,�,mTIk���v C�7v���B�6k�T9��1�*l� '~��ƞF��lU��'�M ����][ΩũJ_�{�i�I�n��$���L�� j��O�dx�����kza۪��#�E��Cl����x˘�o�����V���ɞ�ljr��)�/,�߬h�L��#��^��L�ф�,íMƁe�̩�NB�L�����iL����q�}��(��q��6IçJ$�W�E$��:������=#����(�K�B����zђ <��K(�N�۫K�w��^O{!����)�H���>x�������lx�?>Պ�+�>�W���,Ly!_�D���Ō�l���Q�!�[ �S����J��1��Ɛ�Y}��b,+�Lo�x�ɓ)����=�y�oh�@�꥟/��I��ѭ=��P�y9��� �ۍYӘ�e+�p�Jnϱ?V\SO%�(�t� ���=?MR�[Ș�����d�/ ��n�l��B�7j� ��!�;ӥ�/�[-���A�>�dN�sLj ��,ɪv��=1c�.SQ�O3�U���ƀ�ܽ�E����������̻��9G�ϷD�7(�}��Ävӌ\�y�_0[w ���<΍>����a_��[0+�L��F.�޺��f�>oN�T����q;���y\��bՃ��y�jH�<|q-eɏ�_?_9+P���Hp$�����[ux�K w�Mw��N�ی'$Y2�=��q���KB��P��~������Yul:�[<����F1�2�O���5=d����]Y�sw:���Ϯ���E��j,_Q��X��z`H1,#II ��d�wr��P˂@�ZJV����y$�\y�{}��^~���[:N����ߌ�U�������O��d�����ؾe��${p>G��3c���Ė�lʌ�� ת��[��`ϱ�-W����dg�I��ig2��� ��}s ��ؤ(%#sS@���~���3�X�nRG�~\jc3�v��ӍL��M[JB�T��s3}��j�Nʖ��W����;7��ç?=X�F=-�=����q�ߚ���#���='�c��7���ڑW�I(O+=:uxq�������������e2�zi+�kuG�R��������0�&e�n���iT^J����~\jy���p'dtG��s����O��3����9* �b#Ɋ�� p������[Bws�T�>d4�ۧs���nv�n���U���_�~,�v����ƜJ1��s�� �QIz��)�(lv8M���U=�;����56��G���s#�K���MP�=��LvyGd��}�VwWBF�'�à �?MH�U�g2�� ����!�p�7Q��j��ڴ����=��j�u��� Jn�A s���uM������e��Ɔ�Ҕ�!)'��8Ϣ�ٔ��ޝ(��Vp���צ֖d=�IC�J�Ǡ{q������kԭ�߸���i��@K����u�|�p=..�*+����x�����z[Aqġ#s2a�Ɗ���RR�)*HRsi�~�a &f��M��P����-K�L@��Z��Xy�'x�{}��Zm+���:�)�) IJ�-i�u���� ���ܒH��'�L(7�y�GӜq���� j��� 6ߌg1�g�o���,kر���tY�?W,���p���e���f�OQS��!K�۟cҒA�|ս�j�>��=⬒��˧L[�� �߿2JaB~R��u�:��Q�] �0H~���]�7��Ƽ�I���(}��cq '�ήET���q�?f�ab���ӥvr� �)o��-Q��_'����ᴎo��K������;��V���o��%���~OK ����*��b�f:���-ťIR��`B�5!RB@���ï�� �u �̯e\�_U�_������� g�ES��3�������QT��a����x����U<~�c?�*�#]�MW,[8O�a�x��]�1bC|踤�P��lw5V%�)�{t�<��d��5���0i�XSU��m:��Z�┵�i�"��1�^B�-��P�hJ��&)O��*�D��c�W��vM��)����}���P��ܗ-q����\mmζZ-l@�}��a��E�6��F�@��&Sg@���ݚ�M����� ȹ 4����#p�\H����dYDo�H���"��\��..R�B�H�z_�/5˘����6��KhJR��P�mƶi�m���3�,#c�co��q�a)*Pt����R�m�k�7x�D�E�\Y�閣_X�<���~�)���c[[�BP����6�Yq���S��0����%_����;��Àv�~�| VS؇ ��'O0��F0��\���U�-�d@�����7�SJ*z��3n��y��P����O���������m�~�P�3|Y��ʉr#�C�<�G~�.,! ���bqx���h~0=��!ǫ�jy����l�O,�[B��~��|9��ٱ����Xly�#�i�B��g%�S��������tˋ���e���ې��\[d�t)��.+u�|1 ������#�~Oj����hS�%��i.�~X���I�H�m��0n���c�1uE�q��cF�RF�o���7� �O�ꮧ� ���ۛ{��ʛi5�rw?׌#Qn�TW��~?y$��m\�\o����%W� ?=>S�N@�� �Ʈ���R����N�)�r"C�:��:����� �����#��qb��Y�. �6[��2K����2u�Ǧ�HYR��Q�MV��� �G�$��Q+.>�����nNH��q�^��� ����q��mM��V��D�+�-�#*�U�̒ ���p욳��u:�������IB���m���PV@O���r[b= �� ��1U�E��_Nm�yKbN�O���U�}�the�`�|6֮P>�\2�P�V���I�D�i�P�O;�9�r�mAHG�W�S]��J*�_�G��+kP�2����Ka�Z���H�'K�x�W�MZ%�O�YD�Rc+o��?�q��Ghm��d�S�oh�\�D�|:W������UA�Qc yT�q������~^�H��/��#p�CZ���T�I�1�ӏT����4��"�ČZ�����}��`w�#�*,ʹ�� ��0�i��課�Om�*�da��^gJ݅{���l�e9uF#T�ֲ��̲�ٞC"�q���ߍ ոޑ�o#�XZTp����@ o�8��(jd��xw�]�,f���`~�|,s��^����f�1���t��|��m�򸄭/ctr��5s��7�9Q�4�H1꠲BB@l9@���C�����+�wp�xu�£Yc�9��?`@#�o�mH�s2��)�=��2�.�l����jg�9$�Y�S�%*L������R�Y������7Z���,*=�䷘$�������arm�o�ϰ���UW.|�r�uf����IGw�t����Zwo��~5 ��YյhO+=8fF�)�W�7�L9lM�̘·Y���֘YLf�큹�pRF���99.A �"wz��=E\Z���'a� 2��Ǚ�#;�'}�G���*��l��^"q��+2FQ� hj��kŦ��${���ޮ-�T�٭cf�|�3#~�RJ����t��$b�(R��(����r���dx� >U b�&9,>���%E\� Ά�e�$��'�q't��*�א���ެ�b��-|d���SB�O�O��$�R+�H�)�܎�K��1m`;�J�2�Y~9��O�g8=vqD`K[�F)k�[���1m޼c��n���]s�k�z$@��)!I �x՝"v��9=�ZA=`Ɠi �:�E��)`7��vI��}d�YI�_ �o�:ob���o ���3Q��&D&�2=�� �Ά��;>�h����y.*ⅥS������Ӭ�+q&����j|UƧ����}���J0��WW< ۋS�)jQR�j���Ư��rN)�Gű�4Ѷ(�S)Ǣ�8��i��W52���No˓� ۍ%�5brOn�L�;�n��\G����=�^U�dI���8$�&���h��'���+�(������cȁ߫k�l��S^���cƗjԌE�ꭔ��gF���Ȓ��@���}O���*;e�v�WV���YJ\�]X'5��ղ�k�F��b 6R�o՜m��i N�i����>J����?��lPm�U��}>_Z&�KK��q�r��I�D�Չ~�q�3fL�:S�e>���E���-G���{L�6p�e,8��������QI��h��a�Xa��U�A'���ʂ���s�+טIjP�-��y�8ۈZ?J$��W�P� ��R�s�]��|�l(�ԓ��sƊi��o(��S0��Y� 8�T97.�����WiL��c�~�dxc�E|�2!�X�K�Ƙਫ਼�$((�6�~|d9u+�qd�^3�89��Y�6L�.I�����?���iI�q���9�)O/뚅����O���X��X�V��ZF[�یgQ�L��K1���RҖr@v�#��X�l��F���Нy�S�8�7�kF!A��sM���^rkp�jP�DyS$N���q��nxҍ!U�f�!eh�i�2�m���`�Y�I�9r�6� �TF���C}/�y�^���Η���5d�'��9A-��J��>{�_l+�`��A���[�'��յ�ϛ#w:݅�%��X�}�&�PSt�Q�"�-��\縵�/����$Ɨh�Xb�*�y��BS����;W�ջ_mc�����vt?2}1�;qS�d�d~u:2k5�2�R�~�z+|HE!)�Ǟl��7`��0�<�,�2*���Hl-��x�^����'_TV�gZA�'j� ^�2Ϊ��N7t�����?w�� �x1��f��Iz�C-Ȗ��K�^q�;���-W�DvT�7��8�Z�������� hK�(P:��Q- �8�n�Z���܃e貾�<�1�YT<�,�����"�6{/ �?�͟��|1�:�#g��W�>$����d��J��d�B��=��jf[��%rE^��il:��B���x���Sּ�1հ��,�=��*�7 fcG��#q� �eh?��2�7�����,�!7x��6�n�LC�4x��},Geǝ�tC.��vS �F�43��zz\��;QYC,6����~;RYS/6���|2���5���v��T��i����������mlv��������&� �nRh^ejR�LG�f���? �ۉҬܦƩ��|��Ȱ����>3����!v��i�ʯ�>�v��オ�X3e���_1z�Kȗ\<������!�8���V��]��?b�k41�Re��T�q��mz��TiOʦ�Z��Xq���L������q"+���2ۨ��8}�&N7XU7Ap�d�X��~�׿��&4e�o�F��� �H����O���č�c�� 懴�6���͉��+)��v;j��ݷ�� �UV�� i��� j���Y9GdÒJ1��詞�����V?h��l����l�cGs�ځ�������y�Ac�����\V3�? �� ܙg�>qH�S,�E�W�[�㺨�uch�⍸�O�}���a��>�q�6�n6����N6�q������N ! 1AQaq�0@����"2BRb�#Pr���3C`��Scst���$4D���%Td�� ?���N����a��3��m���C���w��������xA�m�q�m���m������$����4n淿t'��C"w��zU=D�\R+w�p+Y�T�&�պ@��ƃ��3ޯ?�Aﶂ��aŘ���@-�����Q�=���9D��ռ�ѻ@��M�V��P��܅�G5�f�Y<�u=,EC)�<�Fy'�"�&�չ�X~f��l�KԆV��?�� �W�N����=(� �;���{�r����ٌ�Y���h{�١������jW����P���Tc�����X�K�r��}���w�R��%��?���E��m�� �Y�q|����\lEE4���r���}�lsI�Y������f�$�=�d�yO����p�����yBj8jU�o�/�S��?�U��*������ˍ�0������u�q�m [�?f����a�� )Q�>����6#������� ?����0UQ����,IX���(6ڵ[�DI�MNލ�c&���υ�j\��X�R|,4��� j������T�hA�e��^���d���b<����n�� �즇�=!���3�^�`j�h�ȓr��jẕ�c�,ٞX����-����a�ﶔ���#�$��]w�O��Ӫ�1y%��L�Y<�wg#�ǝ�̗`�x�xa�t�w��»1���o7o5��>�m뭛C���Uƃߜ}�C���y1Xνm�F8�jI���]����H���ۺиE@I�i;r�8ӭ����V�F�Շ| ��&?�3|x�B�MuS�Ge�=Ӕ�#BE5G�����Y!z��_e��q�р/W>|-�Ci߇�t�1ޯќd�R3�u��g�=0 5��[?�#͏��q�cf���H��{ ?u�=?�?ǯ���}Z��z���hmΔ�BFTW�����<�q�(v� ��!��z���iW]*�J�V�z��gX֧A�q�&��/w���u�gYӘa���; �i=����g:��?2�dž6�ى�k�4�>�Pxs����}������G�9��3 ���)gG�R<>r h�$��'nc�h�P��Bj��J�ҧH� -��N1���N��?��~��}-q!=��_2hc�M��l�vY%UE�@|�v����M2�.Y[|y�"Eï��K�ZF,�ɯ?,q�?v�M 80jx�"�;�9vk�����+ ֧�� �ȺU��?�%�vcV��mA�6��Qg^M����A}�3�nl� QRN�l8�kkn�'�����(��M�7m9و�q���%ޟ���*h$Zk"��$�9��: �?U8�Sl��,,|ɒ��xH(ѷ����Gn�/Q�4�P��G�%��Ա8�N��!� �&�7�;���eKM7�4��9R/%����l�c>�x;������>��C�:�����t��h?aKX�bhe�ᜋ^�$�Iհ �hr7%F$�E��Fd���t��5���+�(M6�t����Ü�UU|zW�=a�Ts�Tg������dqP�Q����b'�m���1{|Y����X�N��b �P~��F^F:����k6�"�j!�� �I�r�`��1&�-$�Bevk:y���#yw��I0��x��=D�4��tU���P�ZH��ڠ底taP��6����b>�xa����Q�#� WeF��ŮNj�p�J* mQ�N����*I�-*�ȩ�F�g�3 �5��V�ʊ�ɮ�a��5F���O@{���NX��?����H�]3��1�Ri_u��������ѕ�� ����0��� F��~��:60�p�͈�S��qX#a�5>���`�o&+�<2�D����: �������ڝ�$�nP���*)�N�|y�Ej�F�5ټ�e���ihy�Z �>���k�bH�a�v��h�-#���!�Po=@k̆IEN��@��}Ll?j�O������߭�ʞ���Q|A07x���wt!xf���I2?Z��<ץ�T���cU�j��]��陎Ltl �}5�ϓ��$�,��O�mˊ�;�@O��jE��j(�ا,��LX���LO���Ц�90�O �.����a��nA���7������j4 ��W��_ٓ���zW�jcB������y՗+EM�)d���N�g6�y1_x��p�$Lv:��9�"z��p���ʙ$��^��JԼ*�ϭ����o���=x�Lj�6�J��u82�A�H�3$�ٕ@�=Vv�]�'�qEz�;I˼��)��=��ɯ���x �/�W(V���p�����$ �m�������u�����񶤑Oqˎ�T����r��㠚x�sr�GC��byp�G��1ߠ�w e�8�$⿄����/�M{*}��W�]˷.�CK\�ުx���/$�WPw���r� |i���&�}�{�X� �>��$-��l���?-z���g����lΆ���(F���h�vS*���b���߲ڡn,|)mrH[���a�3�ר�[1��3o_�U�3�TC�$��(�=�)0�kgP���� ��u�^=��4 �WYCҸ:��vQ�ר�X�à��tk�m,�t*��^�,�}D*� �"(�I��9R����>`�`��[~Q]�#af��i6l��8���6�:,s�s�N6�j"�A4���IuQ��6E,�GnH��zS�HO�uk�5$�I�4��ؤ�Q9�@��C����wp�BGv[]�u�Ov���0I4���\��y�����Q�Ѹ��~>Z��8�T��a��q�ޣ;z��a���/��S��I:�ܫ_�|������>=Z����8:�S��U�I�J��"IY���8%b8���H��:�QO�6�;7�I�S��J��ҌAά3��>c���E+&jf$eC+�z�;��V����� �r���ʺ������my�e���aQ�f&��6�ND��.:��NT�vm�<- u���ǝ\MvZY�N�NT��-A�>jr!S��n�O 1�3�Ns�%�3D@���`������ܟ 1�^c<���� �a�ɽ�̲�Xë#�w�|y�cW�=�9I*H8�p�^(4���՗�k��arOcW�tO�\�ƍR��8����'�K���I�Q�����?5�>[�}��yU�ײ -h��=��% q�ThG�2�)���"ו3]�!kB��*p�FDl�A���,�eEi�H�f�Ps�����5�H:�Փ~�H�0Dت�D�I����h�F3�������c��2���E��9�H��5�zԑ�ʚ�i�X�=:m�xg�hd(�v����׊�9iS��O��d@0ڽ���:�p�5�h-��t�&���X�q�ӕ,��ie�|���7A�2���O%P��E��htj��Y1��w�Ѓ!����  ���� ࢽ��My�7�\�a�@�ţ�J �4�Ȼ�F�@o�̒?4�wx��)��]�P��~�����u�����5�����7X ��9��^ܩ�U;Iꭆ 5 �������eK2�7(�{|��Y׎ �V��\"���Z�1� Z�����}��(�Ǝ"�1S���_�vE30>���p;� ΝD��%x�W�?W?v����o�^V�i�d��r[��/&>�~`�9Wh��y�;���R��� ;;ɮT��?����r$�g1�K����A��C��c��K��l:�'��3 c�ﳯ*"t8�~l��)���m��+U,z��`(�>yJ�?����h>��]��v��ЍG*�{`��;y]��I�T� ;c��NU�fo¾h���/$���|NS���1�S�"�H��V���T���4��uhǜ�]�v;���5�͠x��'C\�SBpl���h}�N����� A�Bx���%��ޭ�l��/����T��w�ʽ]D�=����K���ž�r㻠l4�S�O?=�k �M:� ��c�C�a�#ha���)�ѐxc�s���gP�iG��{+���x���Q���I= �� z��ԫ+ �8"�k�ñ�j=|����c ��y��CF��/��*9ж�h{ �?4�o� ��k�m�Q�N�x��;�Y��4膚�a�w?�6�>e]�����Q�r�:����g�,i"�����ԩA�*M�<�G��b�if��l^M��5� �Ҩ�{����6J��ZJ�����P�*�����Y���ݛu�_4�9�I8�7���������,^ToR���m4�H��?�N�S�ѕw��/S��甍�@�9H�S�T��t�ƻ���ʒU��*{Xs�@����f�����֒Li�K{H�w^���������Ϥm�tq���s� ���ք��f:��o~s��g�r��ט� �S�ѱC�e]�x���a��) ���(b-$(�j>�7q�B?ӕ�F��hV25r[7 Y� }L�R��}����*sg+��x�r�2�U=�*'WS��ZDW]�WǞ�<��叓���{�$�9Ou4��y�90-�1�'*D`�c�^o?(�9��u���ݐ��'PI&� f�Jݮ�������:wS����jfP1F:X �H�9dԯ���˝[�_54 �}*;@�ܨ�� ð�yn�T���?�ןd�#���4rG�ͨ��H�1�|-#���Mr�S3��G�3�����)�.᧏3v�z֑��r����$G"�`j �1t��x0<Ɔ�Wh6�y�6��,œ�Ga��gA����y��b��)��h�D��ß�_�m��ü �gG;��e�v��ݝ�nQ� ��C����-�*��o���y�a��M��I�>�<���]obD��"�:���G�A��-\%LT�8���c�)��+y76���o�Q�#*{�(F�⽕�y����=���rW�\p���۩�c���A���^e6��K������ʐ�cVf5$�'->���ՉN"���F�"�UQ@�f��Gb~��#�&�M=��8�ט�JNu9��D��[̤�s�o�~������ G��9T�tW^g5y$b��Y'��س�Ǵ�=��U-2 #�MC�t(�i� �lj�@Q 5�̣i�*�O����s�x�K�f��}\��M{E�V�{�υ��Ƈ�����);�H����I��fe�Lȣr�2��>��W�I�Ȃ6������i��k�� �5�YOxȺ����>��Y�f5'��|��H+��98pj�n�.O�y�������jY��~��i�w'������l�;�s�2��Y��:'lg�ꥴ)o#'Sa�a�K��Z� �m��}�`169�n���"���x��I ��*+� }F<��cГ���F�P�������ֹ*�PqX�x۩��,� ��N�� �4<-����%����:��7����W���u�`����� $�?�I��&����o��o��`v�>��P��"��l���4��5'�Z�gE���8���?��[�X�7(��.Q�-��*���ތL@̲����v��.5���[��=�t\+�CNܛ��,g�SQnH����}*F�G16���&:�t��4ُ"A��̣��$�b �|����#rs��a�����T�� ]�<�j��BS�('$�ɻ� �wP;�/�n��?�ݜ��x�F��yUn�~mL*-�������Xf�wd^�a�}��f�,=t�׵i�.2/wpN�Ep8�OР���•��R�FJ� 55TZ��T �ɭ�<��]��/�0�r�@�f��V��V����Nz�G��^���7hZi����k��3�,kN�e|�vg�1{9]_i��X5y7� 8e]�U����'�-2,���e"����]ot�I��Y_��n�(JҼ��1�O ]bXc���Nu�No��pS���Q_���_�?i�~�x h5d'�(qw52] ��'ޤ�q��o1�R!���`ywy�A4u���h<קy���\[~�4�\ X�Wt/� 6�����n�F�a8��f���z �3$�t(���q��q�x��^�XWeN'p<-v�!�{�(>ӽDP7��ո0�y)�e$ٕv�Ih'Q�EA�m*�H��RI��=:��� ���4牢) �%_iN�ݧ�l]� �Nt���G��H�L��� ɱ�g<���1V�,�J~�ٹ�"K��Q�� 9�HS�9�?@��k����r�;we݁�]I�!{ �@�G�[�"��`���J:�n]�{�cA�E����V��ʆ���#��U9�6����j�#Y�m\��q�e4h�B�7��C�������d<�?J����1g:ٳ���=Y���D�p�ц� ׈ǔ��1�]26؜oS�'��9�V�FVu�P�h�9�xc�oq�X��p�o�5��Ա5$�9W�V(�[Ak�aY錎qf;�'�[�|���b�6�Ck��)��#a#a˙��8���=äh�4��2��C��4tm^ �n'c���]GQ$[Wҿ��i���vN�{Fu ��1�gx��1┷���N�m��{j-,��x�� Ūm�ЧS�[�s���Gna���䑴�� x�p 8<������97�Q���ϴ�v�aϚG��Rt�Һ׈�f^\r��WH�JU�7Z���y)�vg=����n��4�_)y��D'y�6�]�c�5̪�\� �PF�k����&�c;��cq�$~T�7j ���nç]�<�g ":�to�t}�159�<�/�8������m�b�K#g'I'.W�����6��I/��>v��\�MN��g���m�A�yQL�4u�Lj�j9��#44�t��l^�}L����n��R��!��t��±]��r��h6ٍ>�yҏ�N��fU�� ���� Fm@�8}�/u��jb9������he:A�y�ծw��GpΧh�5����l}�3p468��)U��d��c����;Us/�֔�YX�1�O2��uq�s��`hwg�r~�{ R��mhN��؎*q 42�*th��>�#���E����#��Hv�O����q�}�����6�e��\�,Wk�#���X��b>��p}�դ��3���T5��†��6��[��@�P�y*n��|'f�֧>�lư΂�̺����SU�'*�q�p�_S�����M�� '��c�6�����m�� ySʨ;M��r���Ƌ�m�Kxo,���Gm�P��A�G�:��i��w�9�}M(�^�V��$ǒ�ѽ�9���|���� �a����J�SQ�a���r�B;����}���ٻ֢�2�%U���c�#�g���N�a�ݕ�'�v�[�OY'��3L�3�;,p�]@�S��{ls��X�'���c�jw�k'a�.��}�}&�� �dP�*�bK=ɍ!����;3n�gΊU�ߴmt�'*{,=SzfD� A��ko~�G�aoq�_mi}#�m�������P�Xhύ����mxǍ�΂���巿zf��Q���c���|kc�����?���W��Y�$���_Lv����l߶��c���`?����l�j�ݲˏ!V��6����U�Ђ(A���4y)H���p�Z_�x��>���e��R��$�/�`^'3qˏ�-&Q�=?��CFVR �D�fV�9��{�8g�������n�h�(P"��6�[�D���< E�����~0<@�`�G�6����Hг�cc�� �c�K.5��D��d�B���`?�XQ��2��ٿyqo&+�1^� DW�0�ꊩ���G�#��Q�nL3��c���������/��x ��1�1[y�x�პCW��C�c�UĨ80�m�e�4.{�m��u���I=��f�����0QRls9���f���������9���~f�����Ǩ��a�"@�8���ȁ�Q����#c�ic������G��$���G���r/$W�(��W���V�"��m�7�[m�A�m����bo��D� j����۳� l���^�k�h׽����� ��#� iXn�v��eT�k�a�^Y�4�BN��ĕ��0 !01@Q"2AaPq3BR������?���@4�Q�����T3,���㺠�W�[=JK�Ϟ���2�r^7��vc�:�9 �E�ߴ�w�S#d���Ix��u��:��Hp��9E!�� V 2;73|F��9Y���*ʬ�F��D����u&���y؟��^EA��A��(ɩ���^��GV:ݜDy�`��Jr29ܾ�㝉��[���E;Fzx��YG��U�e�Y�C���� ����v-tx����I�sם�Ę�q��Eb�+P\ :>�i�C'�;�����k|z�رn�y]�#ǿb��Q��������w�����(�r|ӹs��[�D��2v-%��@;�8<a���[\o[ϧw��I!��*0�krs)�[�J9^��ʜ��p1)� "��/_>��o��<1����A�E�y^�C��`�x1'ܣn�p��s`l���fQ��):�l����b>�Me�jH^?�kl3(�z:���1ŠK&?Q�~�{�ٺ�h�y���/�[��V�|6��}�KbX����mn[-��7�5q�94�������dm���c^���h� X��5��<�eޘ>G���-�}�دB�ޟ� ��|�rt�M��V+�]�c?�-#ڛ��^ǂ}���Lkr���O��u�>�-D�ry� D?:ޞ�U��ǜ�7�V��?瓮�"�#���r��չģVR;�n���/_� ؉v�ݶe5d�b9��/O��009�G���5n�W����JpA�*�r9�>�1��.[t���s�F���nQ� V 77R�]�ɫ8����_0<՜�IF�u(v��4��F�k�3��E)��N:��yڮe��P�`�1}�$WS��J�SQ�N�j�ٺ��޵�#l���ј(�5=��5�lǏmoW�v-�1����v,W�mn��߀$x�<����v�j(����c]��@#��1������Ǔ���o'��u+����;G�#�޸��v-lη��/(`i⣍Pm^���ԯ̾9Z��F��������n��1��� ��]�[��)�'������:�֪�W��FC����� �B9،!?���]��V��A�Վ�M��b�w��G F>_DȬ0¤�#�QR�[V��kz���m�w�"��9ZG�7'[��=�Q����j8R?�zf�\a�=��O�U����*oB�A�|G���2�54 �p��.w7� �� ��&������ξxGHp� B%��$g�����t�Џ򤵍z���HN�u�Я�-�'4��0��;_��3 !01"@AQa2Pq#3BR������?��ʩca��en��^��8���<�u#��m*08r��y�N"�<�Ѳ0��@\�p��� �����Kv�D��J8�Fҽ� �f�Y��-m�ybX�NP����}�!*8t(�OqѢ��Q�wW�K��ZD��Δ^e��!� ��B�K��p~�����e*l}z#9ң�k���q#�Ft�o��S�R����-�w�!�S���Ӥß|M�l޶V��!eˈ�8Y���c�ЮM2��tk���� ������J�fS����Ö*i/2�����n]�k�\���|4yX�8��U�P.���Ы[���l��@"�t�<������5�lF���vU�����W��W��;�b�cД^6[#7@vU�xgZv��F�6��Q,K�v��� �+Ъ��n��Ǣ��Ft���8��0��c�@�!�Zq s�v�t�;#](B��-�nῃ~���3g������5�J�%���O������n�kB�ĺ�.r��+���#�N$?�q�/�s�6��p��a����a��J/��M�8��6�ܰ"�*������ɗud"\w���aT(����[��F��U՛����RT�b���n�*��6���O��SJ�.�ij<�v�MT��R\c��5l�sZB>F��<7�;EA��{��E���Ö��1U/�#��d1�a�n.1ě����0�ʾR�h��|�R��Ao�3�m3 ��%�� ���28Q� ��y��φ���H�To�7�lW>����#i`�q���c����a��� �m,B�-j����݋�'mR1Ήt�>��V��p���s�0IbI�C.���1R�ea�����]H�6����������4B>��o��](��$B���m�����a�!=��?�B� K�Ǿ+�Ծ"�n���K��*��+��[T#�{E�J�S����Q�����s�5�:�U�\wĐ�f�3����܆&�)����I���Ԇw��E T�lrTf6Q|R�h:��[K�� �z��c֧�G�C��%\��_�a�84��HcO�bi��ؖV��7H �)*ģK~Xhչ0��4?�0��� �E<���}3���#���u�?�� ��|g�S�6ꊤ�|�I#Hڛ� �ա��w�X��9��7���Ŀ%�SL��y6č��|�F�a 8���b��$�sק�h���b9RAu7�˨p�Č�_\*w��묦��F ����4D~�f����|(�"m���NK��i�S�>�$d7SlA��/�²����SL��|6N�}���S�˯���g��]6��; �#�.��<���q'Q�1|KQ$�����񛩶"�$r�b:���N8�w@��8$�� �AjfG|~�9F ���Y��ʺ��Bwؒ������M:I岎�G��`s�YV5����6��A �b:�W���G�q%l�����F��H���7�������Fsv7��k�� 403WebShell
403Webshell
Server IP : 54.89.25.11  /  Your IP : 216.73.216.121
Web Server : Apache/2.4.7 (Ubuntu)
System : Linux ip-172-31-88-18 3.13.0-74-generic #118-Ubuntu SMP Thu Dec 17 22:52:10 UTC 2015 x86_64
User : www-data ( 33)
PHP Version : 5.5.9-1ubuntu4.24
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,
MySQL : ON  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : ON
Directory :  /proc/self/root/var/www/html/kalemon/module/Secure/src/Secure/View/Helper/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /proc/self/root/var/www/html/kalemon/module/Secure/src/Secure/View/Helper/CommonHelper1.php
<?php
/**
 * CommonHelper
 * common functions use in each view of modules 
 *
 * @package      ZF2
 * @subpackage   View
 * @author       Arun Kr Vishwakarma <arun.vishwakarma@pironcorp.com>
 * @created on   9 June, 2016
 */

namespace Secure\View\Helper;

use Zend\View\Helper\AbstractHelper;
use Zend\View\HelperPluginManager as ServiceManager;
use Secure\Model\CommonTable;
use Secure\Model\Grade\GradeTable;
use Secure\Model\Admgrade\AdmgradeTable;
use B2cstudent\Model\B2cstudentTable;
use Secure\Model\Administrator\DistrictTable;
use Student\Model\StudentTable;
use Secure\Model\Atb\AtbTable;
use Secure\Model\TrackingTable;
use Secure\Model\Message\MessageTable;
use Secure\Model\Assignment\AssignmentTable;
use Secure\Model\UserManagement\UserManagementTable;
use Secure\Model\Quiz\QuizTable;
use Secure\Model\Administrator\AdministratorTable;
use Secure\Model\Attendence\AttendenceTable;
use Secure\Model\SchoolBook\BookTable;
use Curriculum\Model\CurriculumTable;
use Application\Model\AskQuestionTable;
use Standard\Model\StandardTable;
use Assessment\Model\CreateQuizTable;
use Zend\Db\ResultSet\ResultSet;
use Zend\Db\TableGateway\TableGateway;
use Zend\Session\Container;
use Secure\Controller\AtbController;
use DateTime;
use Aws\Sdk;
use DateInterval;
use DatePeriod;
use Crocodoc;
use CrocodocDocument;
use CrocodocException;
use CrocodocSession;
use Checkondispatch\Custom\CommonFunctionTrait;

class CommonHelper extends AbstractHelper {

    protected $ServiceManager;
    protected $adapter;
    public $sm;

    use CommonFunctionTrait;

    public function __construct(ServiceManager $serviceManager) {
        $this->adapter = $serviceManager->getServiceLocator()->get('Zend\Db\Adapter\Adapter');
        $this->container = new Container('auth');
        //$this->container = new Container('path');
        $this->sm = $serviceManager->getServiceLocator();
    }

    public function getCrocodocSessionKey($apiToken = null, $uuid = null) {
        $baseDirPath = getcwd() . '/library/';
        require_once ($baseDirPath . 'crocodoc/Crocodoc.php');
        Crocodoc::setApiToken($apiToken);
        $sessionKey = null;

        $userid = $this->container->authDetail['USER_OID'];
        $username = $this->getUserFullName($userid);

        try {
            //$sessionKey = CrocodocSession::create($uuid);
            //echo 'success :)' . "\n";
            //echo '  The session key is ' . $sessionKey . '.' . "\n";

            $sessionKey = CrocodocSession::create($uuid, array(
                        'isEditable' => true,
                        'user' => array(
                            'id' => $userid,
                            'name' => $username,
                        ),
                        'filter' => 'all',
                        'isAdmin' => false,
                        'isDownloadable' => false,
                        'isCopyprotected' => true,
                        'isDemo' => false,
                        'sidebar' => 'auto',
            ));
        } catch (CrocodocException $e) {
            echo 'failed :(' . "\n";
            echo '  Error Code: ' . $e->errorCode . "\n";
            echo '  Error Message: ' . $e->getMessage() . "\n";
        }

        return $sessionKey;
    }

    public function getTestDetailById($testId) {
        $tblObj = new AssignmentTable($this->adapter);
        return $tblObj->getTestDetailById($testId);
    }

    public function checkTebianLp($lpId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->checkTebianLp($lpId);
    }

    public function getResultOfPT($testId, $levelId, $studentId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getResultOfPT($testId, $levelId, $studentId);
    }

    /**
     * @desc used to get attempt count if quiz attempted.
     * @param integer $testId
     * @param integer $levelId
     * @param integer $studentId
     * @return integer ( attempt count)
     */
    public function isTestAttempted($testId, $levelId, $studentId = null) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->isTestAttempted($testId, $levelId, $studentId);
    }

    public function getQuizTypeByAttemptId($attempt_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getQuizTypeByAttemptId($attempt_id);
    }

    public function getLPidByAttemptId($attempt_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getLPidByAttemptId($attempt_id);
    }

    //  get content type by cont type id
    function getContType($cont_type_id) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getContType($cont_type_id);
    }

    //  get topics  by content Id
    function getTopicIdsByContId($contId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getTopicIdsByContId($contId);
    }

    function getSubjectIdbyContID($CONT_ID) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getSubjectIdbyContID($CONT_ID);
    }

    public function getLPidByAttemptIdB2c($attempt_id) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getLPidByAttemptId($attempt_id);
    }

    public function getQuizAttempts($attemptId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getQuizAttempts($attemptId);
    }

    public function getNextPlc($user_id, $gradeId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getNextPlc($user_id, $gradeId);
    }

    public function getAllMenu($parent = 0, $spacing = '', $user_tree_array = '') {
        $tblObj = new DistrictTable($this->adapter);
        return $tblObj->getAllMenu($parent, $spacing = '', $user_tree_array = '');
    }

    public function getAllSubMenu($parent) {
        $tblObj = new DistrictTable($this->adapter);
        return $tblObj->getAllSubMenu($parent);
    }

    public function hasChild($parent) {
        $tblObj = new DistrictTable($this->adapter);
        return $tblObj->hasChild($parent, $spacing = '', $user_tree_array = '');
    }

    //  get first image of image content 
    function getFirstContentImage($contId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getFirstContentImage($contId);
    }

    //  get first image of image content 
    function getFirstContentAdmImage($contId) {
        $tblObj = new AdmGradeTable($this->adapter);
        return $tblObj->getFirstContentImage($contId);
    }

    public function getCourseTestDetails($contentId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getCourseTestDetails($contentId);
    }

    function getDetails($table, $conditions, $columns, $orderBy = null, $resultType = false, $length = '', $start = '') {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getDetails($table, $conditions, $columns, $orderBy, $resultType, $length, $start);
    }

    public function getBookHashByStudentBookId($stdbookid) {
        $tblObj = new BookTable($this->adapter);
        return $tblObj->getBookHashByStudentBookId($stdbookid);
    }

    public function getBookHashByContId($contId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getBookHashByContId($contId);
    }

    public function getLpNameById($lpId) {
        $tblObj = new GradeTable($this->adapter);
        $data = $tblObj->getLpNameById($lpId);
        return isset($data[0]['LP_NAME']) ? $data[0]['LP_NAME'] : '';
    }

    public function checkLoExist($LO_ID, $parentCat) {
        $tblObj = new GradeTable($this->adapter);
        $data = $tblObj->checkLoExist($LO_ID, $parentCat);
        return $data;
    }

    public function checkLoExistForB2c($LO_ID, $parentCat) {
        $tblObj = new AdmGradeTable($this->adapter);
        $data = $tblObj->checkLoExist($LO_ID, $parentCat);
        return $data;
    }

    public function checkACLInDB($aclId) {
        $tblObj = new AtbTable($this->adapter);
        return $tblObj->checkACLInDB($aclId);
    }

    public function getUserIdByAtbUserId($atbUserId) {
        $tblObj = new UserManagementTable($this->adapter);
        return $tblObj->getUserIdByAtbUserId($atbUserId);
    }

    public function getUserEmail($userId) {
        $tblObj = new UserManagementTable($this->adapter);
        return $tblObj->getUserEmail($userId);
    }

    public function getlessionplanIdeExistcheck($catId) {
        $tblObj = new CurriculumTable($this->adapter);
        return $tblObj->getlessionplanIdeExistcheck($catId);
    }

    public function getlessionplanIdeExistcheckForb2c($catId) {
        $tblObj = new StandardTable($this->adapter);
        return $tblObj->getlessionplanIdeExistcheck($catId);
    }

    public function getEnricmentExistcheck($catId) {
        $tblObj = new StandardTable($this->adapter);
        return $tblObj->getEnricmentExistcheck($catId);
    }
    public function getstandard($countryId) {
        $tblObj = new StandardTable($this->adapter);
        return $tblObj->getStandardsb2cByCountryId($countryId);
    }
    public function getGardebyStandardId($standardId){
        $tblObj = new GradeTable($this->adapter);
       return $className = $tblObj->getGardebyStandardId($standardId);
    }
    public function getsubjectbygradeId($gradeId){
         $tblObj = new GradeTable($this->adapter);
       return $className = $tblObj->getsubjectbygradeId($gradeId);
    }

    // get parent all topic 
    public function getAllChildCatByParent($admSubjectId, $catId) {
        $tblObj = new CurriculumTable($this->adapter);
        return $tblObj->getAllChildCatByParent($admSubjectId, $catId);
    }

    public function getAllChildCatByParentForb2c($admSubjectId, $catId) {
        $tblObj = new StandardTable($this->adapter);
        return $tblObj->getAllChildCatByParent($admSubjectId, $catId);
    }

    public function getUnreadMsg($user_oid) {
        $tblObj = new MessageTable($this->adapter);
        return $tblObj->getUnreadMsg($user_oid);
    }

    public function checkEnrContByPath($path) {
        $tblObj = new AdministratorTable($this->adapter);
        return $tblObj->checkEnrContByPath($path);
    }

    public function getUnreadMsgDetail($user_oid) {
        $tblObj = new MessageTable($this->adapter);
        return $tblObj->getUnreadMsgDetail($user_oid);
    }

    public function getUserFullName($userid = null) {
        $tblObj = new CommonTable($this->adapter);
        if (empty($userid)) {
            $userid = $this->container->authDetail['USER_OID'];
        }
        return $tblObj->getUserFullName($userid);
    }

    public function getAssignmentIdByContentId($content_id) {
        $tblObj = new AssignmentTable($this->adapter);
        return $tblObj->getAssignmentIdByContentId($content_id);
    }

    public function getAllSubmission($assignment_id, $user_id) {
        $tblObj = new AssignmentTable($this->adapter);
        return $tblObj->getAllSubmission($assignment_id, $user_id);
    }

    public function isLogged() {
        $userid = 0;
        if (!empty($this->container->authDetail['USER_OID'])) {
            $userid = $this->container->authDetail['USER_OID'];
        }
        return $userid;
    }

    public function getUtid() {
        $utid = 0;
        if (!empty($this->container->authDetail['UT_ID'])) {
            $utid = $this->container->authDetail['UT_ID'];
        }
        return $utid;
    }

    public function getUserSessionData() {

        if (!empty($this->container->authDetail)) {
            return $this->container->authDetail;
        }
        return array();
    }

    /**
     * @desc Get student's quiz related response data via session.
     * @return type
     */
    public function getQuizSessionData() {
        return (!empty($this->container->studentQuizResponse)) ? $this->container->studentQuizResponse : array();
    }

    public function checkSubscribedmsg() {

        if (!empty($this->container->subscribe)) {
            return true;
        }
        return false;
    }

    public function unsetSubscribedmsg() {
        $this->container->subscribe = null;
    }

    public function checkFailTrans() {

        if (!empty($this->container->failtrans)) {
            return true;
        }
        return false;
    }

    public function unsetFailTrans() {
        $this->container->failtrans = null;
    }

    public function getAliasName() {
        if (!empty($this->container->authDetail['USER_ALIAS'])) {
            return $this->container->authDetail['USER_ALIAS'];
        }
        return $this->container->authDetail['USER_OID'];
    }

    public function getLoggedId() {
        if (!empty($this->container->authDetail['USER_OID'])) {
            return $this->container->authDetail['USER_OID'];
        }
        return 0;
    }

    public function getOrgId() {
        if (!empty($this->container->authDetail['ORG_ID'])) {
            return $this->container->authDetail['ORG_ID'];
        }
        return 0;
    }

    //get atb book details by book hash
    public function atbBookDetails($id) {
        $atbController = new AtbController();
        $config = $this->sm->get('config');
        $retData = $atbController->atbBookDetails($config, $id);
        $retData['atbBaseUrl'] = $config['atbBaseUrl'];
        return $retData;
    }

    //get atb book details by book Id
    public function getBookPublicDetails($book_id) {
        $tblObj = new AtbTable($this->adapter);
        return $tblObj->getBookPublicDetails($book_id);
    }

    //  get Assignment id by content Id
    function getAssignmentByContentId($contId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getAssignmentByContentId($contId);
    }

    //  get lessonplan id by content Id
    function getLessonplanIdByContentId($contId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getLessonplanIdByContentId($contId);
    }

    function getLessonplanIdByContentIdForAdm($contId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getLessonplanIdByContentId($contId);
    }

    //get Batch grade by class ID
    function getClassGrade($grade_id) {
        $tblObj = new GradeTable($this->adapter);
        $className = $tblObj->getGardeName($grade_id);
        return $className;
    }

    //get Book name and Description
    function getBookDetailByBookId($book_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getBookDetailByBookId($book_id);
    }

    // get Active content ids 
    function getAllActiveContentOfLp($lpId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getAllActiveContentOfLp($lpId);
    }

    //total content of lessonplan
    function countContentOfLp($lpId) {
        $tblObj = new GradeTable($this->adapter);
        $data = $tblObj->countContentOfLp($lpId);
        return (!empty($data[0]['COUNT_CONTENT'])) ? $data[0]['COUNT_CONTENT'] : 0;
    }

    //content ids of lessonplan
    function getContentIdsByLpId($lpId) {
        $tblObj = new GradeTable($this->adapter);
        $data = $tblObj->getContentIdsByLpId($lpId);
        return (!empty($data)) ? $data : 0;
    }

    function getContentIdsByLpIdForB2c($lpId) {
        $tblObj = new AdmgradeTable($this->adapter);
        $data = $tblObj->getContentIdsByLpId($lpId);
        return (!empty($data)) ? $data : 0;
    }

    //get startus of content
    function getStatusOfContent($params) {
        if (empty($params['USER_OID']))
            $params['USER_OID'] = $this->container->authDetail['USER_OID'];
        $tblObj = new TrackingTable($this->adapter);
        return $tblObj->getStatusOfContent($params);
    }

    //total completed contents of lessonplan
    function countCompletedContentOfLp($params) {
        if (empty($params['USER_OID']))
            $params['USER_OID'] = $this->container->authDetail['USER_OID'];
        $tblObj = new TrackingTable($this->adapter);
        return $tblObj->countCompletedContentOfLp($params);
    }

    //get latest activity of lesson plan
    function getLatestActivityOfLp($params) {
        if (empty($params['USER_OID']))
            $params['USER_OID'] = $this->container->authDetail['USER_OID'];
        $tblObj = new TrackingTable($this->adapter);
        return $tblObj->getLatestActivityOfLp($params);
    }

    //get topics from LP ID
    function getTopicsFromLpId($lpId) {
        $tblObj = new GradeTable($this->adapter);
        $data = $tblObj->getTopicsFromLpId($lpId);
        return $data;
    }

    //get content multi images
    function getContentImages($contId) {
        $tblObj = new GradeTable($this->adapter);
        $contImgData = $tblObj->getContentImages($contId);
        return $contImgData;
    }

    //get content multi images
    function getAdmContentImages($contId) {
        $tblObj = new AdmgradeTable($this->adapter);
        $contImgData = $tblObj->getContentImages($contId);
        return $contImgData;
    }

    function getSubjectDetailById($id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getSubjectDetailById($id);
    }

    function getSubjectDetailByIdB2c($id) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getSubjectDetailById($id);
    }

    function getSubjectDetail($subjectId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getSubjectDetail($subjectId);
    }

    // get batch name from batch id
    function getBatchName($BATCH_ID) {
        $tblObj = new GradeTable($this->adapter);
        $className = $tblObj->getBatchName($BATCH_ID);
        return $className;
    }

    function getBookListByOrderId($book_order_id) {

        $tblObj = new AdministratorTable($this->adapter);
        return $tblObj->getBookListByOrderId($book_order_id);
    }

    function getCountrieName($country_id) {
        $tblObj = new AdministratorTable($this->adapter);
        return $tblObj->getCountrieName($country_id);
    }

    function getBatchIdByGradeId($gardeid) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getBatchIdByGradeId($gardeid);
    }

    function getGrades($batch_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getGrades($batch_id);
    }

    function getGradeDetails($gradeId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getGradeDetails($gradeId);
    }

    function getQuizIdByContentId($content_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getQuizIdByContentId($content_id);
    }

    function sumQusetion($quizId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->sumQusetion($quizId);
    }

    function sumQusetionB2c($quizId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->sumQusetion($quizId);
    }

    function getContVal($lpid, $content_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getContVal($lpid, $content_id);
    }

    function getBatch($org_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getBatch($org_id);
    }

    //get Batch grade by class ID
    function getClassTeacher($teacher_id) {
        $tblObj = new UserManagementTable($this->adapter);
        $name = $tblObj->getUserName($teacher_id);
        return $name;
    }

    //get user name by user id
    function getUserName($user_oid) {
        $tblObj = new UserManagementTable($this->adapter);
        $name = $tblObj->getUserName($user_oid);
        return $name;
    }

    //get no of users by class ID
    function getNoOfUsers($classId) {
        $tblObj = new UserManagementTable($this->adapter);
        return $tblObj->countUserEnrollmentByClassId($classId);
    }

    //count members of class
    function countMemberOfClass($classId) {
        $tblObj = new GradeTable($this->adapter);
        $classMember = $tblObj->countMemberOfClass($classId);
        return $classMember[0]['TOTAL_MEMBER'];
    }

    //get user profile image
    public function getUserProfileImage($userId) {
        $tblObj = new UserManagementTable($this->adapter);
        $img = $tblObj->getUserProfileImage($userId);
        return $img;
    }

    //get user profile image
    public function getSectionBySectionId($Id) {
        $tblObj = new UserManagementTable($this->adapter);
        $name = $tblObj->getSectionDetail($Id);
        return $name['SECTION_NAME'];
    }

    //get author name by id
    function getAutherNameById($id) {
        $tblObj = new AdministratorTable($this->adapter);
        return $tblObj->getAuthorNameById($id);
    }

    //get Detail by id
    function getAuthorDetail($id) {
        $tblObj = new AdministratorTable($this->adapter);
        return $tblObj->getAuthorDetail($id);
    }

    public function getPublisherDetail($id) {
        $tblObj = new AdministratorTable($this->adapter);
        return $tblObj->getPublisherDetail($id);
    }

    //get publisher name by id
    function getPublisherNameById($id) {
        $tblObj = new AdministratorTable($this->adapter);
        return $tblObj->getPublisherNameById($id);
    }

    //get subject
    function getSubjectLP($grade_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getSubjectByGrade($grade_id);
    }

    function getGradeIdBySubjectId($subjectId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getGradeIdBySubjectId($subjectId);
    }

    //get subject
    function getTopicLP($subject_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getTopicBySubject($subject_id);
    }

    function getAllTopic($lession_plan_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getAllTopic($lession_plan_id);
    }

    function getSubjectID($cat_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getSubjectID($cat_id);
    }

    function getContentTypeNameById($contTypeId) {
        $tblObj = new GradeTable($this->adapter);
        return $contType = $tblObj->getContentTypeById($contTypeId);
    }

    //get enrich content by id
    function getEnrichmentContentById($id) {
        $tblObj = new AdministratorTable($this->adapter);
        return $tblObj->getEnrichmentContentById($id);
    }

    //adding padd with number
    function numberPadded($number) {
        if ($number < 10 && $number > 0) {
            $number = sprintf("%02d", $number);
        }
        return $number;
    }

    //seconds to minutes
    function minutes($seconds) {
        return sprintf("%02.2d:%02.2d", floor($seconds / 60), $seconds % 60);
    }

    //calc ago date from given timeline
    function time2string($timeline) {
        $ret = '';
        $periods = array('day' => 86400, 'hour' => 3600, 'min' => 60, 'second' => 1);
        $replace = array(); //new
        foreach ($periods AS $name => $seconds) {
            $num = floor($timeline / $seconds);
            $timeline -= ($num * $seconds);
            $ret .= $num . ' ' . $name . (($num > 1) ? 's' : '') . ' ';
            $replace[] = $num; //new
        }
        $ret = trim($ret);
        $stChar = $ret[0];

        if ($stChar == '-') {
            $ret = str_replace('-1 day ', '', $ret);
        }
        return ucwords($ret);

        $text = $TRANS_ACT_REP1;
        $ex = explode("x", $text);
        if (count($ex) != 5)
            $ex = explode("X", $text);
        $text1 = $ex[0] . ' x1 ' . $ex[1] . ' x2 ' . $ex[2] . ' x3 ' . $ex[3] . ' x4 ' . $ex[4];
        $find = array('x1', 'x2', 'x3', 'x4');
        return str_replace($find, $replace, $text1);
    }

    function getTimeGap($insertionDate) {

        $translator = $this->sm->get('translator');
        $start_date = new DateTime($insertionDate);
        $diff = $start_date->diff(new DateTime(date("Y-m-d h:i:s")));

        $showString = '';
        if ($diff->y != 0) {

            $showString .= $diff->y . ' ' . $translator->translate("Year") . ', ';
        }
        if ($diff->m != 0) {
            $showString .= $diff->m . ' ' . $translator->translate("Month") . ', ';
        }
        if ($diff->d != 0) {
            $showString .= $diff->d . ' ' . $translator->translate("Days") . ', ';
        }
        if ($diff->h != 0) {
            $showString .= $diff->h . ' ' . $translator->translate("Hour") . ', ';
        }
        if ($diff->i != 0) {
            $showString .= $diff->i . ' ' . $translator->translate("Minutes") . ' ';
        }
        /*
          if ($diff->s != 0) {
          $showString.=$diff->s . ' '.$translator->translate("Seconds").' ';
          }
         */
        if (empty($showString)) {
            $showString = "0 " . $translator->translate("Minute");
        }
        return $showString . " " . $translator->translate("Ago");
    }

    function formatSizeUnits($bytes) {
        if ($bytes >= 1073741824) {
            $bytes = number_format($bytes / 1073741824, 2) . ' GB';
        } elseif ($bytes >= 1048576) {
            $bytes = number_format($bytes / 1048576, 2) . ' MB';
        } elseif ($bytes >= 1024) {
            $bytes = number_format($bytes / 1024, 2) . ' kB';
        } elseif ($bytes > 1) {
            $bytes = $bytes . ' bytes';
        } elseif ($bytes == 1) {
            $bytes = $bytes . ' byte';
        } else {
            $bytes = '0 bytes';
        }

        return $bytes;
    }

    function getOpenBookUrl($config, $book_hash) {
        $atb = new AtbController();
        return $atb->getOpenBookUrl($config, $book_hash);
    }

    function getPrerequisite($lession_plan_id) {
        $grade = new GradeTable($this->adapter);
        return $grade->getPrerequisite($lession_plan_id);
    }

    function getContentListByLpId($lession_plan_id, $publish = null) {
        $grade = new GradeTable($this->adapter);
        return $grade->getContentListByLpId($lession_plan_id, $publish);
    }

    function getContentListByLpIdForB2c($lession_plan_id, $publish = null) {
        $grade = new AdmgradeTable($this->adapter);
        return $grade->getContentListByLpId($lession_plan_id, $publish);
    }

    function getSubjectByGradeAndOrgId($grade_id, $org_id) {
        $grade = new GradeTable($this->adapter);
        return $grade->getSubjectByGradeAndUserOId($grade_id, $org_id);
    }

    /**
     * @desc use of this for convert time to second
     */
    function timeToSeconds($time) {
        $timeExploded = explode(':', $time);
        if (isset($timeExploded[2])) {
            return $timeExploded[0] * 3600 + $timeExploded[1] * 60 + $timeExploded[2];
        }
        return $timeExploded[0] * 3600 + $timeExploded[1] * 60;
    }

    /*     * ********************************  Tracking Functionality Start ****************************** */

    function getAudioVideoActivityDataFromDynamoDb($params) {
        $tbl = new TrackingTable($this->adapter);
        $response = $tbl->getActivityData($params);

        /*
          $aws    = $this->sm->get(Sdk::class);
          $client = $aws->createDynamoDb();

          $userId = (string) $params['userId'];
          $productId = (string) $params['productId'];

          $response = $client->query([
          'TableName' => 'VideoActivity',
          'KeyConditionExpression' => 'userId = :userId and productId = :productId',
          'ExpressionAttributeValues' =>  [
          ':userId' => ['N' => $userId],
          ':productId' => ['N' => $productId]
          ],
          ]); */



        return $response;
    }

    public function getMarkedAttendance($subjectId, $studentId, $finddate = Null, $type = Null) {
        $tblObj = new AttendenceTable($this->adapter);
        return $tblObj->getMarkedAttendance($subjectId, $studentId, $finddate, $type);
    }

    public function getuserClassCount($classId, $studentId) {
        $tblObj = new AttendenceTable($this->adapter);
        return $tblObj->getuserClassCount($classId, $studentId);
    }

    /**
     * @desc used for get user's subject count in attendance table
     * @param integer $subjectId
     * @param integer $studentId
     * @return integer (response as count)
     */
    public function getuserSubjectCount($subjectId, $studentId, $type = 'subject') {
        $tblObj = new AttendenceTable($this->adapter);
        return $tblObj->getuserSubjectCount($subjectId, $studentId, $type);
    }

    function countTotalActivityByType($type) {
        $tbl = new TrackingTable($this->adapter);
        $response = $tbl->countTotalActivityByType($type, $this->container->authDetail);
        return $response;
    }

    function countAllQuez($lpIdArr) {
        $tbl = new TrackingTable($this->adapter);
        $response = $tbl->countAllQuez($lpIdArr);
        return $response;
    }

    function countAllAttemptQuez($contArr, $studentId = null) {
        if (empty($studentId))
            $studentId = $this->container->authDetail['USER_OID'];
        $tbl = new TrackingTable($this->adapter);
        $response = $tbl->countAllAttemptQuez($studentId, $contArr);
        return $response;
    }

    function getDueAssignMent($studentId = null) {
        if (empty($studentId))
            $studentId = $this->container->authDetail['USER_OID'];
        $tbl = new AssignmentTable($this->adapter);
        $response = $tbl->getDueAssignmentOfStudent($studentId);
        return $response;
    }

    function getContentIdByLpIds($lpIds) {
        $tbl = new GradeTable($this->adapter);
        $response = $tbl->getContentIdByLpIds($lpIds);
        return $response;
    }

    /*     * ********************************  Tracking Functionality End ****************************** */

    function addhttp($url) {
        $input = preg_replace("#^[^:/.]*[:/]+#i", "", $url);
        if (!preg_match("~^(?:f|ht)tps?://~i", $input)) {
            $input = "http://" . $input;
        }
        return $input;
    }

    function getVideoIdfromEmbdedCode($code) {
        $pattern = '%(?:https?://)?(?:www\.)?(?:youtu\.be/| youtube\.com(?:/embed/|/v/|/watch\?v=))([\w-]{10,12})[a-zA-Z0-9+?\< \>\"]%x';
        $result = preg_match($pattern, $code, $matches);
        if (!empty($matches[1]))
            return $matches[1];
        return false;
    }

    public function getContentAddEditRow($form, $navigation = '', $tab = null, $lang, $subjectId = 0, $lessionPlanId = null, $contentId) {
        $tab = (!empty($tab)) ? $tab : rand(1000, 99999);

        echo $this->getView()->render('secure/grade/partial/ContentAddEditRow.phtml', ['PageForm' => $form, 'lessionPlanId' => $lessionPlanId, 'navigation' => $navigation, 'tab' => $tab, 'lang' => $lang, 'subjectId' => $subjectId, 'contentId' => $contentId]);
    }

    public function getAdmContentAddEditRow($form, $navigation = '', $tab = null, $lang, $subjectId = 0, $lessionPlanId = null, $contentId = null) {
        $tab = (!empty($tab)) ? $tab : rand(1000, 99999);
        
        echo $this->getView()->render('secure/adm-grade/partial/ContentAddEditRow.phtml', ['PageForm' => $form, 'lessionPlanId' => $lessionPlanId, 'navigation' => $navigation, 'tab' => $tab, 'lang' => $lang, 'subjectId' => $subjectId, 'contentId' => $contentId]);
    }

    function getScriptVideoLibrary($scriptvalue, $urltype, $startWith) {
        if ($urltype == 'youtube.com') {
            $videoId = $this->getVideoIdfromEmbdedCode($scriptvalue);
            ?>
            <div id="youtube_player"></div>
            <script type="text/javascript">
                var tag = document.createElement('script');
                tag.src = "https://www.youtube.com/iframe_api";
                var firstScriptTag = document.getElementsByTagName('script')[0];
                firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
                var player;
                function onYouTubeIframeAPIReady() {
                player = new YT.Player('youtube_player', {
                height: '390',
                        width: '640',
                        videoId: '<?php echo $videoId; ?>',
            <?php if ($startWith != '') { ?>
                    playerVars: {
                    start: <?php echo (int) $startWith; ?>
                    },
            <?php } ?>
                events: {
                'onReady': onPlayerReady/*,
                 'onStateChange': onPlayerStateChange*/
                }
                });
                }
                function onPlayerReady(event) {
                event.target.playVideo();
                }

                var done = false;
                        var videotimerInterval;
                        var callAjaxForVideoTrack;
                        function onPlayerStateChange(event) {
                        document.getElementById('videoToatalLength').value = player.getDuration();
                                document.getElementById('videoPlayerState').value = event.data;
                                switch (event.data) {
                        case 1:  // playing
                                var videoDuration = player.getDuration();
                                videotimerInterval = setInterval(function(){
                                document.getElementById('currentVideoPlayerTime').value = player.getCurrentTime();
                                        if (document.getElementById('videoTimer').value == 0){
                                var timer = player.getCurrentTime();
                                } else{
                                var timer = document.getElementById('videoTimer').value;
                                        var prevTime = document.getElementById('prevTime').value;
                                        if (prevTime != ''){
                                var addValue = parseFloat(player.getCurrentTime()) - parseFloat(prevTime);
                                        document.getElementById('prevTime').value = player.getCurrentTime();
                                        if (addValue < parseFloat(0.5)){
                                timer = parseFloat(timer) + parseFloat(addValue);
                                } else{
                                var increment = parseFloat(timer) - parseFloat(player.getCurrentTime());
                                        if (increment < parseFloat(1)){
                                timer = parseFloat(timer) + 0.5 + (parseFloat(player.getCurrentTime()) - parseFloat(timer));
                                } else{
                                timer = parseFloat(timer) + 0.5;
                                }
                                }
                                } else{
                                document.getElementById('prevTime').value = player.getCurrentTime();
                                        timer = parseFloat(timer) + 0.5;
                                }
                                }
                                document.getElementById('yt_diffrence').value = parseFloat(timer) - parseFloat(player.getCurrentTime());
                                        document.getElementById('videoTimer').value = timer;
                                        completedpercentage = (timer * 100) / videoDuration;
                                        document.getElementById('videoCompletePercent').value = completedpercentage;
                                }, 500);
                                var setAjaxtime = (videoDuration / 100) * 5 * 1000;
                                if (parseInt(setAjaxtime) < 10000){ setAjaxtime = 10000; }
                        callAjaxForVideoTrack = setInterval(function(){
                        puttrackindb();
                        }, parseInt(setAjaxtime));
                                break;
                                case 2:  // paused
                                clearInterval(videotimerInterval);
                                clearInterval(callAjaxForVideoTrack);
                                puttrackindb();
                                break;
                                case 0:  // ended
                                clearInterval(videotimerInterval);
                                clearInterval(callAjaxForVideoTrack);
                                break;
                                default:  // ended
                                clearInterval(videotimerInterval);
                                clearInterval(callAjaxForVideoTrack);
                                break;
                        }
                        }

            </script>
            <?php
        }
    }

    function getJwModulePlayer($type, $videoS3Url, $videoPlayedPercentage, $videoTimer) {
        $user_id = $this->container->authDetail['USER_OID'];
        $translator = $this->sm->get('translator');
        ?>
        <div id="my-video" style="padding-left:30px;"><?php echo $translator->translate('Loading the player...'); ?></div>
        <script type='text/javascript'>
            var videotimerInterval;
                    var callAjaxForVideoTrack;
                    var JWplayerInstance;
                    JWplayerInstance = jwplayer('my-video').setup({
            file: "<?php echo $videoS3Url; ?>",
                    primary: "html5",
                    width: '<?php
        if ($type == 'AUDIO')
            echo "480px";
        else
            echo "100%"
            ?>',
                    height:'<?php
        if ($type == 'AUDIO')
            echo "40px";
        else
            echo "100%"
            ?>',
                    //aspectratio: '16:9',
        <?php if ($user_id != '') { ?>
                autostart: 'true',
        <?php } ?>

        <?php if ($user_id != '') { ?>
                events: {
                onPlay: function(e){
                var videoDuration = this.getDuration();
                        document.getElementById('videoToatalLength').value = this.getDuration();
                        document.getElementById('videoPlayerState').value = 'playing';
                        if (videotimerInterval){clearInterval(videotimerInterval); }
                videotimerInterval = setInterval(function(){
                var videoDuration = jwplayer("my-video").getDuration();
                        document.getElementById('currentVideoPlayerTime').value = jwplayer("my-video").getPosition();
                        if (document.getElementById('videoTimer').value <= 0){
                var timer = jwplayer("my-video").getPosition();
                } else{
                var timer = document.getElementById('videoTimer').value;
                        var prevTime = document.getElementById('prevTime').value;
                        if (prevTime != ''){
                var addValue = parseFloat(jwplayer("my-video").getPosition()) - parseFloat(prevTime);
                        document.getElementById('prevTime').value = jwplayer("my-video").getPosition();
                        if (addValue < parseFloat(0.5)){
                timer = parseFloat(timer) + parseFloat(addValue);
                } else{ timer = parseFloat(timer) + 0.5; }
                } else{
                document.getElementById('prevTime').value = jwplayer("my-video").getPosition();
                        timer = parseFloat(timer) + 0.5;
                }
                }
                document.getElementById('videoTimer').value = timer;
                        if (document.getElementById('videoToatalLength').value <= 0){
                document.getElementById('videoToatalLength').value = videoDuration;
                }
                completedpercentage = (timer * 100) / videoDuration;
                        document.getElementById('videoCompletePercent').value = completedpercentage;
                }, 500);
                        setTimeout(function(){
                        var videoLength = jwplayer("my-video").getDuration();
                                setAjaxtime = (videoLength / 100) * 5 * 1000;
                                if (parseInt(setAjaxtime) < 10000){
                        setAjaxtime = 10000;
                        }
                        if (callAjaxForVideoTrack){clearInterval(callAjaxForVideoTrack); }
                        callAjaxForVideoTrack = setInterval(function(){
                        if (jwplayer("my-video").getPosition() != - 1 && jwplayer("my-video").getDuration() != - 1){
                        puttrackindb();
                        }
                        }, parseInt(setAjaxtime));
                        }, 1000);
                },
                        onPause:function(e){
                        var isSeeked = document.getElementById('jwvideoSeeked').value;
                                if (parseInt(isSeeked) < 2){
                        document.getElementById('prevTime').value = jwplayer("my-video").getPosition();
                                document.getElementById('videoTimer').value = jwplayer("my-video").getPosition();
                                document.getElementById('currentVideoPlayerTime').value = jwplayer("my-video").getPosition();
                                document.getElementById('videoCompletePercent').value = (parseFloat(jwplayer("my-video").getPosition()) * 100) / parseFloat(jwplayer("my-video").getDuration());
                        }
                        document.getElementById('videoPlayerState').value = 'paused';
                                clearInterval(videotimerInterval);
                                clearInterval(callAjaxForVideoTrack);
                                if (jwplayer("my-video").getPosition() != - 1){
                        puttrackindb();
                        }
                        },
                        onSeek:function(e){
                        document.getElementById('jwvideoSeeked').value = parseInt(document.getElementById('jwvideoSeeked').value) + 1;
                        },
                        onComplete: function(e){
                        var isSeeked = document.getElementById('jwvideoSeeked').value;
                                if (parseInt(isSeeked) < 2){
                        document.getElementById('prevTime').value = jwplayer("my-video").getPosition();
                                document.getElementById('videoTimer').value = jwplayer("my-video").getPosition();
                                document.getElementById('currentVideoPlayerTime').value = jwplayer("my-video").getPosition();
                                document.getElementById('videoCompletePercent').value = (parseFloat(jwplayer("my-video").getPosition()) * 100) / parseFloat(jwplayer("my-video").getDuration());
                        }
                        document.getElementById('videoPlayerState').value = 'completed';
                                clearInterval(videotimerInterval);
                                clearInterval(callAjaxForVideoTrack);
                                if (jwplayer("my-video").getPosition() != - 1){
                        puttrackindb();
                        }
                        },
                        onBuffer: function(e){
                        var isSeeked = document.getElementById('jwvideoSeeked').value;
                                if (parseInt(isSeeked) < 2){
                        document.getElementById('prevTime').value = jwplayer("my-video").getPosition();
                                document.getElementById('videoTimer').value = jwplayer("my-video").getPosition();
                                document.getElementById('currentVideoPlayerTime').value = jwplayer("my-video").getPosition();
                                document.getElementById('videoCompletePercent').value = (parseFloat(jwplayer("my-video").getPosition()) * 100) / parseFloat(jwplayer("my-video").getDuration());
                        }
                        document.getElementById('videoPlayerState').value = 'buffer';
                                clearInterval(videotimerInterval);
                                clearInterval(callAjaxForVideoTrack);
                        }
                },
        <?php } ?>
            startparam: "starttime"
            });
                    jwplayer('my-video').onReady(function() {
            jwplayer().seek(<?php echo $videoTimer; ?>);
            });
        <?php if ($this->container->authDetail['UT_ID'] != 1) { ?>
                /***************************************  Annotation ************************************/
                // defining global variables
                var annotation_storage_array = new Array();
                        var isAnnotationStored = false;
                        var content_div_height = $('.asset-container').outerHeight() - 40;
                        var content_div_width = $('.asset-container').outerWidth();
                        var canvas = document.getElementById('video-canvas');
                        var context = canvas.getContext("2d");
                        canvas.setAttribute('width', content_div_width);
                        canvas.setAttribute('height', content_div_height);
                        canvas_height = canvas.height;
                        canvas_width = canvas.width;
                        // function to activate/inactivate canvas
                                function startEndAnnotation() {
                                // initialize canvas with sketch.js
                                $('#video-canvas').sketch();
                                        // remove 'hide' class from canvas container and add 'show' class
                                        //  so that canvas could be activate
                                        if ($('.video_canvas_container').hasClass('hide')) {
                                // show all hidden elements
                                $('.annoation-eraser-tool, .annoation-marker-tool').show();
                                        // show canvas
                                        $('.video_canvas_container').removeClass('hide').addClass('show');
                                        $(".videomarker").addClass('annotation_active_tools');
                                        // swap text 'Start' to 'Stop'
                                        $(".video_start_annotation").text('Stop Annotation');
                                        // pause the file & change text
                                        jwplayer('my-video').pause(true);
                                        jwplayer('my-video').setControls(false);
                                } else {
                                // hide all elements
                                $('.annoation-eraser-tool, .annoation-marker-tool').hide();
                                        // if canvas is not blank then store this annotation into array				
                                        if (isCanvasEmpty()) {
                                storeAnnotation();
                                        setTimeout(function () {
                                        //$('.video_canvas_container').html('');
                                        //add it back to the container
                                        //$('.video_canvas_container').html('<canvas id="video-canvas" height="'+canvas_height+'" width="'+canvas_width+'"></canvas>');						
                                        context.clearRect(0, 0, canvas_width, canvas_height);
                                                $('#video-canvas').sketch('actions', []);
                                        }, 1000);
                                }
                                $('.video_canvas_container').removeClass('show').addClass('hide');
                                        // swap text 'Stop' to 'Start'
                                        $(".video_start_annotation").text('Start Annotation');
                                        // play the file & change text
                                        jwplayer('my-video').play(true);
                                        jwplayer('my-video').setControls(true);
                                }
                                }
                        // to check if canvas is empty or not
                        function isCanvasEmpty() {
                        var video_canvas = document.getElementById('video-canvas');
                                if (!video_canvas.getContext) return;
                                var ctx = video_canvas.getContext('2d');
                                //var w       = video_canvas.width = video_canvas.height = 100;
                                var drawn = null;
                                var d = ctx.getImageData(0, 0, content_div_width, content_div_height); //image data 
                                var len = d.data.length;
                                for (var i = 0; i < len; i++) {
                        if (!d.data[i]) {
                        drawn = false;
                        } else if (d.data[i]) {
                        drawn = true;
                                break;
                        }
                        }
                        return drawn;
                        }
                        // function to store annotation locally
                        function storeAnnotation() {
                        var annotation_array = new Array();
                                var canvas = document.getElementById('video-canvas');
                                // get current time to set annotation start time
                                annotation_array.annotation_start_time = jwplayer('my-video').getPosition().toFixed(0);
                                annotation_array.data_string = canvas.toDataURL();
                                // store annotation in array, to retrieve back
                                annotation_storage_array.push(annotation_array);
                                // set true to this var, because annotation has been stored
                                isAnnotationStored = true;
                        }
                        // function to erase all annotations
                        function eraseAllAnnotations() {
                        // script to erase all annotations and reinitialize canvas    
                        //if (confirm("Are you sure you want to remove all annotations?")) {
                        //$('.video_canvas_container').html(''); //remove canvas from container
                        //$('.video_canvas_container').html('<canvas id="video-canvas" height="'+canvas_height+'" width="'+canvas_width+'"></canvas>'); //add it back to the container				
                        //$('#video-canvas').sketch();
                        context.clearRect(0, 0, canvas_width, canvas_height);
                                $('#video-canvas').sketch('actions', []);
                                //$(".video_start_annotation").text('Start Annotation');
                                return true;
                                //} else {
                                //return false;
                                //}
                        }
                        // function to draw stored annotation
                        function drawStoredAnnotation(annotation_baase_64_string, annotation_numbering) {
                        annotation_numbering++;
                                $('.annotation_image_div').append('<img src="' + annotation_baase_64_string + '" class="annotation_image annotation_numbering_' + annotation_numbering + '" />');
                                // remove images
                                setTimeout(function () {
                                $('.annotation_numbering_' + annotation_numbering).attr('src', '');
                                }, 3000);
                        }
                        // script to contorls video & canvas
                        $(document).ready(function () {
                        // script to activate/inactivate canvas
                        $(".video_start_annotation").on("click", function () {
                        startEndAnnotation();
                        });
                                // script when user clicks on eraser
                                $('.videoeraser').on('click', function () {
                        $(".videomarker").removeClass('annotation_active_tools');
                                $(".videoeraser").addClass('annotation_active_tools');
                                $(".annotation-color-tools").hide();
                                $('.annoation-marker-tool ul').hide();
                                $('.annoation-eraser-tool ul').show();
                        });
                                // script when user clicks on marker
                                $('.videomarker').on('click', function () {
                        $(".videoeraser").removeClass('annotation_active_tools');
                                $(".videomarker").addClass('annotation_active_tools');
                                $(".annotation-color-tools").show();
                                $('.annoation-marker-tool ul').show();
                                $('.annoation-eraser-tool ul').hide();
                        });
                                // hide dropdown	
                                $(".dropdown-menu").mouseleave(function(){
                        $('.annoation-marker-tool ul').hide();
                                $('.annoation-eraser-tool ul').hide();
                        });
                                // script to erase all annotations
                                $('.erase_all_annotations').on("click", function () {
                        eraseAllAnnotations();
                        });
                                // event to track during playing of video
                                var loopcounter = 0;
                                var video_current_playing_time;
                                JWplayerInstance.on('time', function () {
                                video_current_playing_time = 0;
                                        // current running time
                                        video_current_playing_time = parseInt(JWplayerInstance.getPosition().toFixed(0));
                                        // condition to check that same annotation should be drawn only once. 
                                        // Since ontime event runs 10 times/second.
                                        //console.log('Player time = '+video_current_playing_time);
                                        //console.log('Loop time = '+loopcounter);
                                        if (video_current_playing_time == loopcounter){
                                if (isAnnotationStored) {
                                var count = 0;
                                        for (count = 0; count < annotation_storage_array.length; count++) {
                                if (video_current_playing_time == parseInt(annotation_storage_array[count]['annotation_start_time'])) {
                                drawStoredAnnotation(annotation_storage_array[count]['data_string'], count);
                                }
                                }
                                }
                                loopcounter += 1;
                                }
                                });
                                // event to track when video finished
                                JWplayerInstance.on('complete', function() {
                                loopcounter = 0;
                                });
                                // event to track seeking (rewind/forward) of video
                                JWplayerInstance.onSeek(function(evt) {
                                loopcounter = parseInt(evt.offset.toFixed(0));
                                });
                                // track full screen event
                                JWplayerInstance.on('fullscreen', function () {
                                // while screen become full then make canvas as equivalent of screen
                                if ($('.annotation_image').hasClass('annotation_image_fullscreen')) {
                                $('.annotation_image').removeClass('annotation_image_fullscreen');
                                } else {
                                $('.annotation_image').addClass('annotation_image_fullscreen');
                                }
                                });
                        });
                                /***************************************  Annotation ************************************/
        <?php } ?>


        </script>

        <input type="hidden" name="jwvideoSeeked" id="jwvideoSeeked" value="0"/>

        <?php
    }

    /** used of this function for get subject and topic by questrion id */
    public function getSubAndTopicByQusId($qusId, $url) {
        $tblObj = new QuizTable($this->adapter);
        $subject = $tblObj->fectDataFromQuizTopic($qusId);
        $translator = $this->sm->get('translator');
        $topic = '';
        $subjName = '';
        $subj = '';
        $topicUrl = '';
        if (!empty($subject)) {
            foreach ($subject as $subData) {
                $subjName = $subData['SUBJECT_NAME'];
                $topic .= '<a data-title="' . $translator->translate("Lesson Plan List") . '" data-remote="' . $url . '/' . $subData['CAT_ID'] . '" data-toggle="lightbox" href="#" class="label label-info mr-5 topic-lp-list-review">' . $subData['CAT_NAME'] . '</a>';
            }

            $subj = '<span class="label label-danger mr-5">' . $subjName . '</span>' . $topic;
        }
        return $subj;
    }

    //function to get random numeric/alpha-numeric numbers with length
    public function generateRandomNumber($length, $format = 'numeric') {
        if ($format == 'numeric') {
            $number = '';
            for ($i = 0; $i < $length; $i++) {
                $number .= rand(0, 9);
            }
            return (int) $number;
        } else if ($format == 'alphanumeric') {
            return $s = substr(str_shuffle(str_repeat("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ", $length)), 0, $length);
        }
    }

    public function generateSessionKey($path) {
        $key = $this->generateRandomNumber(12);

        $keyindex = array_search($path, $_SESSION['PATH']);
        if (!$keyindex) {
            $_SESSION['PATH'][$key] = $path;
        } else {
            $key = $keyindex;
        }

        /*
          if(empty($this->container->path[$key])){
          //$arr[$key] = $path;
          $_SESSION['PATH'][$key] = $path;
          }else{
          $key = $this->generateRandomNumber(12);

          $_SESSION['PATH'][$key] = $path;
          } */

        return $key;
    }

    public function getSessionValue($key) {
        return $_SESSION['PATH'][$key];
    }

    public function getcontentUnreadData() {
        $tbl = new GradeTable($this->adapter);
        $response = $tbl->getcontentUnreadData();
        return $response;
    }

    public function gettopiclist($lessionPlanId, $lessionPlan = null) {
        $tbl = new GradeTable($this->adapter);
        if ($lessionPlan == "lessionPlan") {
            $response = $tbl->gettopicIdlist($lessionPlanId);
        } else {
            $response = $tbl->gettopiclist($lessionPlanId);
        }
        return $response;
    }

    public function getAdmTopiclist($lessionPlanId, $lessionPlan = null) {
        $tbl = new AdmgradeTable($this->adapter);
        if ($lessionPlan == "lessionPlan") {
            $response = $tbl->gettopicIdlist($lessionPlanId);
        } else {
            $response = $tbl->gettopiclist($lessionPlanId);
        }
        return $response;
    }

    public function getAdmTopiclistByContId($contentId) {
        $tbl = new AdmgradeTable($this->adapter);
        $response = $tbl->getTopicListByContentId($contentId);
        
        return $response;
    }

    public function getLOlist($lessionPlanId) {
        $tbl = new GradeTable($this->adapter);
        $response = $tbl->getLOlist($lessionPlanId);
        return $response;
    }

    public function getcatIdCount($topicId, $contentId = null) {
        $tbl = new GradeTable($this->adapter);
        $response = $tbl->getcatIdCount($topicId, $contentId);
        return $response;
    }

    public function getAdmcatIdCount($topicId, $contentId = null) {
        $tbl = new AdmgradeTable($this->adapter);
        $response = $tbl->getcatIdCount($topicId, $contentId);
        return $response;
    }

//      public function getLessonplanIdByContentId($contId) {
//        $tbl = new GradeTable($this->adapter);
//        $response = $tbl->getLessonplanIdByContentId($contId);
//        return $response;
//    }
//    

    public function getCatId($CONT_ID) {
        $tbl = new GradeTable($this->adapter);
        $response = $tbl->getcatId($CONT_ID);
        $i = 0;
        $CAT_ID = array();
        foreach ($response as $data) {
            $CAT_ID[] = $data['CAT_ID'];

            $i++;
        }
        //print_r($a);die;
        return $CAT_ID;
    }

    public function getCatIdForadm($CONT_ID) {
        $tbl = new AdmgradeTable($this->adapter);
        $response = $tbl->getcatIdForAdm($CONT_ID);
        $i = 0;
        $CAT_ID = array();
        foreach ($response as $data) {
            $CAT_ID[] = $data['CAT_ID'];

            $i++;
        }
        //print_r($a);die;
        return $CAT_ID;
    }

    public function getAdmCatId($CONT_ID) {
        $tbl = new AdmgradeTable($this->adapter);
        $response = $tbl->getcatId($CONT_ID);
        $i = 0;
        $CAT_ID = array();
        foreach ($response as $data) {
            $CAT_ID[] = $data['CAT_ID'];

            $i++;
        }
        //print_r($a);die;
        return $CAT_ID;
    }

    function getStringArrBetweenDlm($str, $startDelimiter, $endDelimiter) {
        $contents = array();
        $startDelimiterLength = strlen($startDelimiter);
        $endDelimiterLength = strlen($endDelimiter);
        $startFrom = $contentStart = $contentEnd = 0;
        while (false !== ($contentStart = strpos($str, $startDelimiter, $startFrom))) {
            $contentStart += $startDelimiterLength;
            $contentEnd = strpos($str, $endDelimiter, $contentStart);
            if (false === $contentEnd) {
                break;
            }
            $contents[] = substr($str, $contentStart, $contentEnd - $contentStart);
            $startFrom = $contentEnd + $endDelimiterLength;
        }

        return $contents;
    }

    public function getFileExt($fileName) {
        return pathinfo($fileName, PATHINFO_EXTENSION);
    }

    function playAudioVideoWithJw($div_id, $path, $width = 600, $height = 360, $isaudio = false) {

        $ext = pathinfo($path, PATHINFO_EXTENSION);

        if ($isaudio || $ext == 'mp3') {
            $height = 40;
        }
        $request = $this->sm->get('request');
        $basePath = "http://" . $request->getUri()->getHost() . $request->getBasePath();
        ?>
        <script type="text/javascript" src="<?php echo $basePath . '/js/plugins/jwplayer/jwplayer.js'; ?>"></script>
        <script>
                            jwplayer.key = "NpbrkfaG2NwekvM4a7otBoSO7STZVEJnQPEUHg=="
        </script>
        <script type="text/javascript">
                            var playerInstance = jwplayer("<?php echo $div_id; ?>");
                            playerInstance.setup({
                            file: "<?php echo $path; ?>",
                                    //width: "<?php echo $width; ?>",
                                    width: "100%",
                                    height: "<?php echo $height; ?>"
                            });
        </script>
        <?php
    }

    public function quizDetailsB2b($cont_id) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getCourseTestDetails($cont_id);
    }

    public function quizDetails($cont_id) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getCourseTestDetails($cont_id);
    }

    public function quizDetailsById($testId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getTestDetails($testId);
    }

    public function b2cQuizDetailsById($testId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getTestDetails($testId);
    }

    /**
     * @desc get full string for sub string
     * @param string $text
     * @param integer $length
     * @param string $tail
     * @return string
     */
    function subStrWithFullString($text, $length = 100, $tail = "...") {
        $text = trim($text);
        if (strlen($text) > $length) {
            for ($i = 0; $text[$length + $i] != " "; $i++) {
                if (!$text[$length + $i]) {
                    return $text;
                }
            }
            $text = substr($text, 0, $length + $i) . $tail;
        }
        return $text;
    }

    function getCurrentQuizAttened($quiz_id, $user_oid) {
        $tblObj = new StudentTable($this->adapter);
        return $tblObj->checkQuizAttened($quiz_id, $user_oid);
    }

    function getCurrentQuizAttenedB2c($quiz_id, $user_oid) {
        $tblObj = new B2cstudentTable($this->adapter);
        return $tblObj->checkQuizAttened($quiz_id, $user_oid);
    }

    function getUserResponseWithAttemptId($val) {
        $aws = $this->sm->get(Sdk::class);
        $config = $this->sm->get('config');
        $dynamo_db_table_for_quiz = $config['dynamo_db_table_for_quiz'];
        $client = $aws->createDynamoDb();
        $response = $client->query([
            'TableName' => $dynamo_db_table_for_quiz,
            'KeyConditionExpression' => 'AttemptID = :v_id',
            'ExpressionAttributeValues' => [
                ':v_id' => ['S' => $val]
            ],
        ]);
        return $response;
    }

    function getUserRightWrongResponseCountWithAttemptId($val, $status = true) {
        $aws = $this->sm->get(Sdk::class);
        $config = $this->sm->get('config');
        $dynamo_db_table_for_quiz = $config['dynamo_db_table_for_quiz'];
        $client = $aws->createDynamoDb();
        $response = $client->query([
            'TableName' => $dynamo_db_table_for_quiz,
            'Select' => 'COUNT',
            'KeyConditionExpression' => 'AttemptID = :v_id',
            'FilterExpression' => 'ResultSuccess = :v_res',
            'ExpressionAttributeValues' => [
                ':v_id' => ['S' => $val],
                ':v_res' => ['S' => ($status) ? 'true' : 'false']
            ],
        ]);
        return $response['Count'];
    }

    function getUserFlagedResponseCountWithAttemptId($val) {
        $aws = $this->sm->get(Sdk::class);
        $config = $this->sm->get('config');
        $dynamo_db_table_for_quiz = $config['dynamo_db_table_for_quiz'];
        $client = $aws->createDynamoDb();
        $response = $client->query([
            'TableName' => $dynamo_db_table_for_quiz,
            'Select' => 'COUNT',
            'KeyConditionExpression' => 'AttemptID = :v_id',
            'FilterExpression' => 'IsFlaged = :v_flg',
            'ExpressionAttributeValues' => [
                ':v_id' => ['S' => $val],
                ':v_flg' => ['S' => 'true']
            ],
        ]);
        return $response['Count'];
    }

    function getEssayQsnResponseCountWithAttemptId($val) {
        $aws = $this->sm->get(Sdk::class);
        $config = $this->sm->get('config');
        $dynamo_db_table_for_quiz = $config['dynamo_db_table_for_quiz'];
        $client = $aws->createDynamoDb();
        $response = $client->query([
            'TableName' => $dynamo_db_table_for_quiz,
            'Select' => 'COUNT',
            'KeyConditionExpression' => 'AttemptID = :v_id',
            'FilterExpression' => 'ResultSuccess = :v_res and QuestionType = :v_typ',
            'ExpressionAttributeValues' => [
                ':v_id' => ['S' => (string) $val],
                ':v_res' => ['S' => (string) 'false'],
                ':v_typ' => ['S' => (string) '1']
            ],
        ]);
        return $response['Count'];
    }

    function getUserResponseWithAttemptNQsnId($AttemptID, $QuestionID) {
        $aws = $this->sm->get(Sdk::class);
        $config = $this->sm->get('config');
        $dynamo_db_table_for_quiz = $config['dynamo_db_table_for_quiz'];
        $client = $aws->createDynamoDb();
        $response = $client->query([
            'TableName' => $dynamo_db_table_for_quiz,
            'KeyConditionExpression' => 'AttemptID = :v_id and QuestionID = :v_qid',
            'ExpressionAttributeValues' => [
                ':v_id' => ['S' => (string) $AttemptID],
                ':v_qid' => ['N' => (string) $QuestionID]
            ],
        ]);
        return $response['Items'][0];
    }

    function getQuizScore($QUIZ_ID, $USER_OID, $QUIZ_SCORE_KEEP) {
        if (!empty($QUIZ_ID) && !empty($USER_OID) && !empty($QUIZ_SCORE_KEEP)) {
            $tblObj = new StudentTable($this->adapter);
            return $tblObj->getQuizScore($QUIZ_ID, $USER_OID, $QUIZ_SCORE_KEEP);
        } else {
            return true;
        }
    }

    function getQuizScoreB2c($QUIZ_ID, $USER_OID, $QUIZ_SCORE_KEEP) {
        if (!empty($QUIZ_ID) && !empty($USER_OID) && !empty($QUIZ_SCORE_KEEP)) {
            $tblObj = new B2cstudentTable($this->adapter);
            return $tblObj->getQuizScore($QUIZ_ID, $USER_OID, $QUIZ_SCORE_KEEP);
        } else {
            return true;
        }
    }

    function getQuestioncount($table, $conditions) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->totalques($table, $conditions);
    }

    function getB2cQuestioncount($table, $conditions) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->totalques($table, $conditions);
    }

    //getcutscore of quiz
    function getcutscoreofquiz($quizid) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getquizcutcore($quizid);
    }

    //getcutscore of quiz
    function getcutscoreofquizB2c($quizid) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getquizcutcore($quizid);
    }

    /**
     * @desc get count of lesson plan by specific subject-id.
     * @param integer $subject
     */
    function getLpCountBySubjectId($subjectId) {
        $tblObj = new GradeTable($this->adapter);
        return (!empty($subjectId)) ? $tblObj->countData('t_cm_lessonplan_master', ['SUBJECT_ID' => $subjectId]) : 0;
    }

    // get users id by org id
    function getuserIdsByOrgId($orgId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getuserIdsByOrgId($orgId);
    }

    // funciton to get Final Test id by Subject id for teacher/school

    function getFinalTestIdBySubjectId($subjectId, $userIds) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getFinalTestIdBySubjectId($subjectId, $userIds);
    }

    function getB2cFinalTestIdBySubjectId($subjectId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getb2cFinalTestIdBySubjectId($subjectId);
    }

    function getlessonplanexist($subjectId) {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->checklessonplan($subjectId);
    }

    /**
     * @desc used to get all PT test related details via specific grade for a specific user.
     * @param integer $gradeId
     * @param integer $userId
     * @return array
     */
    function getPlcTestListWithGrade($gradeId, $userId) {
        $tblObj = new CreateQuizTable($this->adapter);
        return $tblObj->getPlcTestListWithGrade($gradeId, $userId);
    }

    function getB2cTestIdByContId($contId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getB2cTestIdByContId($contId);
    }

    // Fetch all grade data from grade table 
    public function getAllGradeDetails() {
        $tblObj = new GradeTable($this->adapter);
        return $tblObj->getGradeallDetails();
    }

    // Fetch the days ago
    public function convert_in_days($datetime) {
        $seconds_ago = (time() - strtotime($datetime));
        if (($seconds_ago >= 86400)) {
            return intval($seconds_ago / 86400) . ' days ago';
        } else {
            return 'Some time ago';
        }
    }

    // Fetch all comment data from grade table 
    public function getAllCommentDetails($questionId) {
        $tblObj = new AskQuestionTable($this->adapter);
        return $tblObj->getCommentallDetails($questionId);
    }

    public function AnswerCount($questionId) {
        $tblObj = new AskQuestionTable($this->adapter);
        return $tblObj->AnswerCount($questionId);
    }

    // Fetch Like count from db    
    public function LikeCount($answerId) {

        $tblObj = new AskQuestionTable($this->adapter);
        return $tblObj->LikeCount($answerId);
    }

    // Fetch Unlike count from db    
    public function UnLikeCount($answerId) {

        $tblObj = new AskQuestionTable($this->adapter);
        return $tblObj->UnLikeCount($answerId);
    }

    // Fetch like data from db 
    public function LikeData($answerId, $user_oid) {
        $tblObj = new AskQuestionTable($this->adapter);
        return $tblObj->LikeDataDetails($answerId, $user_oid);
    }

    public function getallcomment($answerId, $user_oId) {
        $tblObj = new AskQuestionTable($this->adapter);
        return $tblObj->getCommentallDetailData($answerId, $user_oId);
    }

    //get atb grade book details by subject Id
    public function getGradeSubjectPublicDetails($subject_id) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getGradeSimilarSubjectDetails($subject_id);
    }

    public function getAllParentMenu() {
        $tblObj = new DistrictTable($this->adapter);
        return $tblObj->getAllParentMenu();
    }

    public function getAllMenuForHeader($parent, $spacing = '', $user_tree_array = '') {
        $tblObj = new DistrictTable($this->adapter);
        $allSubmenu = $tblObj->getAllMenuForHeader($parent, $spacing = '', $user_tree_array = '');
        
     
        return $allSubmenu;
        
    }
    
     public function callMenuRecord($allSubmenu,$menu_id){
         foreach ($allSubmenu as $data){
             
         }
     }


     
    public function getAllLessonPlanBySubjectId($subject_id) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getCourseTestDetails($cont_id);
    }

    public function getNextContentDetails($lessonId, $subId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getNextRecordDetails($lessonId, $subId);
    }

    public function getNextContentData($contId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getNextContentDetails($contId);
    }
    
    public function getSubIdByContentId($contId) {
        $tblObj = new AdmgradeTable($this->adapter);
        return $tblObj->getSubjIdByContentId($contId);
    }
}
?>

Youez - 2016 - github.com/yon3zu
LinuXploit