UNPKG

tix-react-ssr

Version:

Tiket.com React Project Scripts

6 lines 6.16 kB
'use strict';Object.defineProperty(exports,"__esModule",{value:true});exports.GTM=undefined;var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||false;descriptor.configurable=true;if("value"in descriptor)descriptor.writable=true;Object.defineProperty(target,descriptor.key,descriptor);}}return function(Constructor,protoProps,staticProps){if(protoProps)defineProperties(Constructor.prototype,protoProps);if(staticProps)defineProperties(Constructor,staticProps);return Constructor;};}();var _extends=Object.assign||function(target){for(var i=1;i<arguments.length;i++){var source=arguments[i];for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){target[key]=source[key];}}}return target;};var _react=require('react');var _react2=_interopRequireDefault(_react);var _hoistNonReactStatics=require('hoist-non-react-statics');var _hoistNonReactStatics2=_interopRequireDefault(_hoistNonReactStatics);var _ExecutionEnvironment=require('fbjs/lib/ExecutionEnvironment');var _propTypes=require('prop-types');var _eventListener=require('./eventListener');var _eventListener2=_interopRequireDefault(_eventListener);var _visibility=require('./visibility');var _visibility2=_interopRequireDefault(_visibility);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj};}function _defineProperty(obj,key,value){if(key in obj){Object.defineProperty(obj,key,{value:value,enumerable:true,configurable:true,writable:true});}else{obj[key]=value;}return obj;}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError("Cannot call a class as a function");}}function _possibleConstructorReturn(self,call){if(!self){throw new ReferenceError("this hasn't been initialised - super() hasn't been called");}return call&&(typeof call==="object"||typeof call==="function")?call:self;}function _inherits(subClass,superClass){if(typeof superClass!=="function"&&superClass!==null){throw new TypeError("Super expression must either be null or a function, not "+typeof superClass);}subClass.prototype=Object.create(superClass&&superClass.prototype,{constructor:{value:subClass,enumerable:false,writable:true,configurable:true}});if(superClass)Object.setPrototypeOf?Object.setPrototypeOf(subClass,superClass):subClass.__proto__=superClass;}var GTM=exports.GTM={pushObject:function pushObject(object){window.dataLayer=window.dataLayer||[];window.dataLayer.push(object);},handleTags:function handleTags(){if(!window.tixHandlingTag){window.tixHandlingTag=true;}// Click tag (0,_eventListener2.default)(document,'click touchend gtm','[data-click]',function(){if(!this.dataset.clicked||this.dataset.repeatable){var eventObject=this.getAttribute('data-click');console.log('SENDING GTM Object',eventObject);try{eventObject=JSON.parse(eventObject);}catch(e){console.log(e);// Empty }this.dataset.clicked=true;GTM.pushObject(eventObject);}});// Impression (0,_eventListener2.default)(document,'resize scroll load gtm',function(){// TODO: Find a better way to handle element visibility change var impressions=Array.from(document.querySelectorAll('[data-impression]'));if(impressions&&Array.isArray(impressions)&&impressions.length>0){impressions.forEach(function(el){var triggered=el.dataset&&el.dataset.visible;if(!triggered&&(0,_visibility2.default)(el)){var eventObject=el.getAttribute('data-impression');if(!eventObject){return;}try{eventObject=JSON.parse(eventObject);}catch(e){console.error(e);// Empty }el.dataset.visible=true;GTM.pushObject(eventObject);}});}});}};function GTMHandler(){if(_ExecutionEnvironment.canUseDOM){var data=window.__data||window.__INITIAL_STATE__||{};var appData=data.app||{};var context=appData.context||{};var userData=appData.account&&appData.account.data||{};var userResult=userData.results||{};window.gtm=window.gtm||{};window.gtm=_extends({},window.gtm,{trackingId:context.trackingId||'',platform:context.deviceType||'WEB',vertical:'',orderId:context.query&&context.query.order_id||'',screenName:'',user:{user_id:userData.id||'',gender:'',nationality:'',dob:'',age:'',language:'',login_status:userData.login_status||'false',tix_point:userResult.point_balance&&userResult.point_balance.point_amount||0,signup_method:'',signup_date:userData.member_since||''}});}return function wrapWithGTMHandler(WrappedComponent){var wrappedComponentName=WrappedComponent.displayName||WrappedComponent.name||'Component';var displayName='GTMHandler('+wrappedComponentName+')';var GTMHandler=function(_Component){_inherits(GTMHandler,_Component);function GTMHandler(props){_classCallCheck(this,GTMHandler);var _this=_possibleConstructorReturn(this,(GTMHandler.__proto__||Object.getPrototypeOf(GTMHandler)).call(this,props));_this.error=0;_this.displayName='GTMHandler';return _this;}_createClass(GTMHandler,[{key:'componentDidMount',value:function componentDidMount(){var type=this.props.type;if(type){return;}GTM.handleTags();}},{key:'componentWillReceiveProps',value:function componentWillReceiveProps(nextProps){var payload=nextProps.payload,screenName=nextProps.screenName,loading=nextProps.loading,_nextProps$type=nextProps.type,type=_nextProps$type===undefined?'pageLoad':_nextProps$type;if(loading){return;}if(screenName&&type==='pageLoad'&&_ExecutionEnvironment.canUseDOM){GTM.pushObject({"gtm.screenName":screenName});}if(payload&&type==='pageLoad'){GTM.pushObject(payload);}}},{key:'render',value:function render(){var _this2=this;var _props=this.props,_props$type=_props.type,type=_props$type===undefined?'pageLoad':_props$type,_props$payload=_props.payload,payload=_props$payload===undefined?{}:_props$payload;var attr=_defineProperty({},'data-'+type,WrappedComponent.payload||payload);return(0,_react.createElement)(type!=='pageLoad'?WrappedComponent:WrappedComponent,_extends({},attr,this.props,{ref:function ref(r){return _this2.dom=r;}}));}}]);return GTMHandler;}(_react.Component);GTMHandler.WrappedComponent=WrappedComponent;GTMHandler.displayName=displayName;return(0,_hoistNonReactStatics2.default)(GTMHandler,WrappedComponent);};}exports.default=GTMHandler();