/* global _ angular store moment */ 'use strict'; angular.module('DinsorApp.services', []) .factory('member', function($q, $http, $window, $location) { // var apikey = 'RSlFKu7tArWPu1eSru6yKebBsFdQB1Baef28bmBGoNxvFiAcN9'; var baseApi = '//valuecreation.ditp.go.th/service'; var language = 'th'; return { authorized: function() { var deferred = $q.defer(); $http.get(baseApi + '/user/authorized', { transformRequest: angular.identity, headers: { 'Content-Type': 'application/json' } }).then(function(response) { //console.log(response.data) if(response.data.user_id !=undefined) store.set('user', response.data); deferred.resolve(response.data); //deferred.resolve(user) }); return deferred.promise; }, form: function(id) { var deferred = $q.defer(); $http.get(baseApi + '/forms/th/'+id, { /* transformRequest: angular.identity, headers: { //'Authorization': 'Basic ' + btoa(program.key()+':'), 'Content-Type': undefined } */ }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; }, object: function(qryStr) { if(qryStr =='') return false; var object = {}; //qryStr.replace*('?','&'); qryStr.split('&').map(function(str) { object[str.split('=')[0]] = str.split('=')[1]; }); // return object; }, logout: function() { var deferred = $q.defer(); $http.get(baseApi + '/users/logout/th', { transformRequest: angular.identity, headers: { 'Content-Type': 'application/json' } }).then(function(response) { deferred.resolve(response.data); }); return deferred.promise;; } /* center: function(service) { if(!_.isUndefined(service)) return memberUrl+'/restapi/'+service; return; }, clear: function() { store.set('token', ''); }, signup: function(forminput) { var deferred = $q.defer(); var postdata = {}; angular.forEach(forminput, function(input) { var $input = angular.element(input); postdata[$input.attr('name')] = $input.val(); }); //console.log(postdata) var username = postdata['username']; delete postdata['username']; var password = postdata['password']; delete postdata['password']; if(password !==postdata['confirm_password']) { deferred.resolve( {err:true, msg:'รหัสผ่านไม่ถูกต้อง'} ) } else { delete postdata['confirm_password']; //console.log(postdata) $http.post(memberUrl + '/sso/authorize/signup', postdata, { headers: { 'Authorization': 'Basic ' + btoa(username+':'+password), //"Content-Type": 'application/json', }, }).then(function(response) { //console.log(response); deferred.resolve(response.data) }); } return deferred.promise; }, signin: function(forminput) { var deferred = $q.defer(); var postdata = {}; angular.forEach(forminput, function(input) { var $input = angular.element(input); //console.log($input.attr('name')) postdata[$input.attr('name')] = $input.val(); }); var username = postdata['username']; delete postdata['username']; var password = postdata['password']; delete postdata['password']; //console.log(postdata); $http.post(memberUrl + '/sso/authorize/signin', postdata, { headers: { 'Authorization': 'Basic ' + btoa(username+':'+password), }, }).then(function(response) { //console.log(response.data) deferred.resolve(response.data) }); // return deferred.promise; }, password: function(email) { var deferred = $q.defer(); //console.log(email) //console.log(program.key()) $http.get(memberUrl + '/sso/authorize/passwd', { headers: { 'Authorization': 'Basic ' + btoa(email+':'+$location.host()), }, }).then(function(response) { //console.log(response.data) deferred.resolve(response.data) }); // return deferred.promise; }, resetpassword: function(email, password) { var deferred = $q.defer(); //console.log(email) $http.get(memberUrl + '/sso/authorize/resetpasswd', { headers: { 'Authorization': 'Basic ' + btoa(email+':'+password), }, }).then(function(response) { //console.log(response.data) deferred.resolve(response.data) }); // return deferred.promise; }, registration: function(formregister, uuid) { var deferred = $q.defer(); var postdata = {}; angular.forEach(formregister, function(input) { var $input = angular.element(input); //console.log($input.attr('name')) if($input.attr('name')!=undefined) { switch($input.attr('type')) { case 'radio': if($input.is(':checked')) { postdata[$input.attr('name')] = $input.val(); } break; default: postdata[$input.attr('name')] = $input.val(); } } }); delete postdata['file']; //console.log(postdata) // $http.post(memberUrl + '/restapi/registration/program', postdata, { headers: { //'Authorization': 'Basic ' + btoa(program.key()+':'+uuid), }, }).then(function(response) { //console.log(response.data) deferred.resolve(response.data) }); return deferred.promise; }, upload: function(formdata, id) { var deferred = $q.defer(); //console.log(userpath + '/photo') $http.post(memberUrl + '/restapi/registration/upload/'+id, formdata, { transformRequest: angular.identity, headers: { //'Authorization': 'Basic ' + btoa(program.key()+':'), 'Content-Type': undefined } }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; } */ } }) .factory('user', function($q, $http, $window, $location) { // var apikey = 'RSlFKu7tArWPu1eSru6yKebBsFdQB1Baef28bmBGoNxvFiAcN9'; var baseUrl = '//valuecreation.ditp.go.th/admin'; var language = 'th'; return { clear: function() { store.set('user', ''); //store.set('token', ''); //store.destroy(); }, form: function(id) { var deferred = $q.defer(); $http.get(baseUrl + '/forms/th/'+id, { /* transformRequest: angular.identity, headers: { //'Authorization': 'Basic ' + btoa(program.key()+':'), 'Content-Type': undefined } */ }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; } } }) .factory('app', function($q, $http, $window, $location) { // var apikey = 'RSlFKu7tArWPu1eSru6yKebBsFdQB1Baef28bmBGoNxvFiAcN9'; var baseApi = '//valuecreation.ditp.go.th/admin/api'; var language = 'th'; return { language: function() { ///if(_.isUndefined(store.get('language'))) { // store.set('language', 'th'); //} //if(_.isDefined()) // if(language =='th') { store.set('language', 'en'); } else { store.set('language', 'th'); } language = store.get('language'); }, banners: function() { var deferred = $q.defer(); $http.get(baseApi + '/banner', { transformRequest: angular.identity, headers: { 'Authorization': 'Bearer ' + apikey, 'Content-Type': 'application/json' } }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; }, projects: function(query) { var deferred = $q.defer(); $http.get(baseApi + '/project/'+language, { params: query, transformRequest: angular.identity, headers: { 'Authorization': 'Bearer ' + apikey, 'Content-Type': 'application/json' } }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; }, knowledges: function(query) { var deferred = $q.defer(); //console.log(query) /*var query = {}; if(!_.isUndefined(type)) { query['type'] = type; } if(!_.isUndefined(id)) { query['id'] = id; }*/ $http.get(baseApi + '/knowledge/'+language, { params: query, transformRequest: angular.identity, headers: { 'Authorization': 'Bearer ' + apikey, 'Content-Type': 'application/json' } }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; }, news: function(type, id) { var deferred = $q.defer(); var query = {} if(!_.isUndefined(type)) { query['type'] = type; } if(!_.isUndefined(id)) { query['id'] = id; } $http.get(baseApi + '/newses/'+language, { params: query, transformRequest: angular.identity, headers: { 'Authorization': 'Bearer ' + apikey, 'Content-Type': 'application/json' } }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; }, galleries: function(query) { var deferred = $q.defer(); /*var query = {}; if(!_.isUndefined(type)) { query['type'] = type; } if(!_.isUndefined(id)) { query['id'] = id; }*/ $http.get(baseApi + '/gallery/'+language, { params: query, transformRequest: angular.identity, headers: { 'Authorization': 'Bearer ' + apikey, 'Content-Type': 'application/json' } }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; }, partner: function(query) { var deferred = $q.defer(); $http.get(baseApi + '/partner/'+language, { params: query, transformRequest: angular.identity, headers: { 'Authorization': 'Bearer ' + apikey, 'Content-Type': 'application/json' } }).then(function(response) { //console.log(response.data) deferred.resolve(response.data); }); return deferred.promise; }, login: function() { $http.get(baseApi + '/login', { transformRequest: angular.identity, headers: { 'Authorization': 'Bearer ' + apikey, 'Content-Type': 'application/json' } }).then(function(response) { console.log(response.data) //$window.location.href = response.data }); }, register: function() { } } }) .factory('alerts', function($interval) { var alerts = undefined; if (!window.alertsInterval) { window.alertsInterval = $interval(function() { var alive = []; _.forEach(alerts, function(alert) { if (!moment().isAfter(moment(alert.timestamp).add(5, 'seconds'))) { alive.push(alert); } }); alerts = alive; store.set('alerts', alerts); }, 1000); } return { clear: function() { store.set('alerts', []); }, get: function() { if (_.isUndefined(alerts)) { alerts = store.get('alerts'); } if (_.isEmpty(alerts)) { alerts = []; } return alerts; }, set: function(val) { alerts = val; store.set('alerts', alerts); }, success: function(msg) { alerts.push({id: Math.random().toString(16), success: msg, timestamp: new Date().getTime()}); store.set('alerts', alerts); }, fail: function(msg) { alerts.push({id: Math.random().toString(16), danger: msg, timestamp: new Date().getTime()}); store.set('alerts', alerts); } }; }) .service("sqlDate", function() { // this.date = function(sqlDate) { // var datetime = sqlDate.replace(" ", "T").split("T") var dates = datetime[0].split("-") var times = datetime[1].substring(0, 8).split(":") // var date = new Date(dates[0], parseInt(dates[1])-1, dates[2]) var time = new Date(1970, 0, 1, times[0], times[1], times[2]) datetime[0] = date; datetime[1] = time; // return datetime } this.budha = function(year) { // return (year + 543) } }) .service('analyticsHandler', function ($rootScope, $window) { angular.element(document).ready(function () { //console.log('element(document).ready'); (function (w, d, s, l, i) { w[l] = w[l] || []; w[l].push({ 'gtm.start': new Date().getTime(), event: 'gtm.js' }); var f = d.getElementsByTagName(s)[0], j = d.createElement(s), dl = l != 'dataLayer' ? '&l=' + l : ''; j.async = true; j.src = '//www.googletagmanager.com/gtm.js?id=' + i + dl; f.parentNode.insertBefore(j, f); })($window, document, 'script', 'tm', 'GTM-5GH3ZM9'); //note: I've changed original code to use $window instead of window }); // set user details $rootScope.$on("analyticalDataRetrieved", function (userDetails) { //console.log('analyticalDataRetrieved'); if ($window.tm) { $window.tm.push( { 'a': userDetails.Age, 'm': userDetails.MemberType }); } }); $rootScope.$on('$routeChangeSuccess', function (event) { if ($window.tm) { // this is an example I found around there using Google Analytics (ga), need to find out how to do it with GTM: //$window.ga('send', 'pageview', { page: $window.location.pathname }); } }); // Note: event is used to trigger the GoogleTagManager tracker, but its value is not sent to the server. // rest of values are sent to server as category, action, label (there's also value if we need it) // ec -> category, ea -> action, el -> label $rootScope.$on('upgradeMembershipClicked', function (event, data) { if ($window.tm) { $window.tm.push({ event: 'Paywall', ec: 'Paywall', ea: 'Click', el: data.gtmLabel }); } }); })