{"version":3,"sources":["images/GHCLogo.png","index.js"],"names":["module","exports","App","_this","Object","C_Users_apeasley_source_repos_ReactApps_machinereadablefiles_node_modules_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__","this","C_Users_apeasley_source_repos_ReactApps_machinereadablefiles_node_modules_babel_runtime_helpers_esm_possibleConstructorReturn__WEBPACK_IMPORTED_MODULE_2__","C_Users_apeasley_source_repos_ReactApps_machinereadablefiles_node_modules_babel_runtime_helpers_esm_getPrototypeOf__WEBPACK_IMPORTED_MODULE_3__","call","state","data","pages","markers","loading","prefix","fetchData","listBlobs","bind","C_Users_apeasley_source_repos_ReactApps_machinereadablefiles_node_modules_babel_runtime_helpers_esm_assertThisInitialized__WEBPACK_IMPORTED_MODULE_5__","test","instance","_this2","setState","anonymousCredential","AnonymousCredential","pipeline","StorageURL","newPipeline","serviceURL","ServiceURL","concat","containerURL","ContainerURL","fromServiceURL","URLSearchParams","window","location","search","get","listBlobHierarchySegment","Aborter","none","page","maxresults","pageSize","then","res","slice","totalPages","nextMarker","Array","prototype","push","apply","segment","blobItems","blobPrefixes","sortedData","_","orderBy","sorted","map","sort","row","id","Infinity","undefined","properties","toLowerCase","d","desc","blobName","link","react__WEBPACK_IMPORTED_MODULE_6___default","a","createElement","href","_this3","_this$state","dataset","name","alt","src","logo","react_table__WEBPACK_IMPORTED_MODULE_12__","columns","Header","accessor","Cell","renderLink","value","manual","onFetchData","showPagination","defaultPageSize","className","React","Component","render","document","getElementById"],"mappings":"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","file":"static/js/main.99b441f9.chunk.js","sourcesContent":["module.exports = \"\"","import React from \"react\";\r\nimport { render } from \"react-dom\";\r\nimport _ from \"lodash\";\r\nimport \"./index.css\";\r\nimport 'bootstrap/dist/css/bootstrap.css';\r\nimport logo from './images/GHCLogo.png';\r\n\r\n// This sample uses React Table\r\n// Check it out at https://react-table.js.org/#/story/readme\r\nimport ReactTable from \"react-table\";\r\nimport \"react-table/react-table.css\";\r\n\r\n// Import Azure Storage Blob SDK\r\nimport { Aborter, ServiceURL, ContainerURL, StorageURL, AnonymousCredential } from \"@azure/storage-blob\";\r\n\r\n// Account name, and the container to list from\r\nconst account = 'transparencyincoverage'\r\nconst container = 'public'\r\n\r\nclass App extends React.Component {\r\n constructor() {\r\n super();\r\n this.state = {\r\n data: [],\r\n pages: 2,\r\n markers: [],\r\n loading: true,\r\n prefix: \"\"\r\n };\r\n this.fetchData = this.listBlobs.bind(this);\r\n this.test = \"\";\r\n }\r\n \r\n \r\n listBlobs(state, instance) {\r\n // this lists Blobs in pages defined in state.pageSize\r\n this.setState({ loading: true });\r\n \r\n // Use AnonymousCredential since $web container is made a 'public container' \r\n // and does not require authorization\r\n const anonymousCredential = new AnonymousCredential();\r\n const pipeline = StorageURL.newPipeline(anonymousCredential);\r\n \r\n const serviceURL = new ServiceURL(\r\n `https://${account}.blob.core.windows.net`,\r\n pipeline\r\n );\r\n \r\n // If you are using a SAS token, simply append to ContainerURL here. \r\n // We will use anonymous access hence no SAS token\r\n const containerName = container //+ `?st=2018-11-06T06%3A15%3A24Z&se=2019-11-07T06%3A15%3A00Z&sp=rl&sv=2018-03-28&sr=c&sig=4vCT7aInDWRiypkuYlezN8dos0K2h2DvQ0pnNkMJSFs%3D`;\r\n const containerURL = ContainerURL.fromServiceURL(serviceURL, containerName);\r\n \r\n // Fetch the prefix in the query params to browse into folders\r\n const urlParams = new URLSearchParams(window.location.search);\r\n const prefix = urlParams.get('prefix');\r\n\r\n // List objects from Blob storage using the prefix\r\n // Delimiter for virtual directories is a forward slash '/' here\r\n containerURL.listBlobHierarchySegment (\r\n Aborter.none,\r\n \"/\",\r\n state.markers[state.page],\r\n {\r\n maxresults: state.pageSize,\r\n prefix: prefix\r\n }\r\n ).then(res => {\r\n // Store the nextMarker in an array for prev/next buttons only if there are more blobs to show\r\n const markers = state.markers.slice();\r\n var totalPages = state.page+1;\r\n if (res.nextMarker) {\r\n markers[(state.page+1)] = res.nextMarker;\r\n totalPages++;\r\n }\r\n \r\n // Combine the found virtual directories and files\r\n Array.prototype.push.apply(res.segment.blobItems, res.segment.blobPrefixes)\r\n\r\n // This is to sort rows, and handles blobName, contentLength and lastModified time\r\n const sortedData = _.orderBy(\r\n res.segment.blobItems,\r\n state.sorted.map(sort => {\r\n return row => {\r\n if (row[sort.id] === null) {\r\n return -Infinity;\r\n } // TODO: following is a workaround to special case contentLength and lastModified\r\n else if(row[sort.id] === undefined){\r\n if(row.properties === undefined)\r\n {\r\n return -Infinity;\r\n } else {\r\n return row.properties[sort.id];\r\n }\r\n }\r\n return typeof row[sort.id] === \"string\"\r\n ? row[sort.id].toLowerCase()\r\n : row[sort.id];\r\n };\r\n }),\r\n state.sorted.map(d => (d.desc ? \"desc\" : \"asc\"))\r\n );\r\n\r\n // Store the state\r\n this.setState({\r\n data: sortedData,\r\n pages: totalPages,\r\n markers: markers,\r\n loading: false,\r\n prefix: prefix\r\n });\r\n });\r\n }\r\n\r\n // Custom links for various scenarios (handles blobs, directories and go back link)\r\n renderLink(blobName) {\r\n var link;\r\n if(blobName === \"../\")\r\n {\r\n link = \"/\"\r\n }\r\n else if(blobName.slice(-1) === \"/\")\r\n {\r\n link = \"?prefix=\" + blobName\r\n } else {\r\n link = \"/\" + blobName\r\n }\r\n return (\r\n \r\n {blobName}\r\n \r\n );\r\n }\r\n\r\n\r\n render() {\r\n const { data, pages, markers, loading, prefix } = this.state;\r\n\r\n // If this is a directory view, add a go back link for the root\r\n var dataset = data\r\n if(prefix !== null)\r\n {\r\n dataset = [{name: \"../\"}].concat(dataset);\r\n }\r\n\r\n return (\r\n \r\n
\r\n \"test\"\r\n
\r\n
\r\n
\r\n \r\n \r\n (\r\n this.renderLink(row.value)\r\n )\r\n }\r\n ]}\r\n manual // Do not paginate as we can only list objects in pages from Blob storage\r\n data={dataset}\r\n pages={pages} \r\n markers={markers}\r\n loading={loading} \r\n onFetchData={this.fetchData} \r\n showPagination={false}\r\n defaultPageSize={800}\r\n className=\"-striped -highlight\"\r\n />\r\n
\r\n );\r\n }\r\n}\r\n\r\nrender(, document.getElementById(\"root\"));"],"sourceRoot":""}