liff-functions.js 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. function getProfile() {
  2. liff
  3. .getProfile()
  4. .then(profile => {
  5. console.log(JSON.stringify(profile));
  6. window.alert(JSON.stringify(profile));
  7. })
  8. .catch(e => {
  9. console.log(e);
  10. window.alert(e);
  11. });
  12. }
  13. function getAccessToken() {
  14. window.alert(liff.getAccessToken());
  15. }
  16. function getContext() {
  17. window.alert(JSON.stringify(liff.getContext()));
  18. }
  19. function sendMessage() {
  20. liff
  21. .sendMessages([{ type: "text", text: "中文測試 Hello from LIFF2.0" }])
  22. .then(() => {
  23. window.alert("Message has been sent");
  24. })
  25. .catch(e => {
  26. window.alert(e);
  27. });
  28. }
  29. function login() {
  30. liff.login();
  31. }
  32. function scanCode() {
  33. liff
  34. .scanCode()
  35. .then(result => {
  36. window.alert(JSON.stringify(result));
  37. })
  38. .catch(e => {
  39. window.alert(e);
  40. });
  41. }
  42. function openWindow() {
  43. liff.openWindow({
  44. url: "https://sirateek.me",
  45. external: true
  46. });
  47. }
  48. function closeWindow() {
  49. liff.closeWindow();
  50. }
  51. function logout() {
  52. if (liff.isLoggedIn()) {
  53. liff.logout();
  54. window.alert("Successfully to Logout");
  55. location.reload();
  56. }
  57. }
  58. function createFlexMessageData() {
  59. var myFlexContent = {
  60. "type": "carousel",
  61. "contents": [
  62. {
  63. "type": "bubble",
  64. "size": "nano",
  65. "header": {
  66. "type": "box",
  67. "layout": "vertical",
  68. "contents": [
  69. {
  70. "type": "text",
  71. "text": "In Progress",
  72. "color": "#ffffff",
  73. "align": "start",
  74. "size": "md",
  75. "gravity": "center"
  76. },
  77. {
  78. "type": "text",
  79. "text": "70%",
  80. "color": "#ffffff",
  81. "align": "start",
  82. "size": "xs",
  83. "gravity": "center",
  84. "margin": "lg"
  85. },
  86. {
  87. "type": "box",
  88. "layout": "vertical",
  89. "contents": [
  90. {
  91. "type": "box",
  92. "layout": "vertical",
  93. "contents": [
  94. {
  95. "type": "filler"
  96. }
  97. ],
  98. "width": "70%",
  99. "backgroundColor": "#0D8186",
  100. "height": "6px"
  101. }
  102. ],
  103. "backgroundColor": "#9FD8E36E",
  104. "height": "6px",
  105. "margin": "sm"
  106. }
  107. ],
  108. "backgroundColor": "#27ACB2",
  109. "paddingTop": "19px",
  110. "paddingAll": "12px",
  111. "paddingBottom": "16px"
  112. },
  113. "body": {
  114. "type": "box",
  115. "layout": "vertical",
  116. "contents": [
  117. {
  118. "type": "box",
  119. "layout": "horizontal",
  120. "contents": [
  121. {
  122. "type": "text",
  123. "text": "Buy milk and lettuce before class",
  124. "color": "#8C8C8C",
  125. "size": "sm",
  126. "wrap": true
  127. }
  128. ],
  129. "flex": 1
  130. }
  131. ],
  132. "spacing": "md",
  133. "paddingAll": "12px"
  134. },
  135. "styles": {
  136. "footer": {
  137. "separator": false
  138. }
  139. }
  140. },
  141. {
  142. "type": "bubble",
  143. "size": "nano",
  144. "header": {
  145. "type": "box",
  146. "layout": "vertical",
  147. "contents": [
  148. {
  149. "type": "text",
  150. "text": "Pending",
  151. "color": "#ffffff",
  152. "align": "start",
  153. "size": "md",
  154. "gravity": "center"
  155. },
  156. {
  157. "type": "text",
  158. "text": "30%",
  159. "color": "#ffffff",
  160. "align": "start",
  161. "size": "xs",
  162. "gravity": "center",
  163. "margin": "lg"
  164. },
  165. {
  166. "type": "box",
  167. "layout": "vertical",
  168. "contents": [
  169. {
  170. "type": "box",
  171. "layout": "vertical",
  172. "contents": [
  173. {
  174. "type": "filler"
  175. }
  176. ],
  177. "width": "30%",
  178. "backgroundColor": "#DE5658",
  179. "height": "6px"
  180. }
  181. ],
  182. "backgroundColor": "#FAD2A76E",
  183. "height": "6px",
  184. "margin": "sm"
  185. }
  186. ],
  187. "backgroundColor": "#FF6B6E",
  188. "paddingTop": "19px",
  189. "paddingAll": "12px",
  190. "paddingBottom": "16px"
  191. },
  192. "body": {
  193. "type": "box",
  194. "layout": "vertical",
  195. "contents": [
  196. {
  197. "type": "box",
  198. "layout": "horizontal",
  199. "contents": [
  200. {
  201. "type": "text",
  202. "text": "Wash my car",
  203. "color": "#8C8C8C",
  204. "size": "sm",
  205. "wrap": true
  206. }
  207. ],
  208. "flex": 1
  209. }
  210. ],
  211. "spacing": "md",
  212. "paddingAll": "12px"
  213. },
  214. "styles": {
  215. "footer": {
  216. "separator": false
  217. }
  218. }
  219. },
  220. {
  221. "type": "bubble",
  222. "size": "nano",
  223. "header": {
  224. "type": "box",
  225. "layout": "vertical",
  226. "contents": [
  227. {
  228. "type": "text",
  229. "text": "In Progress",
  230. "color": "#ffffff",
  231. "align": "start",
  232. "size": "md",
  233. "gravity": "center"
  234. },
  235. {
  236. "type": "text",
  237. "text": "100%",
  238. "color": "#ffffff",
  239. "align": "start",
  240. "size": "xs",
  241. "gravity": "center",
  242. "margin": "lg"
  243. },
  244. {
  245. "type": "box",
  246. "layout": "vertical",
  247. "contents": [
  248. {
  249. "type": "box",
  250. "layout": "vertical",
  251. "contents": [
  252. {
  253. "type": "filler"
  254. }
  255. ],
  256. "width": "100%",
  257. "backgroundColor": "#7D51E4",
  258. "height": "6px"
  259. }
  260. ],
  261. "backgroundColor": "#9FD8E36E",
  262. "height": "6px",
  263. "margin": "sm"
  264. }
  265. ],
  266. "backgroundColor": "#A17DF5",
  267. "paddingTop": "19px",
  268. "paddingAll": "12px",
  269. "paddingBottom": "16px"
  270. },
  271. "body": {
  272. "type": "box",
  273. "layout": "vertical",
  274. "contents": [
  275. {
  276. "type": "box",
  277. "layout": "horizontal",
  278. "contents": [
  279. {
  280. "type": "text",
  281. "text": "Buy milk and lettuce before class",
  282. "color": "#8C8C8C",
  283. "size": "sm",
  284. "wrap": true
  285. }
  286. ],
  287. "flex": 1
  288. }
  289. ],
  290. "spacing": "md",
  291. "paddingAll": "12px"
  292. },
  293. "styles": {
  294. "footer": {
  295. "separator": false
  296. }
  297. }
  298. }
  299. ]
  300. };
  301. var flex = {
  302. "type": "flex",
  303. "altText": _title,
  304. "contents": myFlexContent,
  305. };
  306. return flex;
  307. }
  308. function shareTargetPicker() {
  309. var xx=createFlexMessageData() ;
  310. liff
  311. .shareTargetPicker([
  312. xx
  313. ])
  314. .then(() => {
  315. alert("Shared to the friend(s) you picked");
  316. })
  317. .catch(function(res) {
  318. alert(res);
  319. });
  320. }