jeter20131220 3 years ago
parent
commit
a82c18d064
2 changed files with 119 additions and 90 deletions
  1. 103 79
      desktop11/goto.js
  2. 16 11
      desktop11/index.html

+ 103 - 79
desktop11/goto.js

@@ -253,87 +253,111 @@ $(document).ready(function () {
 // This is called with the results from from FB.getLoginStatus().
 
 
-// function statusChangeCallback(response) {
-//   console.log('statusChangeCallback');
-//   console.log(response);
-//   // The response object is returned with a status field that lets the
-//   // app know the current login status of the persopren.
-//   // Full docs on the response object can be found in the documentation
-//   // for FB.getLoginStatus().
-//   if (response.status === 'connected') {
-//     // Logged into your app and Facebook.
-//     login(response.authResponse.accessToken);
-//   } else if (response.status === 'not_authorized') {
-//     // The person is logged into Facebook, but not your app.
-//     console.log('The person is logged into Facebook, but not your app');
-//   } else {
-//     // The person is not logged into Facebook, so we're not sure if
-//     // they are logged into this app or not.
-//     console.log("The person is not logged into Facebook");
-//   }
-// }
-// // This function is called when someone finishes with the Login
-// // Button.  See the onlogin handler attached to it in the sample
-// // code below.
-// function checkLoginState() {
-//   FB.getLoginStatus(function (response) {
-//     statusChangeCallback(response);
-//   });
-// }
-// window.fbAsyncInit = function () {
-//   FB.init({
-//     appId: '1388696554848391',
-//     cookie: true,  // enable cookies to allow the server to access 
-//     // the session
-//     xfbml: true,  // parse social plugins on this page
-//     version: 'v11.0' // use version 2.2
+function statusChangeCallback(response) {
+  console.log('statusChangeCallback');
+  console.log(response);
+  // The response object is returned with a status field that lets the
+  // app know the current login status of the persopren.
+  // Full docs on the response object can be found in the documentation
+  // for FB.getLoginStatus().
+  if (response.status === 'connected') {
+    // Logged into your app and Facebook.
+    login(response.authResponse.accessToken);
+  } else if (response.status === 'not_authorized') {
+    // The person is logged into Facebook, but not your app.
+    console.log('The person is logged into Facebook, but not your app');
+  } else {
+    // The person is not logged into Facebook, so we're not sure if
+    // they are logged into this app or not.
+    console.log("The person is not logged into Facebook");
+  }
+}
+// This function is called when someone finishes with the Login
+// Button.  See the onlogin handler attached to it in the sample
+// code below.
+function checkLoginState() {
+  FB.getLoginStatus(function (response) {
+    statusChangeCallback(response);
+  });
+}
+window.fbAsyncInit = function () {
+  FB.init({
+    appId: '1388696554848391',
+    cookie: true,  // enable cookies to allow the server to access 
+    // the session
+    xfbml: true,  // parse social plugins on this page
+    version: 'v11.0' // use version 2.2
+  });
+};
+// Now that we've initialized the JavaScript SDK, we call
+// FB.getLoginStatus().  This function gets the state of the
+// person visiting this page and can return one of three states to
+// the callback you provide.  They can be:
+//
+// 1. Logged into your app ('connected')
+// 2. Logged into Facebook, but not your app ('not_authorized')
+// 3. Not logged into Facebook and can't tell if they are logged into
+//    your app or not.
+//
+// These three cases are handled in the callback function.
+// Load the SDK asynchronously
+(function (d, s, id) {
+  var js, fjs = d.getElementsByTagName(s)[0];
+  if (d.getElementById(id)) return;
+  js = d.createElement(s); js.id = id;
+  js.src = "//connect.facebook.net/en_US/sdk.js";
+  fjs.parentNode.insertBefore(js, fjs);
+}(document, "script", "facebook-jssdk"));
+// Here we run a very simple test of the Graph API after login is
+// successful.  See statusChangeCallback() for when this call is made.
+function loginNEMI(token) {
+  // 把 access_token 傳至後端再做資料拿取
+  console.log("Welcome!  Fetching your information.... ");
+  var xhr = new XMLHttpRequest();
+  xhr.open("POST", "/login", true);
+  xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
+  xhr.onreadystatechange = function () {
+    if (xhr.readyState === 4 && xhr.status === 200) {
+      if (JSON.parse(xhr.responseText).status === "ok")
+        location.href = "/index";
+      else
+        alert("something wrong!");
+    }
+  };
+  xhr.send("token=" + token);
+}
+// custom fb login button
+function fbLogin() {
+  // FB 第三方登入,要求公開資料與email
+  FB.login(function (response) {
+    statusChangeCallback(response);
+    console.log(response);
+  }, { scope: 'public_profile,email' });
+  if (response.id) {
+    // 設定欄位預設值
+    document.getElementById("email").value = response.email;
+    document.getElementById("name").value = response.name;
+
+    // 隱藏FB登入按鈕
+    document.getElementById("fb_login").style.display = 'none';
+  }
+}
+
+
+// function fb_login() {
+//   FB.api('/me/?fields=id,name,email', function (response) {
+//     console.log('FB API回傳資料: ' + JSON.stringify(response));
+
+//     if (response.id) {
+//       // 設定欄位預設值
+//       document.getElementById("email").value = response.email;
+//       document.getElementById("name").value = response.name;
+
+//       // 隱藏FB登入按鈕
+//       document.getElementById("fb_login").style.display = 'none';
+//     }
 //   });
 // };
-// // Now that we've initialized the JavaScript SDK, we call
-// // FB.getLoginStatus().  This function gets the state of the
-// // person visiting this page and can return one of three states to
-// // the callback you provide.  They can be:
-// //
-// // 1. Logged into your app ('connected')
-// // 2. Logged into Facebook, but not your app ('not_authorized')
-// // 3. Not logged into Facebook and can't tell if they are logged into
-// //    your app or not.
-// //
-// // These three cases are handled in the callback function.
-// // Load the SDK asynchronously
-// (function (d, s, id) {
-//   var js, fjs = d.getElementsByTagName(s)[0];
-//   if (d.getElementById(id)) return;
-//   js = d.createElement(s); js.id = id;
-//   js.src = "//connect.facebook.net/en_US/sdk.js";
-//   fjs.parentNode.insertBefore(js, fjs);
-// }(document, "script", "facebook-jssdk"));
-// // Here we run a very simple test of the Graph API after login is
-// // successful.  See statusChangeCallback() for when this call is made.
-// function loginNEMI(token) {
-//   // 把 access_token 傳至後端再做資料拿取
-//   console.log("Welcome!  Fetching your information.... ");
-//   var xhr = new XMLHttpRequest();
-//   xhr.open("POST", "/login", true);
-//   xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
-//   xhr.onreadystatechange = function () {
-//     if (xhr.readyState === 4 && xhr.status === 200) {
-//       if (JSON.parse(xhr.responseText).status === "ok")
-//         location.href = "/index";
-//       else
-//         alert("something wrong!");
-//     }
-//   };
-//   xhr.send("token=" + token);
-// }
-// // custom fb login button
-// function fb_login() {
-//   // FB 第三方登入,要求公開資料與email
-//   FB.login(function (response) {
-//     statusChangeCallback(response);
-//     console.log(response);
-//   }, { scope: 'public_profile,email' });
-// }
 
 
 

+ 16 - 11
desktop11/index.html

@@ -37,7 +37,7 @@
 
 
 <body id="top">
-    <script>
+    <!-- <script>
         function statusChangeCallback(response) {  // Called with the results from FB.getLoginStatus().
             if (response.status === 'connected') {  // 已登入
                 testAPI();
@@ -81,7 +81,7 @@
 
 
 
-    </script>
+    </script> -->
 
     <div class="container-fluid" style="padding:0;margin:0 ">
         <div class="banner container-fluid" style="padding:0; margin:0 ">
@@ -326,7 +326,7 @@
 
             <div class="container-fluid" style="padding:0; margin:0;">
                 <form class="contact-form1">
-                    <div id="contact-form" name="myForm" >
+                    <div id="contact-form" name="myForm">
                         <div id="form-left">
                             <select name="loc" id="loc" required>
                                 <option value="" disabled selected="selected">地區</option>
@@ -424,16 +424,20 @@
                         </div>
                         <hr>
 
-                        
+
                         <div id="form-right">
-                            
+
                             <div id="fb_login">
-                                <button  id="fb-button" scope="public_profile,email"
-                                onlogin="checkLoginState();"  ><img src="./img/logo/facebook.png" alt=""><p><span  style="padding-right:5vw; font-size: 25px;">|</span>使用fb填入信箱與姓名</p></button>
+                                <button id="fb-button" onClick="fbLogin()" scope="public_profile,email"
+                                    onlogin="checkLoginState();"><img src="./img/logo/facebook.png" alt="">
+                                    <p><span style="padding-right:5vw; font-size: 25px;">|</span>使用fb填入信箱與姓名</p>
+                                </button>
+                                <div id="status"></div>
                             </div>
                             <!-- <div id="fb_login">
                                 <fb:login-button id="fb-button" scope="public_profile,email"
-                                    onlogin="checkLoginState();"   data-button-type="continue_with" data-size="large">使用FB填入信箱與姓名
+                                    onlogin="checkLoginState();" data-button-type="continue_with" data-size="large">
+                                    使用FB填入信箱與姓名
                                 </fb:login-button>
                                 <div id="status"></div>
                             </div> -->
@@ -447,7 +451,8 @@
                                 <option class="option">女</option>
                             </select>
                             <input type="checkbox" style="margin:30px 10px;" id="checkbox" checked><label
-                                for="agree">同意</label><a  target="https://hhh.com.tw/about/privacy_policy/" href="https://hhh.com.tw/about/privacy_policy/">免責聲明與隱私使用政策</a>
+                                for="agree">同意</label><a target="https://hhh.com.tw/about/privacy_policy/"
+                                href="https://hhh.com.tw/about/privacy_policy/">免責聲明與隱私使用政策</a>
                         </div>
 
                     </div>
@@ -479,12 +484,12 @@
     <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.1/dist/js/bootstrap.min.js"
         integrity="sha384-Atwg2Pkwv9vp0ygtn1JAojH0nYbwNJLPhwyoVbhoPwBhjQPR5VtM2+xf0Uwh9KtT"
         crossorigin="anonymous"></script>
-        <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
+    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
     <script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
     <script type="text/javascript" src="//cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.min.js"></script>
 
     <script src="./goto.js"></script>
- 
+
 </body>
 
 </html>