Difference between revisions of "Widget:DataExporter"

From LINKS Community Center
Jump to: navigation, search
 
(9 intermediate revisions by the same user not shown)
Line 22: Line 22:
  
 
                 // Check user.
 
                 // Check user.
                 const usrData = await fetch('/api.php?action=query&meta=userinfo&format=json').then(rsp => rsp.json());
+
                 const usrData = await fetch(
 +
                    '/api.php?action=query&meta=userinfo&format=json'
 +
                ).then(rsp => rsp.json());
 
                 if (!permittedUsers.includes(usrData?.query?.userinfo?.name)) {
 
                 if (!permittedUsers.includes(usrData?.query?.userinfo?.name)) {
 
                     output.innerHTML = '<span style="color:red; font-size:large">Access Denied</span>';
 
                     output.innerHTML = '<span style="color:red; font-size:large">Access Denied</span>';
Line 30: Line 32:
 
                 const formData = new FormData(document.getElementById('export_form'));
 
                 const formData = new FormData(document.getElementById('export_form'));
  
                 const schemaParams = new URLSearchParams();
+
                // Fetch schema and parse it into an export query.
                schemaParams.set('action', 'raw');
+
                 const schemaXml = await fetch(
                schemaParams.set('title', 'Category:' + formData.get('library'));
+
                    '/index.php?&action=raw&title=Category:' + formData.get('library')
 
+
                 ).then(rsp => rsp.text());
                 const exportParams = new URLSearchParams();
+
                 const schema = (new DOMParser).parseFromString(schemaXml, 'text/xml');
                exportParams.set('action', 'ask');
 
                 exportParams.set('format', 'spreadsheet');
 
                exportParams.set('fileformat', formData.get('fileformat'));
 
 
 
                // exportUrl = '/api.php?action=ask&format=spreadsheet&query=[[Category:Disaster Community Technology]]';
 
                // exportUrl = '/api.php?action=ask&format=spreadsheet&query=[[Category:Use Cases]]';
 
                // exportUrl = '/api.php?action=ask&format=spreadsheet&query=[[Category:Guideline]]';
 
  
                 const schemaXml = await fetch('/index.php?' + schemaParams.toString()).then(rsp => rsp.text());
+
                 let exportUrl = encodeURIComponent(
                 const schema = (new DOMParser).parseFromString(schemaXml, 'text/xml');
+
                    '[[Category:' + formData.get('library').replaceAll('_', ' ') + ']]'
 +
                 ).replaceAll('%', '-');
  
 
                 for (const field of schema.querySelectorAll('Field')) {
 
                 for (const field of schema.querySelectorAll('Field')) {
Line 50: Line 46:
 
                         || field.getAttribute('name');
 
                         || field.getAttribute('name');
 
                     const label = field.querySelector('Label')?.textContent;
 
                     const label = field.querySelector('Label')?.textContent;
                     output.innerHTML += prop + ' | ' + label + '<br>';
+
                     exportUrl += '/' + encodeURIComponent('?' + prop).replaceAll('%', '-');
 +
                    if (!!label) exportUrl += '%3D' + encodeURIComponent(label).replaceAll('%', '-');
 
                 }
 
                 }
 +
 +
                exportUrl += '/format%3Dspreadsheet/fileformat%3D' + formData.get('fileformat');
 +
                output.innerHTML = exportUrl;
 +
 +
                // const exportParams = new URLSearchParams();
 +
                // exportParams.set('action', 'ask');
 +
                // exportParams.set('format', 'spreadsheet');
 +
                // exportParams.set('fileformat', formData.get('fileformat'));
 +
                // exportParams.set('query', encodeURIComponent(exportUrl));
 +
 +
                // fetch('/api.php?' + exportParams.toString());
 +
 +
                // const dl = document.createElement('a');
 +
                // dl.href = 'https://links.communitycenter.eu/index.php/Special:Ask/' + exportUrl;
 +
                // dl.download = 'export.' + formData.get('fileformat');
 +
                // document.body.appendChild(dl);
 +
                // dl.click();
 +
                // document.body.removeChild(dl);
 +
 +
                fetch('https://links.communitycenter.eu/index.php/Special:Ask/' + exportUrl)
 +
                    .then(res => res.blob())
 +
                    .then(blob => {
 +
                        const file = window.URL.createObjectURL(blob);
 +
                        window.location.assign(file);
 +
                    })
 +
 +
                // exportUrl = '/api.php?action=ask&format=spreadsheet&query=[[Category:Disaster Community Technology]]';
 +
                // exportUrl = '/api.php?action=ask&format=spreadsheet&query=[[Category:Use Cases]]';
 +
                // exportUrl = '/api.php?action=ask&format=spreadsheet&query=[[Category:Guideline]]';
  
 
                 // exportUrl += ''; // &fileformat=csv  &fileformat=ods  &fileformat=xlsx
 
                 // exportUrl += ''; // &fileformat=csv  &fileformat=ods  &fileformat=xlsx

Latest revision as of 13:34, 17 August 2023