ProfileView.cshtml 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  1. @using NEducation.Controllers;
  2. @using NEducation.Content.Texts
  3. @{
  4. ViewBag.Title = "Profiles";
  5. Layout = "~/Views/Shared/_LayoutHome.cshtml";
  6. }
  7. @model NEducation.Models.ProfileModel
  8. <link rel="stylesheet" href="~/Content/assets/css/profile/personal.css" />
  9. <script src="~/Content/assets/js/profile/personal.js" type="text/javascript"></script>
  10. @*
  11. <link rel="stylesheet" href="~/Content/assets/css/profile/main.css" />*@
  12. <!-- Show notification -->
  13. <!-- Header -->
  14. <!-- Body -->
  15. <div class="main-body">
  16. <div class="setting-container">
  17. <div class="setting-body">
  18. <div class="setting-left">
  19. <div class="setting-left-content">
  20. <div class="left-item">
  21. <a href="javascript:void(0)" class="left-item-menu menu-item-course">
  22. @Lang.Course
  23. @*Khóa học*@
  24. <i class="fa fa-angle-up"></i>
  25. </a>
  26. <ul>
  27. @*<li class="menu-order">*@
  28. <li class="menu-course">
  29. <a href="/Individual">
  30. @Lang.CourseManager
  31. @*Quản lý khóa học*@
  32. </a>
  33. </li>
  34. </ul>
  35. </div>
  36. <div class="left-item">
  37. <a href="javascript:void(0)" class="left-item-menu menu-item-information">
  38. @Lang.Personal
  39. @*Cá nhân*@
  40. <i class="fa fa-angle-up"></i>
  41. </a>
  42. <ul>
  43. <li class="menu-information">
  44. <a href="/Home/Profile">
  45. @Lang.Information
  46. @*Thông tin chung*@
  47. </a>
  48. </li>
  49. <li class="menu-security">
  50. <a href="/Home/ChangePass">
  51. @Lang.ChangePassword
  52. @*Thay đổi mật khẩu*@
  53. </a>
  54. </li>
  55. </ul>
  56. </div>
  57. </div>
  58. </div>
  59. <div class="setting-right">
  60. <div class="setting-right-content">
  61. <style>
  62. @@media (min-width: 768px) {
  63. #modal-update-password .modal-dialog {
  64. width: 460px;
  65. margin-top: 70px;
  66. }
  67. }
  68. @@media(max-width: 768px) {
  69. .setting-personal .personal-avatar-group {
  70. float: none;
  71. width: 100%;
  72. margin-left: 0px;
  73. }
  74. .setting-personal .personal-info {
  75. width: 100%;
  76. float: left;
  77. margin-top: 20px;
  78. }
  79. }
  80. </style>
  81. <h1>
  82. @Lang.MyInformation
  83. @*Thông tin của tôi*@
  84. </h1>
  85. <div class="right-item">
  86. <div class="setting-default setting-personal">
  87. <div class="personal-avatar-group">
  88. <p class="update-avatar-label">
  89. @Lang.ChooseYourPicture
  90. @*Chọn ảnh của bạn*@
  91. </p>
  92. <div class="personal-image" style="margin: 10px 0 50px 0;">
  93. @*<span class="image-text" style="background: #FEBF10">H</span>*@
  94. @*<span class="image-text" style="background: #FEBF10">H</span>
  95. <img src="~/Content/assets/imgs/picture/course/1grammar.jpg" />
  96. <img src="~/Content/assets/imgs/post/1523464517.jpeg" />*@
  97. @{
  98. System.Diagnostics.Debug.WriteLine("image: " + Model.profileDetail.picture);
  99. if (Model.profileDetail.picture == "")
  100. {
  101. <span class="image-text" style="background: #FEBF10">H</span>
  102. }
  103. else
  104. {
  105. <img id="personal-picture" src="@Model.profileDetail.picture" />
  106. }
  107. }
  108. <div style="margin:20px 0px 100px 0px">
  109. @using (Html.BeginForm("UploadImage", "Home", FormMethod.Post, new { id = "myForm", enctype = "multipart/form-data" }))
  110. {
  111. @*<label for="file">Upload Image:</label>*@
  112. <input type="file" name="file" id="file" />
  113. <input type="submit" id="submit" value="Upload Image" style="margin: 10px 0px 10px 0px; display: none;" />
  114. <script>
  115. var oFReader = null;
  116. $(document).ready(function () {
  117. $('#file').change(function (e) {
  118. $('#submit').css('display', "block");
  119. $('#file').css('display', "none");
  120. var fileLoad = document.getElementById("file").files[0];
  121. var fileExt = fileLoad.name.match(/(.*)\??/i).shift().replace(/\?.*/, '').split('.').pop();
  122. if (fileExt != "png" && fileExt != "jpg") {
  123. $('#message-dialog').modal('show');
  124. $('#message-content').html("File Extension Is InValid - Only Upload PNG/JPG File");
  125. } else if (fileLoad.size >= 5 * 1024 * 1024 || fileLoad.size < 100) {
  126. $('#message-dialog').modal('show');
  127. $('#message-content').html("File size Should Be UpTo 5MB and min size is 100KB");
  128. } else {
  129. var oFReader = new FileReader();
  130. oFReader.readAsDataURL(fileLoad);
  131. oFReader.onload = function (oFREvent) {
  132. document.getElementById("personal-picture").src = oFREvent.target.result;
  133. };
  134. var control = $("#file");
  135. control.replaceWith(control = control.clone(true));
  136. }
  137. //var oFReader = new FileReader();
  138. //oFReader.readAsDataURL(document.getElementById("file").files[0]);
  139. //oFReader.onload = function (oFREvent) {
  140. // document.getElementById("personal-picture").src = oFREvent.target.result;
  141. // $('#file').reset();
  142. //};
  143. });
  144. });
  145. </script>
  146. @*@ViewBag.Message*@
  147. }
  148. </div>
  149. </div>
  150. <div class="image-group">
  151. <div class="image-item avatar-item">
  152. <img alt="@Lang.Determination" data-toggle="tooltip" data-placement="right" title="@Lang.Determination" src="~/Content/assets/imgs/post/avatar_aspiration.png" />
  153. </div>
  154. <div class="image-item avatar-item">
  155. <img alt="@Lang.Hope" data-toggle="tooltip" data-placement="right" title="@Lang.Hope" src="~/Content/assets/imgs/post/avatar_hope.png" />
  156. </div>
  157. <div class="image-item avatar-item">
  158. <img alt="@Lang.Clever" data-toggle="tooltip" data-placement="right" title="@Lang.Clever" src="~/Content/assets/imgs/post/avatar_intelligent.png" />
  159. </div>
  160. <div class="image-item avatar-item">
  161. <img alt="@Lang.Active" data-toggle="tooltip" data-placement="right" title="@Lang.Active" src="~/Content/assets/imgs/post/avatar_creation.png" />
  162. </div>
  163. <div class="image-item avatar-item">
  164. <img alt="@Lang.Strong" data-toggle="tooltip" data-placement="right" title="@Lang.Strong" src="~/Content/assets/imgs/post/avatar_strong.png" />
  165. </div>
  166. <div class="image-item avatar-item">
  167. <img alt="@Lang.Passion" data-toggle="tooltip" data-placement="right" title="@Lang.Passion" src="~/Content/assets/imgs/post/avatar_passion.png" />
  168. </div>
  169. <div class="image-item avatar-item">
  170. <img alt="@Lang.Enthusiasm" data-toggle="tooltip" data-placement="right" title="@Lang.Enthusiasm" src="~/Content/assets/imgs/post/avatar_enthusiasm.png" />
  171. </div>
  172. <div class="image-item avatar-item">
  173. <img alt="@Lang.Aspiration" data-toggle="tooltip" data-placement="right" title="@Lang.Aspiration" src="~/Content/assets/imgs/post/avatar_aspiration.png" />
  174. </div>
  175. <div class="image-item avatar-item">
  176. <img alt="@Lang.Secret" data-toggle="tooltip" data-placement="right" title="@Lang.Secret" src="~/Content/assets/imgs/post/avatar_secret.png" />
  177. </div>
  178. <div class="image-item avatar-item">
  179. <img alt="@Lang.Confident" data-toggle="tooltip" data-placement="right" title="@Lang.Confident" src="~/Content/assets/imgs/post/avatar_confidence.png" />
  180. </div>
  181. </div>
  182. </div>
  183. <div class="personal-info">
  184. @*<form method="post" action="/Home/UpdateProfile">*@
  185. <input type="hidden" name="_token" value="uBG5dtnM0z92gZHHm9CESPZY7ImlOEj3zh7c3Yen">
  186. <label for="personal-name" class="info-label">
  187. @Lang.Name
  188. @*Họ và tên*@
  189. </label>
  190. <div class="info-input">
  191. <input class="input-text" placeholder="@Lang.Name" type="text" id="personal-name" value="@Model.profileDetail.fullName" name="name" />
  192. <span class="input-line"></span>
  193. </div>
  194. <label for="personal-phone" class="info-label">@Lang.PhoneNumber</label>
  195. <div class="info-input">
  196. <input disabled class="input-text" placeholder="@Lang.PhoneNumber" type="text" id="personal-phone" value="@Model.profileDetail.users" name="phone_number" />
  197. <span class="input-line"></span>
  198. </div>
  199. <label for="personal-name" class="info-label">@Lang.Birthday</label>
  200. <div class="info-input">
  201. <input type="hidden" id="birthday-data" value="@Model.profileDetail.birthday" />
  202. <input type="date" onchange="changeDate()" id="personal-birthday" name="birthday" style=" display: block; width: 100%; border-radius: 5px; border: 0px; font-size: 15px;" value="@Model.profileDetail.birthday">
  203. @*<a class="input-text" placeholder="Birthday" id="personal-birthday" value="@Model.profileDetail.birthday" name="birthday">@Model.profileDetail.birthday</a>*@
  204. <span class="input-line"></span>
  205. <script>
  206. // convert birthday
  207. var birthday = $("#birthday-data").val();
  208. var splitBirthday = birthday.split('/').reverse();
  209. var result = "";
  210. for (var i = 0; i < splitBirthday.length; i++) {
  211. if (i == 0) result = splitBirthday[i];
  212. else result += ("-" + splitBirthday[i]);
  213. }
  214. document.getElementById('personal-birthday').value = result;
  215. </script>
  216. </div>
  217. <button id="update-info-button" class="setting-button-save" type="submit" onclick="return checkUpdateInformation();">@Lang.Submit</button>
  218. @*</form>*@
  219. <script>
  220. function changeDate() {
  221. var newBirthday = document.getElementById('personal-birthday').value;
  222. var oldBirthday = document.getElementById('birthday-data').value;
  223. if (newBirthday != oldBirthday) {
  224. $('.setting-personal .personal-info .setting-button-save').addClass('button-active');
  225. } else {
  226. }
  227. }
  228. </script>
  229. </div>
  230. <div class="clearfix"></div>
  231. </div>
  232. </div>
  233. <script>
  234. $('.menu-item-information').addClass('menu-active');
  235. $('.menu-information').addClass('menu-active');
  236. $(function () {
  237. $('[data-toggle="tooltip"]').tooltip()
  238. })
  239. $(document).on("click", ".avatar-item img", function () {
  240. console.log("avatar click");
  241. var linkAvatar = $(this).attr('src');
  242. console.log(linkAvatar);
  243. document.getElementById("personal-picture").src = linkAvatar;
  244. $.ajax({
  245. url: urlConfig("/Home/UploadExistedImage"),
  246. type: "POST",
  247. data: {
  248. __RequestVerificationToken: $('input[name=__RequestVerificationToken]').val(),
  249. picture: linkAvatar,
  250. }
  251. }).success(function (data) {
  252. if (data.error_code != "0") {
  253. // fail
  254. $('#message-dialog').modal('show');
  255. $('#message-content').html(data.error_content);
  256. } else {
  257. console.log(data.error_content);
  258. $('#message-dialog').modal('show');
  259. $('#message-content').html(data.error_content);
  260. }
  261. });
  262. });
  263. $('#update-info-button').click(function () {
  264. var check = $("#update-info-button").hasClass("button-active");
  265. if (check == true) {
  266. var fullname = $('#personal-name').val();
  267. var phone = $('#personal-phone').val();
  268. var birthdayDate = $('#personal-birthday').val();
  269. // convert birthday
  270. var splitBirthday = birthdayDate.split('-').reverse();
  271. var birthday = "";
  272. for (var i = 0; i < splitBirthday.length; i++) {
  273. if (i == 0) birthday = splitBirthday[i];
  274. else birthday += ("/" + splitBirthday[i]);
  275. }
  276. $.ajax({
  277. url: urlConfig("/Home/UpdateProfile"),
  278. type: "POST",
  279. data: {
  280. __RequestVerificationToken: $('input[name=__RequestVerificationToken]').val(),
  281. fullname: fullname,
  282. phone: phone,
  283. birthday: birthday,
  284. }
  285. }).success(function (data) {
  286. if (data.error_code != "0") {
  287. // fail
  288. $('#message-dialog').modal('show');
  289. $('#message-content').html(data.error_content);
  290. } else {
  291. console.log(data.error_content);
  292. if (data.href != null) {
  293. location.href = data.href;
  294. } else {
  295. location.reload();
  296. }
  297. }
  298. });
  299. } else {
  300. console.log("not update");
  301. }
  302. });
  303. </script>
  304. @*<div id="modal-update-password" class="modal fade" tabindex="-1" role="dialog">
  305. <div class="modal-dialog" role="document">
  306. <div class="modal-content">
  307. <a class="modal-button-close" href="javascript:void(0)" data-dismiss="modal"></a>
  308. <div class="setting-tab-pane">
  309. <p class="setting-modal-title">Thay đổi mật khẩu</p>
  310. <label for="new-password" class="info-label">Mật khẩu mới</label>
  311. <div class="info-input">
  312. <input class="input-text" placeholder="Nhập mật khẩu" type="password" id="new-password" />
  313. <span class="input-line"></span>
  314. </div>
  315. <label for="confirm-password" class="info-label">Nhập lại mật khẩu</label>
  316. <div class="info-input">
  317. <input class="input-text" placeholder="Nhập mật khẩu" type="password" id="confirm-password" />
  318. <span class="input-line"></span>
  319. </div>
  320. <button id="update-pass-button" class="setting-button-save" type="button" onclick="return checkUpdatePassword();">Lưu thay đổi</button>
  321. </div>
  322. </div>
  323. </div>
  324. </div>
  325. <script>
  326. $('#update-pass-button').click(function () {
  327. var password = $('#new-password').val();
  328. $.ajax({
  329. url: urlConfig("/Home/UpdatePass"),
  330. type: "POST",
  331. data: {
  332. __RequestVerificationToken: $('input[name=__RequestVerificationToken]').val(),
  333. password: password,
  334. }
  335. }).success(function (data) {
  336. if (data.error_code != "0") {
  337. // fail
  338. $('#message-dialog').modal('show');
  339. $('#message-content').html(data.error_content);
  340. } else {
  341. console.log(data.error_content);
  342. $('#message-dialog').modal('show');
  343. $('#message-content').html("Update password successful");
  344. //if (data.href != null) {
  345. // location.href = data.href;
  346. //} else {
  347. // location.reload();
  348. //}
  349. }
  350. });
  351. });
  352. </script>*@
  353. </div>
  354. </div>
  355. <div class="clearfix"></div>
  356. </div>
  357. </div>
  358. </div>