HEX
Server: LiteSpeed
System: Linux premium127.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
User: luxbsolr (925)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: /home/luxbsolr/cardsord.store/wp-content/plugins/woocommerce-shipping/client/utils/analytics.ts
import {
	getDateParamsFromQuery,
	appendTimestamp,
	getCurrentDates,
} from '@woocommerce/date';
import { addQueryArgs } from '@wordpress/url';
import { getLabelsReportPath } from 'data/routes';
import { ReportQuery } from 'types';

const defaultFields = [
	'created_date',
	'order_id',
	'rate',
	'service_name',
	'refund',
	'tracking',
	'carrier_id',
];

export const createDateQuery = ( query: Record< string, string > ) => {
	const { period, compare, before, after } = getDateParamsFromQuery( query );
	const { primary, secondary } = getCurrentDates( query );
	return {
		period,
		compare,
		before,
		after,
		primary,
		secondary,
	};
};

export const getQueryParameters = (
	dateQuery: ReturnType< typeof createDateQuery >,
	pagination: {
		perPage: string;
		offset: string;
	}
) => {
	const afterDate = encodeURIComponent(
		appendTimestamp( dateQuery.primary.after, 'start' )
	);
	const beforeDate = encodeURIComponent(
		appendTimestamp( dateQuery.primary.before, 'end' )
	);

	return {
		after: afterDate,
		before: beforeDate,
		per_page: pagination.perPage,
		offset: pagination.offset,
		fields: defaultFields,
	};
};

export const createReportQueryPath = ( query: ReportQuery ) =>
	addQueryArgs(
		getLabelsReportPath(),
		getQueryParameters( createDateQuery( query ), {
			perPage: query.perPage,
			offset: query.offset,
		} )
	);