OData Explorer

This demo shows how DataViews binds with queried OData.

This demo shows how DataViews binds with queried OData. Try creating a query using the options and then click the "Get Data" button to show that data bound to a DataViews grid.
<!DOCTYPE html> <html lang="en"> <head> <base href="/dataviewsjs/demos/en/sample/Showcase/ODataExplorer/purejs/" /> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="keywords" content="column, operation, OData" /> <meta name="description" content="This demo shows how DataViews binds with queried OData." /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>OData Explorer | Showcase | GrapeCity DataViewsJS JavaScript Demos</title> <link href="/dataviewsjs/demos/node_modules/normalize.css/normalize.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/static/css/base.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/static/css/bootstrap-snippet.min.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/node_modules/@fortawesome/fontawesome-free/css/all.min.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/static/dataviews/gc.dataviews.core.min.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/static/dataviews/gc.dataviews.grid.min.css" rel="stylesheet" type="text/css" /> <link href="styles.css" rel="stylesheet" type="text/css" /> <!-- Google Tag Manager --> <script> (function (w, d, s, l, i) { w[l] = w[l] || []; w[l].push({ 'gtm.start': new Date().getTime(), event: 'gtm.js' }); var f = d.getElementsByTagName(s)[0], j = d.createElement(s), dl = l != 'dataLayer' ? '&l=' + l : ''; j.async = true; j.src = 'https://www.googletagmanager.com/gtm.js?id=' + i + dl; f.parentNode.insertBefore(j, f); })(window, document, 'script', 'dataLayer', 'GTM-WT462SJ'); </script> <!-- End Google Tag Manager --> <script src="/dataviewsjs/demos/static/js/app-polyfills.min.js" type="text/javascript"></script> <script type="text/javascript"> window.process = { env: { NODE_ENV: 'production', USE_NPM: false, USE_CDN: false, SITE_ROOT: '/dataviewsjs/demos', FRAMEWORK: 'purejs', DVJS_LICENSE_KEY: 'GrapeCity-Internal-Use-Only,GrapeCity,E195393772372914#B0KV4Ny56Vr5Wb7w6buJWeGRWb4NXUnNXRlFWWXl6SoN5VzVkYslmQ95WTENkTllVQzd4QhpEejdDNJZlWOp6M7oERQNnWspkaaB5QMhnR7dmUkRnVJR4L5cHTKNkZZdDbRBzZIxmSSR6NrpVQaVUQrBlc6ImYysSd4UlUEZGbw2kMl9UOzQVMId6ZXtUN83CO5RzaZt4VY5kM5pkUGpUUUV7UExUeGpUdTV5dFJ4bPhTc8pGeXJHWrkzNlFzdUtWTr5UQDdVckdGbSVUWr2yMPNzctZVRxEEW9lEbsZHUKJnVaRXT5p6Z0tWMqJGVrtSTIZnaopGSWZXbVNjY0hzQB5We4dnUr3ER8MkI0IyUiwiIGZUNwEkN5MjI0ICSiwSM9ETO6czNygTM0IicfJye#4Xfd5nIZRVV9IiOiMkIsISM6ByUKN7dllmVhRXYEJiOi8kI1tlOiQmcQJCLiEDMzATOwAyMwgDMwIDMyIiOiQncDJCLiI7au26YukHdpNWZwFmcn9iKsAnau26YukHdpNWZwFmcn9iKs86Yu46bj9Se4l6YlBXYydmLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLt36YukHdpNWZwFmcn9iKiojIz5GRiwiI9RXaDVGchJ7RiojIh94QiwSZ5JHd0ICb6VkIsICNxkjM7MjM7czM9MTN9EjI0ICZJJye0ICRiwiI34zZN3yZGNlUnJDe5wkQPVlcBh7SppmUNBlU9dWS7J4ZMRES4MTZkRXTxM7Uq5GeQdHcyFHVup6dQd6ZDpEVrNDSh9kbNdzZrl4dwdPQ', SJS_LICENSE_KEY: '*.grapecity.com,E613631884219496#B0qRgJHWSJ7NyBlc8BjNMRHW7g7YldTZXFTQuFnW4hVOCplVSlVV09ERlhEZuVTVKlTazE4Q6VGSw2CdWZUWSVmbjVXbrxmWFVWR8ZzQro7U84WMGdlbuVHb73kS5kjUTN4NvFVdLdXWVR4Nox6Z7UUSysEcXJEMsN6bDN4TxMDVwVmWBRzKxhkTzAXTaJmdD3CRFJTd8R4R6M5RklWa6oUaLlXMwR4R8ZUdtRWVxUUaQh6VXNDdEhlZ7FHR6QXTPJTVvkWcyZnbSdHRtZHcYF6TKN4axYGcZNjTDF7TvFTTr24VqZjVHVjcLd7QkRmdNxkI0IyUiwiI5gDOEF4QGVjI0ICSiwiMzkTO9kTOyMTM0IicfJye35XX3JSSGljQiojIDJCLiITMuYHITpEIkFWZyB7UiojIOJyebpjIkJHUiwiI4MDMyEDMgkDM8ATOxAjMiojI4J7QiwiIt36YukHdpNWZwFmcn9iKiojIz5GRiwiIj9WagkHdpNUZwFmcHJiOiEmTDJCLlVnc4pjIsZXRiwiI6kDN9EjM4gDOxMjNzEjNiojIklkIs4XZzxWYmpjIyNHZisnOiwmbBJye0ICRiwiI34TQ72kNBV6YXpXdGxGWxdHcol4MyUGUHJVbQVHRx44Sw84YxRkS4QnZadDNmhWWxV5QxFlTlZEbBJ5N8gUNQlDb7J6Kl36YHVnb4NGN92UMFdlNORFU8VDSaFlQSVlS4EHTrA5Ohh', }, }; </script> <script src="/dataviewsjs/demos/node_modules/lodash/lodash.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/jquery/dist/jquery.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.common.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.core.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.grid.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/js/license.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/systemjs/dist/system.js" type="text/javascript"></script> <script src="systemjs.config.js" type="text/javascript"></script> </head> <body class="theme-default"> <!-- Google Tag Manager (noscript) --> <noscript ><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-WT462SJ" height="0" width="0" style="display: none; visibility: hidden;" ></iframe ></noscript> <!-- End Google Tag Manager (noscript) --> <noscript>You need to enable JavaScript to run this app.</noscript> <div id="queryBuilderContainer"> <h4 id="promtInfo"> In this demo you can select options to build the request data url, then request data from the service to fill the DataView. </h4> <div id="queryBuilder" class="row-fluid"> <div id="selectQuery"> <div class="filterLabel">Select:</div> <div class="selectDropDown"> <select id="dataSource" placeholder="-- Select --"> </select> <select id="top"> <option value="0" class="queryDropdownColor">Single using Keys</option> <option value="100000" class="queryDropdownColor">Count Only</option> <option value="1" class="queryDropdownColor">top 1</option> <option value="10" class="queryDropdownColor">top 10</option> <option value="20" class="queryDropdownColor">top 20</option> <option value="50" class="queryDropdownColor">top 50</option> <option value="100" class="queryDropdownColor">top 100</option> </select> </div> </div> <div id="queryFilters" class="hidden"> <div id="filtersConditions"> <div id="selectConditions" class="filterContainer"> <div class="flex-button"> <div class="filterLabel">Columns:</div> <button id="addSelectCondition" class="addCondition"></button> </div> <span id="selectFiltersList" class="filterList"></span> </div> <div id="orderByConditions" class="filterContainer"> <div class="flex-button"> <div class="filterLabel">Order by:</div> <button id="addOrderByCondition" class="addCondition">+</button> </div> <span id="orderByFiltersList" class="filterList"></span> </div> </div> <div id="queryURLBlock" class="alert-info"> <input readonly type="text" id="queryUrlText" class="form-control input-sm" rel="tooltip" /> </div> </div> <div id="queryButtons" class="hidden"> <button id="submitQuery" class="buttonQuery btn btn-success">Get Data</button> <button id="clearQuery" class="buttonQuery btn btn-warning">Reset</button> </div> <div id="qbErrorMessageLine" class="text-center hidden"> <div id="errorMessage" class="alert-warning"></div> </div> </div> <div id="result" class="row-fluid hidden"> <div id="grid"></div> </div> <div id="backgroundOverlay" class="gc-popup-overlay"> <div class="cube-loader-container"> <div class="sk-cube-grid"> <div class="sk-cube sk-cube1"></div> <div class="sk-cube sk-cube2"></div> <div class="sk-cube sk-cube3"></div> <div class="sk-cube sk-cube4"></div> <div class="sk-cube sk-cube5"></div> <div class="sk-cube sk-cube6"></div> <div class="sk-cube sk-cube7"></div> <div class="sk-cube sk-cube8"></div> <div class="sk-cube sk-cube9"></div> </div> <h3></h3> </div> </div> </div> <script type="text/javascript"> System.import('./app.js'); </script> </body> </html>
import { baseUrl, loadMetadata, metadata, fetchData } from './odata'; let searchUrl; let selectTop = 20; let orderBys = []; let selectedColumns = []; $(() => { loadMetadata((metadata) => { const dataSource = document.getElementById('dataSource'); metadata.forEach((md) => { if (dataSource) { const html = `<option value="${md.tableName}" class="queryDropdownColor">${md.tableName}</option>`; const option = createElement(html); dataSource.appendChild(option); } }); initUI(); }); }); $('#selectConditions #addSelectCondition').click(() => { $('#selectConditions').toggleClass('listVisible'); }); $('#orderByConditions #addOrderByCondition').click(() => { $('#orderByConditions').toggleClass('listVisible'); }); $('#top').val(selectTop.toString()); $('#dataSource').change(() => { $('.hidden').removeClass('hidden'); updateConditions(); updateUrl(); }); $('#top').change(() => { selectTop = parseInt($('#top').val(), 10); updateUrl(); }); $('#submitQuery').click(() => { fetchData(searchUrl) .then((data) => { const rowHeight = 35; const minHeight = rowHeight * Math.min(data.length + 1, 11) + 2; $('#grid')[0].style.minHeight = `${minHeight}px`; destroyView(); const layout = new GC.DataViews.GridLayout(); new GC.DataViews.DataView(document.getElementById('grid'), data, null, layout); //focus data.view by default document.querySelector('#grid').focus(); }) .catch((err) => { alert(`Failed to get data from ${searchUrl}`); }); }); function destroyView() { const dataView = GC.DataViews.DataView.getControlByElement(document.body); if (dataView) { dataView.destroy(); } } function initUI() { initElement(); updateConditions(); updateUrl(); destroyView(); } $('#clearQuery').click(initUI); function updateConditions() { initElement(); for (let i = 0, len = metadata.length; i < len; i++) { if (metadata[i].tableName === selectedTable()) { metadata[i].columns.forEach((col) => { appendColumnElement(col.Name); if (col.Type !== 'Edm.Binary') { appendOrderByElement(col.Name); } }); registerEvent(); break; } } } function registerEvent() { $('#orderByFiltersList .queryOrderByValue').click(handleSortButtonClick); $('#selectFiltersList label').click(handleCheckBoxClick); } function initElement() { $('#selectFiltersList').empty(); $('#orderByFiltersList').empty(); $('#queryUrlText').empty(); $('#top').val(20); $('#selectConditions')[0].className = 'filterContainer'; $('#orderByConditions')[0].className = 'filterContainer'; orderBys = []; selectedColumns = []; selectTop = 20; } function appendColumnElement(prop) { const element = createElement(`<label><input type="checkbox" data-column="${prop}">${prop}</label>`); document.getElementById('selectFiltersList').appendChild(element); } function appendOrderByElement(prop) { const html = `<label> <div class="queryOrderByValueGroup btn-group" data-toggle="buttons"> <div name="queryOrderByValueGroup" class="queryOrderByValue btn btn-sm btn-info" data-toggle="radio" data-value="0" data-id="1" data-column="${prop}"> <i class="fa fa-lg fa-times"></i> </div> <div name="queryOrderByValueGroup" class="queryOrderByValue btn btn-sm btn-info" data-toggle="radio" data-value="1" data-id="1" data-column="${prop}"> <i class="fa fa-lg fa-sort-alpha-up"></i> </div> <div name="queryOrderByValueGroup" class="queryOrderByValue btn btn-sm btn-info" data-toggle="radio" data-value="2" data-id="1" data-column="${prop}"> <i class="fa fa-lg fa-sort-alpha-down"></i> </div> </div>${prop}</label>`; const sortElement = createElement(html); document.getElementById('orderByFiltersList').appendChild(sortElement); } function handleCheckBoxClick(event) { const columnName = event.target.dataset.column; if (columnName) { if (event.target.checked) { selectedColumns.push(columnName); } else { selectedColumns.splice(selectedColumns.indexOf(columnName), 1); } updateUrl(); } } function handleSortButtonClick(event) { const target = event.currentTarget; const column = target.dataset.column; const value = parseInt(target.dataset.value, 10); _.remove(orderBys, (order) => order.column === column); if (value !== 0) { orderBys.push({ column, desc: value === 2 }); } updateUrl(); } function selectedTable() { return $('#dataSource').val(); } function orderByQuery() { if (orderBys.length > 0) { const conditions = _.map(orderBys, (t) => `${t.column}${t.desc ? ' desc' : ''}`).join(','); return `$orderby=${conditions}`; } return undefined; } function selectQuery() { if (selectedColumns.length > 0) { const cols = selectedColumns.join(','); return `$select=${cols}`; } return undefined; } function updateUrl() { const block = $('#queryUrlText')[0]; let url = baseUrl; if (selectedTable()) { url += selectedTable(); } if (selectTop === 100000) { url += '/$count?'; } else if (selectTop === 0) { url += '()?'; } else { url += `?$top=${selectTop}&`; } const params = [orderByQuery(), selectQuery()].filter(_.identity).join('&'); url += params; url = _.trim(url, '?'); url = _.trim(url, '&'); searchUrl = url; block.value = url; } function createElement(html) { const div = document.createElement('div'); div.innerHTML = html; return div.children[0]; }
import _ from 'lodash'; export const baseUrl = process.env.SITE_ROOT + '/Northwind.svc/'; function isMSBrowser() { const isIE = /*@cc_on!@*/ false || !!document.documentMode; // Edge 20+ const isEdge = !isIE && !!window.StyleMedia; return isIE || isEdge; } export const metadata = []; const nodeName = isMSBrowser() ? 'childNodes' : 'children'; const parentName = isMSBrowser() ? 'parentNode' : 'parentElement'; export function fetchData(url) { return new Promise((resolve, reject) => { beginLoad(`Getting data from ${url}`); $.ajax({ url: url, crossDomain: true, success: (resp) => { endLoad(); if (_.isPlainObject(resp)) { const first = _.head(resp.value); if (first) { const props = Object.keys(first).filter( (prop) => !_.startsWith(prop, '_') && !_.isPlainObject(first[prop]) ); const data = resp.value.map((r) => _.pick(r, props)); resolve(data); } else { resolve([]); } } else { resolve([{ data: resp }]); } }, error: (err) => { endLoad(); reject(err); }, }); }); } export function loadMetadata(callback) { beginLoad('Getting metadata from ' + window.location.protocol + baseUrl); $.ajax({ url: `${baseUrl}$metadata`, crossDomain: true, success: (data) => { endLoad(); if (isMSBrowser()) { data = data.childNodes[0]; } const entityTypes = []; const entitySets = []; getEntityInfo(data, entityTypes, entitySets); metadata.length = 0; fillMetadata(entityTypes, entitySets); callback(metadata); }, error: (xhr, status) => { endLoad(); if (status !== 'abort') { alert('Failed to load data from remote web site.'); } }, }); } function fillMetadata(entityTypes, entitySets) { for (let i = 0, len1 = entitySets.length; i < len1; i++) { const entitySet = entitySets[i]; for (let j = 0, len2 = entityTypes.length; j < len2; j++) { const entityType = entityTypes[j]; if (entitySet.EntityType === entityType.Name) { metadata.push({ tableName: entitySet.Name, tableType: entityType.Name, columns: entityType.columns, }); } } } } function getEntityInfo(data, entityTypes, entitySets) { for (let i = 0, len = data.childElementCount; i < len; i++) { const subData = data[nodeName][i]; if (subData.nodeName === 'EntityType') { const nameSpace = readNode(subData[parentName], null, true); const type = {}; readEntityType(subData, type, nameSpace); entityTypes.push(type); } else if (subData.nodeName === 'EntitySet') { const set = {}; readNode(subData, set); entitySets.push(set); } else { getEntityInfo(subData, entityTypes, entitySets); } } } function readEntityType(entityType, node, nameSpace) { readNode(entityType, node); node.Name = nameSpace + '.' + node.Name; node.columns = []; for (let i = 0, len = entityType.childElementCount; i < len; i++) { const column = {}; if (entityType[nodeName][i].nodeName === 'Property') { readNode(entityType[nodeName][i], column); node.columns.push(column); } } } function readNode(xmlNode, node, onlyNameSpace) { for (let i = 0, len = xmlNode.attributes.length; i < len; i++) { const attribute = xmlNode.attributes[i]; const name = attribute.nodeName; const val = attribute.nodeValue; if (onlyNameSpace) { if (name === 'Namespace') { return val; } } else { node[name] = val; } } } function setDisplay(id, display) { const element = document.getElementById(id); if (element) { element.style.display = display; } } function beginLoad(text) { setDisplay('custom-loadIcon', ''); const msg = document.querySelector('#backgroundOverlay h3'); msg.innerHTML = text; setDisplay('backgroundOverlay', 'block'); } function endLoad() { setDisplay('custom-loadIcon', 'none'); setDisplay('backgroundOverlay', 'none'); }
html { background: #fff url("/dataviewsjs/demos/images/grid-background.png"); width: 100%; height: 100%; } body { background-color: transparent; padding: 10px 30px; font-family: "Roboto", Helvetica, Arial, sans-serif !important; } .form-control { color: #747474; background-color: #fffffb; font-weight: bold; display: inline-block; width: auto; vertical-align: middle; } .gc-grid { font-size: 12px; } .gc-popup-overlay { background-color: darkgrey; } #queryBuilderContainer { height: 100%; display: flex; flex-direction: column; } #queryBuilderContainer #backgroundOverlay { display: none; } #queryBuilderContainer #backgroundOverlay .cube-loader-container { position: fixed; left: 45%; top: 45%; } #queryBuilderContainer #backgroundOverlay .cube-loader-container h3 { left: -35%; position: relative; color: white; } #queryBuilderContainer #promtInfo { flex-grow: 0; flex-shrink: 0; } #queryBuilderContainer #queryBuilder { flex-grow: 0; flex-shrink: 1; } #queryBuilderContainer #queryBuilder #selectQuery { display: flex; align-items: center; margin-bottom: 20px; } #queryBuilderContainer #queryBuilder #selectQuery .selectDropDown { display: flex; align-items: center; margin-left: 45px; } #queryBuilderContainer #queryBuilder #selectQuery .selectDropDown #dataSource { margin-right: 10px; } #queryBuilderContainer #queryBuilder input { width: 18px; height: 18px; vertical-align: bottom; margin-right: 5px; } #queryBuilderContainer #queryBuilder input[type=text] { min-width: 250px; margin: 5px; padding: 3px; width: 99%; height: 30px; } #queryBuilderContainer #queryBuilder #errorMessage { display: none; } #queryBuilderContainer #queryBuilder #queryUrlText { display: inline-block; } #queryBuilderContainer #queryBuilder .buttonQuery { cursor: pointer; margin-top: 15px; width: 100px; height: 40px; } #queryBuilderContainer #queryBuilder #submitQuery { background: #29abe0; color: #ffffff; margin-right: 15px; } #queryBuilderContainer #queryBuilder #clearQuery { color: #000000; background-color: #e6e6e6; } #queryBuilderContainer #queryBuilder .filterList { display: none; } #queryBuilderContainer #queryBuilder .listVisible .filterList { overflow-y: auto; overflow-x: hidden; max-height: 200px; width: auto; display: inline-block; margin-left: 10px; } #queryBuilderContainer #queryBuilder .listVisible button { vertical-align: top; background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7CAAAOwgEVKEqAAAAAB3RJTUUH3QsJATEJ1u8O6wAAAbBJREFUOMut1V+LTVEYBvDf2bOPUmp8h9MwF0oSytVEdkfNRLmYK00ulFwpJWNEHYYo5gO40rggKRkX/tYkSaNc00l8hCEiMw43767V7nTmODy1L9ba63ne9b7rfdaqFUWhC0ZxEOPYhRy/sYolPMR9vKsShxqNRjpeh1O4hf34gdsxfoZP2IJJHIkgS/hVCuSJ2EbMx66e4yqe6I4iAl/CbhzGMmSxoI6bIXYOzR5i4l8z1o4Ht56mfBrHcR4X0LE2OngRaR/Dd7ysFUUxgrdRiyZW/B3qeITt2JbhEDZgdgAxwZnFMCYzTKCNRYNjMTQmcuzAjUrdhrE+6tMNGb7gW1LPpziaRw3aFcJFHOhxOEOYw/Vkro162Tar/hPyENtUmT8bhV4r5RQjWMmTdsmSFD/H1y8y7MObDAuhPvYPmY6FxkKGe/iKmdI+AzT2TGR0J4vTuYw9mB5AcDq4V/Cx9PJrbA1PdvCqDz/nsbMWHuAEOllin6m4OFvhzaKHWBFrWsGZKm2b3ofL4euTEfkx3sfd2E5aYy82R9ucwTX8LEVqfTwBO5PA6RNwFx+qxD9+2m672NnhxQAAAABJRU5ErkJggg==); background-repeat: no-repeat; } #queryBuilderContainer #queryBuilder .filterList > label { display: block; white-space: nowrap; margin-bottom: 10px; } #queryBuilderContainer #queryBuilder .queryOrderByValueGroup { margin-right: 5px; } #queryBuilderContainer #queryBuilder .filterContainer { display: flex; align-items: start; margin-bottom: 10px; } #queryBuilderContainer #queryBuilder .flex-button { display: flex; align-items: center; } #queryBuilderContainer #queryBuilder .filterLabel { margin-right: 10px; } #queryBuilderContainer #queryBuilder .addCondition { background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7CAAAOwgEVKEqAAAAAB3RJTUUH3QsJATErA49PDwAAAgBJREFUOMut1T1IVWEYB/DfPfdKXxTRkFFD0KUhDUIotEYHl0KkoKlF+qBIoqGGloZoq6EPpaAiCGmIDDVaa4sgSYSyaIiiEEkSK4REr7flOXA63NsH9MCBw/s+z//5/r+Fjo4ONWQrdmMvmlGN8wJe4QEe4WXesJADXImTOI05PMczTMf9GrRhB5bgAi7hewpQyoCtQy/24V4oj6gt28PpOWxDDyazgKvRhz04hluYV19GcABPcDlKcRAzKWBP1Oswbvo7mcd1LOAGRnG+WC6Xm3EH93E204BUVmEX1mMqALIyhs04hKEEneHtIio1ItmCAdzG2hr3lbCdR2eCLjyNkOulVox6/6ijMxoYXQmaYjSyqa7AJjRGqgUk2IgN8TVk9KuB0VQKxS85j+3RnG9YHg6WRepVfEI33mZsppEkoVDxn6QUgI2588fYidnYiruRxX5MhM7nnM0aLJYwjtaoU1rHWbyL/4k4X8SHGkDpjrdhPMFgzFlLnSwaoiQLWFpHpyUwBhMMh9GpGI+8vI797q4TXTFsGzBcLJfLU9HpE/iIFzmDObyPu4UagEdwJohiIN3l3gi7Lxr1J3JIS3E0yGEAV0VkMIPjeIhr6A+K8hv66seV4IAefM3z4WTUaSy4rj1HsJXY5dYYpWKQyS8EW/iHJ6AaGaVPwBDe5A1/AgojgwuRXC6BAAAAAElFTkSuQmCC); background-repeat: no-repeat; cursor: pointer; color: transparent; height: 20px; width: 20px; padding: 0; border: none; outline: none; } #queryBuilderContainer #result { width: 100%; height: 100%; flex-grow: 1; flex-shrink: 1; margin-top: 20px; display: flex; } #queryBuilderContainer #result #grid { width: 100%; height: 100%; flex-grow: 1; flex-shrink: 1; } .sk-cube-grid { width: 80px; height: 80px; } .sk-cube-grid .sk-cube { width: 33%; height: 33%; background-color: blue; float: left; animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out; } .sk-cube-grid .sk-cube1 { animation-delay: 0.2s; } .sk-cube-grid .sk-cube2 { animation-delay: 0.3s; } .sk-cube-grid .sk-cube3 { animation-delay: 0.4s; } .sk-cube-grid .sk-cube4 { animation-delay: 0.1s; } .sk-cube-grid .sk-cube5 { animation-delay: 0.2s; } .sk-cube-grid .sk-cube6 { animation-delay: 0.3s; } .sk-cube-grid .sk-cube7 { animation-delay: 0s; } .sk-cube-grid .sk-cube8 { animation-delay: 0.1s; } .sk-cube-grid .sk-cube9 { animation-delay: 0.2s; } @keyframes sk-cubeGridScaleDelay { 0%, 70%, 100% { transform: scale3D(1, 1, 1); } 35% { transform: scale3D(0, 0, 1); } } /*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["Showcase/ODataExplorer/purejs/styles.scss","Showcase/ODataExplorer/purejs/styles.css"],"names":[],"mappings":"AAAA;EACE,qEAAA;EACA,WAAA;EACA,YAAA;ACCF;;ADEA;EACE,6BAAA;EACA,kBAAA;EACA,8DAAA;ACCF;;ADEA;EACE,cAAA;EACA,yBAAA;EACA,iBAAA;EACA,qBAAA;EACA,WAAA;EACA,sBAAA;ACCF;;ADEA;EACE,eAAA;ACCF;;ADEA;EACE,0BAAA;ACCF;;ADEA;EACE,YAAA;EACA,aAAA;EACA,sBAAA;ACCF;ADCE;EACE,aAAA;ACCJ;ADCI;EACE,eAAA;EACA,SAAA;EACA,QAAA;ACCN;ADCM;EACE,UAAA;EACA,kBAAA;EACA,YAAA;ACCR;ADIE;EACE,YAAA;EACA,cAAA;ACFJ;ADKE;EACE,YAAA;EACA,cAAA;ACHJ;ADKI;EACE,aAAA;EACA,mBAAA;EACA,mBAAA;ACHN;ADKM;EACE,aAAA;EACA,mBAAA;EACA,iBAAA;ACHR;ADKQ;EACE,kBAAA;ACHV;ADQI;EACE,WAAA;EACA,YAAA;EACA,sBAAA;EACA,iBAAA;ACNN;ADSI;EACE,gBAAA;EACA,WAAA;EACA,YAAA;EACA,UAAA;EACA,YAAA;ACPN;ADUI;EACE,aAAA;ACRN;ADWI;EACE,qBAAA;ACTN;ADYI;EACE,eAAA;EACA,gBAAA;EACA,YAAA;EACA,YAAA;ACVN;ADaI;EACE,mBAAA;EACA,cAAA;EACA,kBAAA;ACXN;ADcI;EACE,cAAA;EACA,yBAAA;ACZN;ADeI;EACE,aAAA;ACbN;ADgBI;EACE,gBAAA;EACA,kBAAA;EACA,iBAAA;EACA,WAAA;EACA,qBAAA;EACA,iBAAA;ACdN;ADiBI;EACE,mBAAA;EACA,mwBAAA;EACA,4BAAA;ACfN;ADkBI;EACE,cAAA;EACA,mBAAA;EACA,mBAAA;AChBN;ADmBI;EACE,iBAAA;ACjBN;ADoBI;EACE,aAAA;EACA,kBAAA;EACA,mBAAA;AClBN;ADqBI;EACE,aAAA;EACA,mBAAA;ACnBN;ADsBI;EACE,kBAAA;ACpBN;ADuBI;EACE,22BAAA;EACA,4BAAA;EACA,eAAA;EACA,kBAAA;EACA,YAAA;EACA,WAAA;EACA,UAAA;EACA,YAAA;EACA,aAAA;ACrBN;ADyBE;EACE,WAAA;EACA,YAAA;EACA,YAAA;EACA,cAAA;EACA,gBAAA;EACA,aAAA;ACvBJ;ADyBI;EACE,WAAA;EACA,YAAA;EACA,YAAA;EACA,cAAA;ACvBN;;AD6BA;EACE,WAAA;EACA,YAAA;AC1BF;;AD6BA;EACE,UAAA;EACA,WAAA;EACA,sBAAA;EACA,WAAA;EAEA,0DAAA;AC1BF;;AD4BA;EAEE,qBAAA;ACzBF;;AD2BA;EAEE,qBAAA;ACxBF;;AD0BA;EAEE,qBAAA;ACvBF;;ADyBA;EAEE,qBAAA;ACtBF;;ADwBA;EAEE,qBAAA;ACrBF;;ADuBA;EAEE,qBAAA;ACpBF;;ADsBA;EAEE,mBAAA;ACnBF;;ADqBA;EAEE,qBAAA;AClBF;;ADoBA;EAEE,qBAAA;ACjBF;ADiCA;EACE;IAIE,2BAAA;ECtBF;EDwBA;IAEE,2BAAA;ECtBF;AACF","file":"Showcase/ODataExplorer/purejs/styles.css","sourcesContent":["html {\n  background: #fff url('/dataviewsjs/demos/images/grid-background.png');\n  width: 100%;\n  height: 100%;\n}\n\nbody {\n  background-color: transparent;\n  padding: 10px 30px;\n  font-family: 'Roboto', Helvetica, Arial, sans-serif !important;\n}\n\n.form-control {\n  color: #747474;\n  background-color: #fffffb;\n  font-weight: bold;\n  display: inline-block;\n  width: auto;\n  vertical-align: middle;\n}\n\n.gc-grid {\n  font-size: 12px;\n}\n\n.gc-popup-overlay {\n  background-color: darkgrey;\n}\n\n#queryBuilderContainer {\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n\n  #backgroundOverlay {\n    display: none;\n\n    .cube-loader-container {\n      position: fixed;\n      left: 45%;\n      top: 45%;\n\n      h3 {\n        left: -35%;\n        position: relative;\n        color: white;\n      }\n    }\n  }\n\n  #promtInfo {\n    flex-grow: 0;\n    flex-shrink: 0;\n  }\n\n  #queryBuilder {\n    flex-grow: 0;\n    flex-shrink: 1;\n\n    #selectQuery {\n      display: flex;\n      align-items: center;\n      margin-bottom: 20px;\n\n      .selectDropDown {\n        display: flex;\n        align-items: center;\n        margin-left: 45px;\n\n        #dataSource {\n          margin-right: 10px;\n        }\n      }\n    }\n\n    input {\n      width: 18px;\n      height: 18px;\n      vertical-align: bottom;\n      margin-right: 5px;\n    }\n\n    input[type='text'] {\n      min-width: 250px;\n      margin: 5px;\n      padding: 3px;\n      width: 99%;\n      height: 30px;\n    }\n\n    #errorMessage {\n      display: none;\n    }\n\n    #queryUrlText {\n      display: inline-block;\n    }\n\n    .buttonQuery {\n      cursor: pointer;\n      margin-top: 15px;\n      width: 100px;\n      height: 40px;\n    }\n\n    #submitQuery {\n      background: #29abe0;\n      color: #ffffff;\n      margin-right: 15px;\n    }\n\n    #clearQuery {\n      color: #000000;\n      background-color: #e6e6e6;\n    }\n\n    .filterList {\n      display: none;\n    }\n\n    .listVisible .filterList {\n      overflow-y: auto;\n      overflow-x: hidden;\n      max-height: 200px;\n      width: auto;\n      display: inline-block;\n      margin-left: 10px;\n    }\n\n    .listVisible button {\n      vertical-align: top;\n      background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7CAAAOwgEVKEqAAAAAB3RJTUUH3QsJATEJ1u8O6wAAAbBJREFUOMut1V+LTVEYBvDf2bOPUmp8h9MwF0oSytVEdkfNRLmYK00ulFwpJWNEHYYo5gO40rggKRkX/tYkSaNc00l8hCEiMw43767V7nTmODy1L9ba63ne9b7rfdaqFUWhC0ZxEOPYhRy/sYolPMR9vKsShxqNRjpeh1O4hf34gdsxfoZP2IJJHIkgS/hVCuSJ2EbMx66e4yqe6I4iAl/CbhzGMmSxoI6bIXYOzR5i4l8z1o4Ht56mfBrHcR4X0LE2OngRaR/Dd7ysFUUxgrdRiyZW/B3qeITt2JbhEDZgdgAxwZnFMCYzTKCNRYNjMTQmcuzAjUrdhrE+6tMNGb7gW1LPpziaRw3aFcJFHOhxOEOYw/Vkro162Tar/hPyENtUmT8bhV4r5RQjWMmTdsmSFD/H1y8y7MObDAuhPvYPmY6FxkKGe/iKmdI+AzT2TGR0J4vTuYw9mB5AcDq4V/Cx9PJrbA1PdvCqDz/nsbMWHuAEOllin6m4OFvhzaKHWBFrWsGZKm2b3ofL4euTEfkx3sfd2E5aYy82R9ucwTX8LEVqfTwBO5PA6RNwFx+qxD9+2m672NnhxQAAAABJRU5ErkJggg==);\n      background-repeat: no-repeat;\n    }\n\n    .filterList > label {\n      display: block;\n      white-space: nowrap;\n      margin-bottom: 10px;\n    }\n\n    .queryOrderByValueGroup {\n      margin-right: 5px;\n    }\n\n    .filterContainer {\n      display: flex;\n      align-items: start;\n      margin-bottom: 10px;\n    }\n\n    .flex-button {\n      display: flex;\n      align-items: center;\n    }\n\n    .filterLabel {\n      margin-right: 10px;\n    }\n\n    .addCondition {\n      background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7CAAAOwgEVKEqAAAAAB3RJTUUH3QsJATErA49PDwAAAgBJREFUOMut1T1IVWEYB/DfPfdKXxTRkFFD0KUhDUIotEYHl0KkoKlF+qBIoqGGloZoq6EPpaAiCGmIDDVaa4sgSYSyaIiiEEkSK4REr7flOXA63NsH9MCBw/s+z//5/r+Fjo4ONWQrdmMvmlGN8wJe4QEe4WXesJADXImTOI05PMczTMf9GrRhB5bgAi7hewpQyoCtQy/24V4oj6gt28PpOWxDDyazgKvRhz04hluYV19GcABPcDlKcRAzKWBP1Oswbvo7mcd1LOAGRnG+WC6Xm3EH93E204BUVmEX1mMqALIyhs04hKEEneHtIio1ItmCAdzG2hr3lbCdR2eCLjyNkOulVox6/6ijMxoYXQmaYjSyqa7AJjRGqgUk2IgN8TVk9KuB0VQKxS85j+3RnG9YHg6WRepVfEI33mZsppEkoVDxn6QUgI2588fYidnYiruRxX5MhM7nnM0aLJYwjtaoU1rHWbyL/4k4X8SHGkDpjrdhPMFgzFlLnSwaoiQLWFpHpyUwBhMMh9GpGI+8vI797q4TXTFsGzBcLJfLU9HpE/iIFzmDObyPu4UagEdwJohiIN3l3gi7Lxr1J3JIS3E0yGEAV0VkMIPjeIhr6A+K8hv66seV4IAefM3z4WTUaSy4rj1HsJXY5dYYpWKQyS8EW/iHJ6AaGaVPwBDe5A1/AgojgwuRXC6BAAAAAElFTkSuQmCC);\n      background-repeat: no-repeat;\n      cursor: pointer;\n      color: transparent;\n      height: 20px;\n      width: 20px;\n      padding: 0;\n      border: none;\n      outline: none;\n    }\n  }\n\n  #result {\n    width: 100%;\n    height: 100%;\n    flex-grow: 1;\n    flex-shrink: 1;\n    margin-top: 20px;\n    display: flex;\n\n    #grid {\n      width: 100%;\n      height: 100%;\n      flex-grow: 1;\n      flex-shrink: 1;\n    }\n  }\n}\n\n// loader\n.sk-cube-grid {\n  width: 80px;\n  height: 80px;\n}\n\n.sk-cube-grid .sk-cube {\n  width: 33%;\n  height: 33%;\n  background-color: blue;\n  float: left;\n  -webkit-animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out;\n  animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out;\n}\n.sk-cube-grid .sk-cube1 {\n  -webkit-animation-delay: 0.2s;\n  animation-delay: 0.2s;\n}\n.sk-cube-grid .sk-cube2 {\n  -webkit-animation-delay: 0.3s;\n  animation-delay: 0.3s;\n}\n.sk-cube-grid .sk-cube3 {\n  -webkit-animation-delay: 0.4s;\n  animation-delay: 0.4s;\n}\n.sk-cube-grid .sk-cube4 {\n  -webkit-animation-delay: 0.1s;\n  animation-delay: 0.1s;\n}\n.sk-cube-grid .sk-cube5 {\n  -webkit-animation-delay: 0.2s;\n  animation-delay: 0.2s;\n}\n.sk-cube-grid .sk-cube6 {\n  -webkit-animation-delay: 0.3s;\n  animation-delay: 0.3s;\n}\n.sk-cube-grid .sk-cube7 {\n  -webkit-animation-delay: 0s;\n  animation-delay: 0s;\n}\n.sk-cube-grid .sk-cube8 {\n  -webkit-animation-delay: 0.1s;\n  animation-delay: 0.1s;\n}\n.sk-cube-grid .sk-cube9 {\n  -webkit-animation-delay: 0.2s;\n  animation-delay: 0.2s;\n}\n\n@-webkit-keyframes sk-cubeGridScaleDelay {\n  0%,\n  70%,\n  100% {\n    -webkit-transform: scale3D(1, 1, 1);\n    transform: scale3D(1, 1, 1);\n  }\n  35% {\n    -webkit-transform: scale3D(0, 0, 1);\n    transform: scale3D(0, 0, 1);\n  }\n}\n\n@keyframes sk-cubeGridScaleDelay {\n  0%,\n  70%,\n  100% {\n    -webkit-transform: scale3D(1, 1, 1);\n    transform: scale3D(1, 1, 1);\n  }\n  35% {\n    -webkit-transform: scale3D(0, 0, 1);\n    transform: scale3D(0, 0, 1);\n  }\n}\n","html {\n  background: #fff url(\"/dataviewsjs/demos/images/grid-background.png\");\n  width: 100%;\n  height: 100%;\n}\n\nbody {\n  background-color: transparent;\n  padding: 10px 30px;\n  font-family: \"Roboto\", Helvetica, Arial, sans-serif !important;\n}\n\n.form-control {\n  color: #747474;\n  background-color: #fffffb;\n  font-weight: bold;\n  display: inline-block;\n  width: auto;\n  vertical-align: middle;\n}\n\n.gc-grid {\n  font-size: 12px;\n}\n\n.gc-popup-overlay {\n  background-color: darkgrey;\n}\n\n#queryBuilderContainer {\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n}\n#queryBuilderContainer #backgroundOverlay {\n  display: none;\n}\n#queryBuilderContainer #backgroundOverlay .cube-loader-container {\n  position: fixed;\n  left: 45%;\n  top: 45%;\n}\n#queryBuilderContainer #backgroundOverlay .cube-loader-container h3 {\n  left: -35%;\n  position: relative;\n  color: white;\n}\n#queryBuilderContainer #promtInfo {\n  flex-grow: 0;\n  flex-shrink: 0;\n}\n#queryBuilderContainer #queryBuilder {\n  flex-grow: 0;\n  flex-shrink: 1;\n}\n#queryBuilderContainer #queryBuilder #selectQuery {\n  display: flex;\n  align-items: center;\n  margin-bottom: 20px;\n}\n#queryBuilderContainer #queryBuilder #selectQuery .selectDropDown {\n  display: flex;\n  align-items: center;\n  margin-left: 45px;\n}\n#queryBuilderContainer #queryBuilder #selectQuery .selectDropDown #dataSource {\n  margin-right: 10px;\n}\n#queryBuilderContainer #queryBuilder input {\n  width: 18px;\n  height: 18px;\n  vertical-align: bottom;\n  margin-right: 5px;\n}\n#queryBuilderContainer #queryBuilder input[type=text] {\n  min-width: 250px;\n  margin: 5px;\n  padding: 3px;\n  width: 99%;\n  height: 30px;\n}\n#queryBuilderContainer #queryBuilder #errorMessage {\n  display: none;\n}\n#queryBuilderContainer #queryBuilder #queryUrlText {\n  display: inline-block;\n}\n#queryBuilderContainer #queryBuilder .buttonQuery {\n  cursor: pointer;\n  margin-top: 15px;\n  width: 100px;\n  height: 40px;\n}\n#queryBuilderContainer #queryBuilder #submitQuery {\n  background: #29abe0;\n  color: #ffffff;\n  margin-right: 15px;\n}\n#queryBuilderContainer #queryBuilder #clearQuery {\n  color: #000000;\n  background-color: #e6e6e6;\n}\n#queryBuilderContainer #queryBuilder .filterList {\n  display: none;\n}\n#queryBuilderContainer #queryBuilder .listVisible .filterList {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 200px;\n  width: auto;\n  display: inline-block;\n  margin-left: 10px;\n}\n#queryBuilderContainer #queryBuilder .listVisible button {\n  vertical-align: top;\n  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7CAAAOwgEVKEqAAAAAB3RJTUUH3QsJATEJ1u8O6wAAAbBJREFUOMut1V+LTVEYBvDf2bOPUmp8h9MwF0oSytVEdkfNRLmYK00ulFwpJWNEHYYo5gO40rggKRkX/tYkSaNc00l8hCEiMw43767V7nTmODy1L9ba63ne9b7rfdaqFUWhC0ZxEOPYhRy/sYolPMR9vKsShxqNRjpeh1O4hf34gdsxfoZP2IJJHIkgS/hVCuSJ2EbMx66e4yqe6I4iAl/CbhzGMmSxoI6bIXYOzR5i4l8z1o4Ht56mfBrHcR4X0LE2OngRaR/Dd7ysFUUxgrdRiyZW/B3qeITt2JbhEDZgdgAxwZnFMCYzTKCNRYNjMTQmcuzAjUrdhrE+6tMNGb7gW1LPpziaRw3aFcJFHOhxOEOYw/Vkro162Tar/hPyENtUmT8bhV4r5RQjWMmTdsmSFD/H1y8y7MObDAuhPvYPmY6FxkKGe/iKmdI+AzT2TGR0J4vTuYw9mB5AcDq4V/Cx9PJrbA1PdvCqDz/nsbMWHuAEOllin6m4OFvhzaKHWBFrWsGZKm2b3ofL4euTEfkx3sfd2E5aYy82R9ucwTX8LEVqfTwBO5PA6RNwFx+qxD9+2m672NnhxQAAAABJRU5ErkJggg==);\n  background-repeat: no-repeat;\n}\n#queryBuilderContainer #queryBuilder .filterList > label {\n  display: block;\n  white-space: nowrap;\n  margin-bottom: 10px;\n}\n#queryBuilderContainer #queryBuilder .queryOrderByValueGroup {\n  margin-right: 5px;\n}\n#queryBuilderContainer #queryBuilder .filterContainer {\n  display: flex;\n  align-items: start;\n  margin-bottom: 10px;\n}\n#queryBuilderContainer #queryBuilder .flex-button {\n  display: flex;\n  align-items: center;\n}\n#queryBuilderContainer #queryBuilder .filterLabel {\n  margin-right: 10px;\n}\n#queryBuilderContainer #queryBuilder .addCondition {\n  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7CAAAOwgEVKEqAAAAAB3RJTUUH3QsJATErA49PDwAAAgBJREFUOMut1T1IVWEYB/DfPfdKXxTRkFFD0KUhDUIotEYHl0KkoKlF+qBIoqGGloZoq6EPpaAiCGmIDDVaa4sgSYSyaIiiEEkSK4REr7flOXA63NsH9MCBw/s+z//5/r+Fjo4ONWQrdmMvmlGN8wJe4QEe4WXesJADXImTOI05PMczTMf9GrRhB5bgAi7hewpQyoCtQy/24V4oj6gt28PpOWxDDyazgKvRhz04hluYV19GcABPcDlKcRAzKWBP1Oswbvo7mcd1LOAGRnG+WC6Xm3EH93E204BUVmEX1mMqALIyhs04hKEEneHtIio1ItmCAdzG2hr3lbCdR2eCLjyNkOulVox6/6ijMxoYXQmaYjSyqa7AJjRGqgUk2IgN8TVk9KuB0VQKxS85j+3RnG9YHg6WRepVfEI33mZsppEkoVDxn6QUgI2588fYidnYiruRxX5MhM7nnM0aLJYwjtaoU1rHWbyL/4k4X8SHGkDpjrdhPMFgzFlLnSwaoiQLWFpHpyUwBhMMh9GpGI+8vI797q4TXTFsGzBcLJfLU9HpE/iIFzmDObyPu4UagEdwJohiIN3l3gi7Lxr1J3JIS3E0yGEAV0VkMIPjeIhr6A+K8hv66seV4IAefM3z4WTUaSy4rj1HsJXY5dYYpWKQyS8EW/iHJ6AaGaVPwBDe5A1/AgojgwuRXC6BAAAAAElFTkSuQmCC);\n  background-repeat: no-repeat;\n  cursor: pointer;\n  color: transparent;\n  height: 20px;\n  width: 20px;\n  padding: 0;\n  border: none;\n  outline: none;\n}\n#queryBuilderContainer #result {\n  width: 100%;\n  height: 100%;\n  flex-grow: 1;\n  flex-shrink: 1;\n  margin-top: 20px;\n  display: flex;\n}\n#queryBuilderContainer #result #grid {\n  width: 100%;\n  height: 100%;\n  flex-grow: 1;\n  flex-shrink: 1;\n}\n\n.sk-cube-grid {\n  width: 80px;\n  height: 80px;\n}\n\n.sk-cube-grid .sk-cube {\n  width: 33%;\n  height: 33%;\n  background-color: blue;\n  float: left;\n  -webkit-animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out;\n  animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out;\n}\n\n.sk-cube-grid .sk-cube1 {\n  -webkit-animation-delay: 0.2s;\n  animation-delay: 0.2s;\n}\n\n.sk-cube-grid .sk-cube2 {\n  -webkit-animation-delay: 0.3s;\n  animation-delay: 0.3s;\n}\n\n.sk-cube-grid .sk-cube3 {\n  -webkit-animation-delay: 0.4s;\n  animation-delay: 0.4s;\n}\n\n.sk-cube-grid .sk-cube4 {\n  -webkit-animation-delay: 0.1s;\n  animation-delay: 0.1s;\n}\n\n.sk-cube-grid .sk-cube5 {\n  -webkit-animation-delay: 0.2s;\n  animation-delay: 0.2s;\n}\n\n.sk-cube-grid .sk-cube6 {\n  -webkit-animation-delay: 0.3s;\n  animation-delay: 0.3s;\n}\n\n.sk-cube-grid .sk-cube7 {\n  -webkit-animation-delay: 0s;\n  animation-delay: 0s;\n}\n\n.sk-cube-grid .sk-cube8 {\n  -webkit-animation-delay: 0.1s;\n  animation-delay: 0.1s;\n}\n\n.sk-cube-grid .sk-cube9 {\n  -webkit-animation-delay: 0.2s;\n  animation-delay: 0.2s;\n}\n\n@-webkit-keyframes sk-cubeGridScaleDelay {\n  0%, 70%, 100% {\n    -webkit-transform: scale3D(1, 1, 1);\n    transform: scale3D(1, 1, 1);\n  }\n  35% {\n    -webkit-transform: scale3D(0, 0, 1);\n    transform: scale3D(0, 0, 1);\n  }\n}\n@keyframes sk-cubeGridScaleDelay {\n  0%, 70%, 100% {\n    -webkit-transform: scale3D(1, 1, 1);\n    transform: scale3D(1, 1, 1);\n  }\n  35% {\n    -webkit-transform: scale3D(0, 0, 1);\n    transform: scale3D(0, 0, 1);\n  }\n}"]} */
(function () { const IS_PROD = window.process.env.NODE_ENV === 'production'; const USE_NPM = window.process.env.USE_NPM; const USE_CDN = window.process.env.USE_CDN; const SITE_ROOT = window.process.env.SITE_ROOT; const FRAMEWORK = window.process.env.FRAMEWORK; const ext = IS_PROD ? '.min.js' : '.js'; function js(name) { return name + ext; } function npm(t) { if (!t.file) { t.file = IS_PROD ? t.prod : t.dev; } const version = USE_CDN && t.version ? '@' + t.version : ''; const path = t.pkg + version + '/' + t.file; if (USE_CDN) { return 'https://unpkg.com/' + path; } return 'npm:' + path; } function dv(t) { if (USE_CDN || USE_NPM) { t.file = 'dist/' + t.file + '.min.js'; return npm(t); } return SITE_ROOT + '/static/dataviews/' + js(t.file); } const isTypeScript = FRAMEWORK === 'angular'; const babelConfig = { es2015: true, react: true, }; const meta = { js: { babelOptions: babelConfig, }, ts: { typescriptOptions: { tsconfig: true }, }, }; const map = { // gc.dataviews packages '@grapecity/dataviews.common': dv({pkg:'@grapecity/dataviews.common',file:'gc.dataviews.common',version:'1.8.7'}), '@grapecity/dataviews.core': dv({pkg:'@grapecity/dataviews.core',file:'gc.dataviews.core',version:'1.8.7'}), '@grapecity/dataviews.grid': dv({pkg:'@grapecity/dataviews.grid',file:'gc.dataviews.grid',version:'1.8.7'}), '@grapecity/dataviews.cardlayout': dv({pkg:'@grapecity/dataviews.cardlayout',file:'gc.dataviews.cardlayout',version:'1.8.7'}), '@grapecity/dataviews.masonry': dv({pkg:'@grapecity/dataviews.masonry',file:'gc.dataviews.masonry',version:'1.8.7'}), '@grapecity/dataviews.calendar': dv({pkg:'@grapecity/dataviews.calendar',file:'gc.dataviews.calendar',version:'1.8.7'}), '@grapecity/dataviews.timeline': dv({pkg:'@grapecity/dataviews.timeline',file:'gc.dataviews.timeline',version:'1.8.7'}), '@grapecity/dataviews.trellis': dv({pkg:'@grapecity/dataviews.trellis',file:'gc.dataviews.trellis',version:'1.8.7'}), '@grapecity/dataviews.gantt': dv({pkg:'@grapecity/dataviews.gantt',file:'gc.dataviews.gantt',version:'1.8.7'}), '@grapecity/dataviews.searchbox': dv({pkg:'@grapecity/dataviews.searchbox',file:'gc.dataviews.searchbox',version:'1.8.7'}), '@grapecity/dataviews.react': dv({pkg:'@grapecity/dataviews.react',file:'gc.dataviews.react',version:'1.8.7'}), '@grapecity/dataviews.vue': dv({pkg:'@grapecity/dataviews.vue',file:'gc.dataviews.vue',version:'1.8.7'}), '@grapecity/dataviews.angular': dv({pkg:'@grapecity/dataviews.angular',file:'gc.dataviews.angular',version:'1.8.7'}), '@grapecity/dataviews.csvexport': dv({pkg:'@grapecity/dataviews.angular',file:'gc.dataviews.csvexport',version:'1.8.7'}), // third-party libs react: npm({pkg:'react',prod:'umd/react.production.min.js',dev:'umd/react.development.js',version:'16.13.1'}), 'react-dom': npm({pkg:'react-dom',prod:'umd/react-dom.production.min.js',dev:'umd/react-dom.development.js',version:'16.13.1'}), 'react-router-dom': npm({pkg:'react-router-dom',prod:'umd/react-router-dom.min.js',dev:'umd/react-router-dom.js',version:'5.2.0'}), 'vue': npm({pkg:'vue',file:'dist/vue.js',version:'2.6.11'}), 'vue-router': npm({pkg:'vue-router',file:'dist/vue-router.js',version:'3.3.4'}), 'lodash': npm({pkg: 'lodash', file: js('lodash')}), 'zone.js': npm({pkg: 'zone.js', file: js('dist/zone')}), 'rxjs': npm({pkg: 'rxjs', file: js('bundles/rxjs.umd')}), 'rxjs/operators': npm({pkg:'rxjs-operators-bundle',prod:'dist/bundle.min.js',dev:'dist/bundle.js',version:'1.0.2'}), '@angular/core': npm({pkg: '@angular/core', file: js('bundles/core.umd')}), '@angular/common': npm({pkg: '@angular/common', file: js('bundles/common.umd')}), '@angular/compiler': npm({pkg: '@angular/compiler', file: js('bundles/compiler.umd')}), '@angular/platform-browser': npm({pkg: '@angular/platform-browser', file: js('bundles/platform-browser.umd')}), '@angular/platform-browser-dynamic': npm({pkg: '@angular/platform-browser-dynamic', file: js('bundles/platform-browser-dynamic.umd')}), '@angular/http': npm({pkg: '@angular/http', file: js('bundles/http.umd')}), '@angular/common/http': npm({pkg: '@angular/common', file: js('bundles/common-http.umd')}), '@angular/router': npm({pkg: '@angular/router', file: js('bundles/router.umd')}), '@angular/forms': npm({pkg: '@angular/forms', file: js('bundles/forms.umd')}), // systemjs plugins 'systemjs-plugin-json': npm({pkg:'systemjs-plugin-json',file:'json.js',version:'0.3.0'}), 'systemjs-plugin-css': npm({pkg:'systemjs-plugin-css',file:'css.js',version:'0.1.37'}), 'systemjs-plugin-babel': npm({pkg:'systemjs-plugin-babel',file:'plugin-babel.js',version:'0.0.25'}), 'systemjs-babel-build': npm({pkg:'systemjs-plugin-babel',file:'systemjs-babel-browser.js',version:'0.0.25'}), 'plugin-typescript': npm({pkg:'plugin-typescript',file:'lib/plugin.js',version:'8.0.0'}), 'typescript': npm({pkg:'typescript',file:'lib/typescript.js',version:'3.9.7'}), 'systemjs-vue-browser': npm({pkg:'systemjs-vue-browser',file:'index.js',version:'1.0.11'}), }; const config = { defaultJSExtensions: true, transpiler: isTypeScript ? 'plugin-typescript' : 'systemjs-plugin-babel', typescriptOptions: { tsconfig: true }, meta: { '*.json': {loader: 'systemjs-plugin-json'}, '*.css': {loader: 'systemjs-plugin-css'}, '*.vue': {loader: 'systemjs-vue-browser'}, '*.js': meta.js, '*.ts': meta.ts, 'app.js': { format: 'esm', babelOptions: babelConfig, }, 'typescript': { exports: 'ts', }, '@grapecity/dataviews.common': { format: 'amd', }, '@grapecity/dataviews.core': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.grid': { format: 'amd', deps: [ '@grapecity/dataviews.common', '@grapecity/dataviews.core', ], }, '@grapecity/dataviews.cardlayout': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.masonry': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.calendar': { format: 'amd', deps: [ '@grapecity/dataviews.common', '@grapecity/dataviews.core', ], }, '@grapecity/dataviews.timeline': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.trellis': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.gantt': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.searchbox': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.react': { format: 'amd', deps: [ 'react', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.vue': { format: 'amd', deps: [ 'vue', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.angular': { format: 'amd', deps: [ '@angular/core', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.csvexport': { format: 'amd', deps: [ '@grapecity/dataviews.common' ], }, }, paths: { // paths serve as alias 'npm:': SITE_ROOT + '/node_modules/', }, // map tells the System loader where to look for things map: map, // packages tells the System loader how to load when no filename and/or no extension packages: { '.': { defaultExtension: isTypeScript ? 'ts' : 'js' }, node_modules: { defaultExtension: 'js' }, } }; // fast format detection to avoid detection by source code using regexp Object.keys(map).filter(function (key) { return !config.meta[key]; }).forEach(function (key) { const path = map[key]; if (path.indexOf('/umd') >= 0 || path.indexOf('.umd') >= 0) { config.meta[key] = { format: 'amd' }; } if (path.indexOf('/cjs') >= 0) { config.meta[key] = { format: 'cjs' }; } }); System.config(config); })(this);