HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux wordpress-ubuntu-s-2vcpu-4gb-fra1-01 5.4.0-169-generic #187-Ubuntu SMP Thu Nov 23 14:52:28 UTC 2023 x86_64
User: root (0)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/shoetique/wp-content/plugins/googleanalytics/js/googleanalytics_dashboard.js
/**
 * GoogleAnalytics Dashboard JS.
 *
 * @package GoogleAnalytics
 */

(function ($) {
	const wrapperSelector = '#ga-dashboard-widget';
	const minWidth        = 350;
	const offset          = 10;

	ga_dashboard = {
		chartData: [],
		init: function (dataArr, showLoader) {
			if (showLoader) {
				ga_loader.show();
			}

			if ( google ) {
				google.charts.load( 'current', { 'packages': [ 'corechart' ] } );
				google.charts.setOnLoadCallback(
					function () {
						if ( dataArr ) {
							ga_dashboard.drawChart( dataArr );
							ga_dashboard.setChartData( dataArr );
						}
					}
				);
			}
		},
		events: function (data) {
			$( document ).ready(
				function () {
					$( '#range-selector' ).on(
						'change',
						function () {
							const selected        = $( this ).val();
							const selected_name   = $( '#metrics-selector option:selected' ).html();
							const selected_metric = $( '#metrics-selector option:selected' ).val() || null;

							ga_loader.show();

							var dataObj             = {};
							dataObj['action']       = "ga_ajax_data_change";
							dataObj['date_range']   = selected;
							dataObj['metric']       = selected_metric;
							dataObj[GA_NONCE_FIELD] = GA_NONCE;

							$.ajax(
								{
									type: "post",
									dataType: "json",
									url: ajaxurl,
									data: dataObj,
									success: function (response) {

										ga_loader.hide();

										if (typeof response.error !== "undefined") {
											$( '#ga_widget_error' )
												.removeClass( 'hidden' )
												.html( `GA Dashboard: ${response.error}` );
										} else {
											var dataT = [['Day', selected_name]];
											$.each(
												response.chart,
												function (k, v) {
													dataT.push( [v.day, parseInt( v.current )] );
												}
											);

											$.each(
												response.boxes,
												function (k, v) {
													$( '#ga_box_dashboard_label_' + k ).html( v.label )
													$( '#ga_box_dashboard_value_' + k ).html( v.value );
												}
											);

											ga_dashboard.drawChart( dataT, selected_name );

											// Set new data.
											ga_dashboard.setChartData( dataT );
										}
									}
								}
							);
						}
					);

					$( '#metrics-selector' ).on(
						'change',
						function () {
							const selected       = $( this ).val();
							const selected_name  = $( '#metrics-selector option:selected' ).html();
							const selected_range = $( '#range-selector option:selected' ).val() || null;

							ga_loader.show();

							var dataObj             = {};
							dataObj['action']       = "ga_ajax_data_change";
							dataObj['metric']       = selected;
							dataObj['date_range']   = selected_range;
							dataObj[GA_NONCE_FIELD] = GA_NONCE;

							$.ajax(
								{
									type: "post",
									dataType: "json",
									url: ajaxurl,
									data: dataObj,
									success: function (response) {
										ga_loader.hide();

										if (typeof response.error !== "undefined") {
											$( '#ga_widget_error' )
												.removeClass( 'hidden' )
												.html( `GA Dashboard: ${response.error}` );
										} else {
											var dataT = [['Day', selected_name]];
											$.each(
												response.chart,
												function (k, v) {
													dataT.push( [v.day, parseInt( v.current )] );
												}
											);

											ga_dashboard.drawChart( dataT, selected_name );

											// Set new data.
											ga_dashboard.setChartData( dataT );
										}
									}
								}
							);
						}
					);

					$( '#ga-widget-trigger' ).on(
						'click',
						function () {
							const selected_name   = $( '#metrics-selector option:selected' ).html();
							const selected_metric = $( '#metrics-selector option:selected' ).val() || null;
							const selected_range  = $( '#range-selector option:selected' ).val() || null;

							ga_loader.show();

							var dataObj             = {};
							dataObj['action']       = "ga_ajax_data_change";
							dataObj['metric']       = selected_metric;
							dataObj['date_range']   = selected_range;
							dataObj[GA_NONCE_FIELD] = GA_NONCE;

							$.ajax(
								{
									type: "post",
									dataType: "json",
									url: ajaxurl,
									data: dataObj,
									success: function (response) {

										ga_loader.hide();

										if (typeof response.error !== "undefined") {
											$( '#ga_widget_error' )
												.removeClass( 'hidden' )
												.html( `GA Dashboard: ${response.error}` );
										} else {
											var dataT = [['Day', selected_name]];
											$.each(
												response.chart,
												function (k, v) {
													dataT.push( [v.day, parseInt( v.current )] );
												}
											);

											$.each(
												response.boxes,
												function (k, v) {
													$( '#ga_box_dashboard_label_' + k ).html( v.label )
													$( '#ga_box_dashboard_value_' + k ).html( v.value );
												}
											);

											ga_dashboard.drawChart( dataT, selected_name );

											// Set new data.
											ga_dashboard.setChartData( dataT );
										}
									}
								}
							);
						}
					);

					$( window ).on(
						'resize',
						function () {
							ga_dashboard.drawChart( ga_dashboard.getChartData(), ga_tools.recomputeChartWidth( minWidth, offset, wrapperSelector ) );
						}
					);
				}
			);
		},
		/**
		 * Returns chart data array.
		 *
		 * @returns {Array}
		 */
		getChartData: function () {
			return ga_dashboard.chartData;
		},
		/**
		 * Overwrites initial data array.
		 *
		 * @param new_data
		 */
		setChartData: function (new_data) {
			ga_dashboard.chartData = new_data;
		},
		drawChart: function (dataArr, title) {
			const chart_dom_element = document.getElementById( 'chart_div' );

			if (typeof title == 'undefined') {
				title = 'Pageviews';
			}

			if (dataArr.length > 1) {
				const data = google.visualization.arrayToDataTable( dataArr );

				const options = {
					/*title: title,*/
					legend: 'top',
					lineWidth: 2,
					chartArea: {
						left: 10,
						top: 60,
						bottom: 50,
						right: 10

					},
					width: '95%',
					height: 300,
					hAxis: {title: 'Day', titleTextStyle: {color: '#333'}, direction: 1},
					vAxis: {minValue: 0},
					pointSize: 5
				};

				var chart = new google.visualization.AreaChart( chart_dom_element );
				google.visualization.events.addListener(
					chart,
					'ready',
					function () {
						ga_loader.hide();
					}
				);
				chart.draw( data, options );
			} else {
				$( '#ga_widget_error' )
					.removeClass( 'hidden' )
					.html( 'GA Dashboard: No data available for selected range.' );
			}
		}
	};

})( jQuery );