{
  "version": 3,
  "sources": ["../../../../src/components/dataviews-layouts/grid/index.tsx"],
  "sourcesContent": ["/**\n * External dependencies\n */\nimport clsx from 'clsx';\n\n/**\n * WordPress dependencies\n */\nimport { Spinner } from '@wordpress/components';\nimport { __, sprintf } from '@wordpress/i18n';\nimport { Stack } from '@wordpress/ui';\n\n/**\n * Internal dependencies\n */\nimport type { ViewGridProps } from '../../../types';\nimport getDataByGroup from '../utils/get-data-by-group';\nimport CompositeGrid from './composite-grid';\nimport { useDelayedLoading } from '../../../hooks/use-delayed-loading';\n\nfunction ViewGrid< Item >( {\n\tactions,\n\tdata,\n\tfields,\n\tgetItemId,\n\tisLoading,\n\tonChangeSelection,\n\tonClickItem,\n\tisItemClickable,\n\trenderItemLink,\n\tselection,\n\tview,\n\tclassName,\n\tempty,\n}: ViewGridProps< Item > ) {\n\tconst isDelayedLoading = useDelayedLoading( !! isLoading );\n\tconst hasData = !! data?.length;\n\tconst groupField = view.groupBy?.field\n\t\t? fields.find( ( f ) => f.id === view.groupBy?.field )\n\t\t: null;\n\tconst dataByGroup = groupField ? getDataByGroup( data, groupField ) : null;\n\tconst isInfiniteScroll = view.infiniteScrollEnabled && ! dataByGroup;\n\tif ( ! hasData ) {\n\t\treturn (\n\t\t\t<div\n\t\t\t\tclassName={ clsx( 'dataviews-no-results', {\n\t\t\t\t\t'is-refreshing': isDelayedLoading,\n\t\t\t\t} ) }\n\t\t\t>\n\t\t\t\t{ empty }\n\t\t\t</div>\n\t\t);\n\t}\n\tconst gridProps = {\n\t\tclassName: clsx( className, {\n\t\t\t'is-refreshing': ! isInfiniteScroll && isDelayedLoading,\n\t\t} ),\n\t\tinert: ! isInfiniteScroll && !! isLoading ? 'true' : undefined,\n\t\tisLoading,\n\t\tview,\n\t\tfields,\n\t\tselection,\n\t\tonChangeSelection,\n\t\tonClickItem,\n\t\tisItemClickable,\n\t\trenderItemLink,\n\t\tgetItemId,\n\t\tactions,\n\t};\n\treturn (\n\t\t<>\n\t\t\t{\n\t\t\t\t// Render multiple groups.\n\t\t\t\thasData && groupField && dataByGroup && (\n\t\t\t\t\t<Stack direction=\"column\" gap=\"lg\">\n\t\t\t\t\t\t{ Array.from( dataByGroup.entries() ).map(\n\t\t\t\t\t\t\t( [ groupName, groupItems ] ) => (\n\t\t\t\t\t\t\t\t<Stack\n\t\t\t\t\t\t\t\t\tdirection=\"column\"\n\t\t\t\t\t\t\t\t\tkey={ groupName }\n\t\t\t\t\t\t\t\t\tgap=\"sm\"\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<h3 className=\"dataviews-view-grid__group-header\">\n\t\t\t\t\t\t\t\t\t\t{ view.groupBy?.showLabel === false\n\t\t\t\t\t\t\t\t\t\t\t? groupName\n\t\t\t\t\t\t\t\t\t\t\t: sprintf(\n\t\t\t\t\t\t\t\t\t\t\t\t\t// translators: 1: The label of the field e.g. \"Date\". 2: The value of the field, e.g.: \"May 2022\".\n\t\t\t\t\t\t\t\t\t\t\t\t\t__( '%1$s: %2$s' ),\n\t\t\t\t\t\t\t\t\t\t\t\t\tgroupField.label,\n\t\t\t\t\t\t\t\t\t\t\t\t\tgroupName\n\t\t\t\t\t\t\t\t\t\t\t  ) }\n\t\t\t\t\t\t\t\t\t</h3>\n\t\t\t\t\t\t\t\t\t<CompositeGrid\n\t\t\t\t\t\t\t\t\t\t{ ...gridProps }\n\t\t\t\t\t\t\t\t\t\tdata={ groupItems }\n\t\t\t\t\t\t\t\t\t\tisInfiniteScroll={ false }\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</Stack>\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t) }\n\t\t\t\t\t</Stack>\n\t\t\t\t)\n\t\t\t}\n\t\t\t{\n\t\t\t\t// Render a single grid with all data.\n\t\t\t\t! dataByGroup && (\n\t\t\t\t\t<CompositeGrid\n\t\t\t\t\t\t{ ...gridProps }\n\t\t\t\t\t\tdata={ data }\n\t\t\t\t\t\tisInfiniteScroll={ !! isInfiniteScroll }\n\t\t\t\t\t/>\n\t\t\t\t)\n\t\t\t}\n\t\t\t{ isInfiniteScroll && isLoading && (\n\t\t\t\t<p className=\"dataviews-loading-more\">\n\t\t\t\t\t<Spinner />\n\t\t\t\t</p>\n\t\t\t) }\n\t\t</>\n\t);\n}\n\nexport default ViewGrid;\n"],
  "mappings": ";AAGA,OAAO,UAAU;AAKjB,SAAS,eAAe;AACxB,SAAS,IAAI,eAAe;AAC5B,SAAS,aAAa;AAMtB,OAAO,oBAAoB;AAC3B,OAAO,mBAAmB;AAC1B,SAAS,yBAAyB;AA0B/B,SA0BD,UA1BC,KAiCK,YAjCL;AAxBH,SAAS,SAAkB;AAAA,EAC1B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACD,GAA2B;AAC1B,QAAM,mBAAmB,kBAAmB,CAAC,CAAE,SAAU;AACzD,QAAM,UAAU,CAAC,CAAE,MAAM;AACzB,QAAM,aAAa,KAAK,SAAS,QAC9B,OAAO,KAAM,CAAE,MAAO,EAAE,OAAO,KAAK,SAAS,KAAM,IACnD;AACH,QAAM,cAAc,aAAa,eAAgB,MAAM,UAAW,IAAI;AACtE,QAAM,mBAAmB,KAAK,yBAAyB,CAAE;AACzD,MAAK,CAAE,SAAU;AAChB,WACC;AAAA,MAAC;AAAA;AAAA,QACA,WAAY,KAAM,wBAAwB;AAAA,UACzC,iBAAiB;AAAA,QAClB,CAAE;AAAA,QAEA;AAAA;AAAA,IACH;AAAA,EAEF;AACA,QAAM,YAAY;AAAA,IACjB,WAAW,KAAM,WAAW;AAAA,MAC3B,iBAAiB,CAAE,oBAAoB;AAAA,IACxC,CAAE;AAAA,IACF,OAAO,CAAE,oBAAoB,CAAC,CAAE,YAAY,SAAS;AAAA,IACrD;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AACA,SACC;AAAA;AAAA,IAGE;AAAA,iBAAW,cAAc,eACxB,oBAAC,SAAM,WAAU,UAAS,KAAI,MAC3B,gBAAM,KAAM,YAAY,QAAQ,CAAE,EAAE;AAAA,QACrC,CAAE,CAAE,WAAW,UAAW,MACzB;AAAA,UAAC;AAAA;AAAA,YACA,WAAU;AAAA,YAEV,KAAI;AAAA,YAEJ;AAAA,kCAAC,QAAG,WAAU,qCACX,eAAK,SAAS,cAAc,QAC3B,YACA;AAAA;AAAA,gBAEA,GAAI,YAAa;AAAA,gBACjB,WAAW;AAAA,gBACX;AAAA,cACA,GACJ;AAAA,cACA;AAAA,gBAAC;AAAA;AAAA,kBACE,GAAG;AAAA,kBACL,MAAO;AAAA,kBACP,kBAAmB;AAAA;AAAA,cACpB;AAAA;AAAA;AAAA,UAjBM;AAAA,QAkBP;AAAA,MAEF,GACD;AAAA;AAAA,MAKD,CAAE,eACD;AAAA,QAAC;AAAA;AAAA,UACE,GAAG;AAAA,UACL;AAAA,UACA,kBAAmB,CAAC,CAAE;AAAA;AAAA,MACvB;AAAA,MAGA,oBAAoB,aACrB,oBAAC,OAAE,WAAU,0BACZ,8BAAC,WAAQ,GACV;AAAA;AAAA,GAEF;AAEF;AAEA,IAAO,eAAQ;",
  "names": []
}
