Benchmark

This example compares performance of different grids

This example compares performance of different grids
<!DOCTYPE html> <html lang="en"> <head> <base href="/dataviewsjs/demos/en/sample/Benchmarks/Grid/purejs/" /> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="description" content="This example compares performance of different grids" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Grid | Benchmarks | MESCIUS 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="https://cdn.jsdelivr.net/npm/ag-grid@18.1.2/dist/styles/ag-grid.css" rel="stylesheet" type="text/css" /> <link href="https://cdn.jsdelivr.net/npm/ag-grid@18.1.2/dist/styles/theme-fresh.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/node_modules/devextreme/dist/css/dx.common.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/node_modules/devextreme/dist/css/dx.light.css" rel="stylesheet" type="text/css" /> <link href="//cdn-na.infragistics.com/igniteui/latest/css/themes/infragistics/infragistics.theme.css" rel="stylesheet" type="text/css" /> <link href="//cdn-na.infragistics.com/igniteui/latest/css/structure/infragistics.css" rel="stylesheet" type="text/css" /> <link href="//cdn.syncfusion.com/15.4.0.17/js/web/flat-azure/ej.web.all.min.css" rel="stylesheet" type="text/css" /> <link href="https://cdn.mescius.com/wijmo/5.20191.615/styles/wijmo.min.css" rel="stylesheet" type="text/css" /> <link href="https://cdn.jsdelivr.net/npm/slickgrid@2.4.10/slick.grid.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" /> <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: 'E348418822993781#B0EWvwY4dNNVQqJHUDpFROVWe5ZWNYFlVQFmRsJWRht4Z6lDO4Vla7YUaXhEWxd7Z5YXMuRnY7tWTQRHSlVnaYlXNhlEOpdkZ0FHWYJ5QKd6VXN5aR3ieGhUav9kZTBXWahkYBhEVutmZ72CbjdlZvV5TVdGdiplQsZXe95kUmNmZVF5cJ3mcypWNyx4UydESE3UblxGZyE7KQ94R4BjbUxUewsiaoREMxRDNllWREV6Voh4Q4dDZPRjWrIzUJl4TERXcQZWMHp4Sp9WaMZzN5o6StJmVDJXcwIVVmR6UMVGOlxUW8RmTxZDZTJWVN5GZqJHZuVDMkVGSW3WdxNzKCdDdSB7TzY7cqlnMU5GVyNzNP9WMyhDRvEEOFdkQORDM4dFVlFFWqFWSyMjNQJiOiMlIsISQyIkQ9YjQxIiOigkIsUTM7YjNxYTM0IicfJye&amp;Qf35VfikFVVljI0IyQiwiIxYHITp4c7VWaWFGdhRkI0IiTis7W0ICZyBlIsIiNxUTN6ADI8EDMxMjMwIjI0ICdyNkIsIyc59yc5l6YzVWbuoCLwpmLzVXajNXZt9iKs2WauMXdpN6cl5mLqwSbvNmLzVXajNXZt9iKsAnau26YuMXdpN6cl5mLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLuNmLt36YukHdpNWZwFmcn9iKs46bj9Se4l6YlBXYydmLqwicr9ybj9Se4l6YlBXYydmLqwCcq9ybj9Se4l6YlBXYydmLqIiOiMXbEJCLiMVVJN4UF5kI0ISYONkIsUWdyRnOiwmdFJCLiEDO7MTO9IjM8gTM4gDNzIiOiQWSisnOiQkIsISP3EkVxBVUHFDMplzLlVUdGd7cI9UeIt4SshESzV7NvY7ZxlDOuNTb5tzLr', SJS_LICENSE_KEY: 'E518585142165236#B0wm4nx4QzdlTHRTSOFzcvVnaJdjSnNEeXdTMUtSUzk6bU94QuVXNwZVZjd4SzYjcadXRIVEMzEXTThkVyR7R85UayoHZZBTYQ5mZyh4Shd6VxFXazF4cBNGRG5WTvUGTsV4T6knQYRzKxxUdk9EarplU7d6VLF6KIR7bPJ5N6ZUMWZWaURGRKRDbLJDN5YjSN5mUoxmaxonSD56LEh7Y7RXenpmTvomevZlV9dkaysCO7hTRQFHcGRWQyc5LI9kQmB7QwR4Z7ZHOR3CSXp6SiFWYzFXeXZUSp94K8VDTkFjdwl4KptSYlRWcDxmNE5kS6kzdrkVcNJXROVGbLJkcTNGRzIER8tmd4YGNhh7dxAnMvIHRv46VtBXS4U5KvJ6dZJ6M5p4TxIjd9I5QSpXTTV6SDZXb7lzaL56ZiojITJCLikTQxUTQFV4NiojIIJCLyETO7UzM7kTO0IicfJye&amp;Qf35VfikkR9IkI0IyQiwiIyEjL6ByUKBCZhVmcwNlI0IiTis7W0ICZyBlIsISNwkTN6ADI8EDMxMjMwIjI0ICdyNkIsIyc59yc5l6YzVWbuoCLwpmLzVXajNXZt9iKs2WauMXdpN6cl5mLqwSbvNmLzVXajNXZt9iKsAnau26YuMXdpN6cl5mLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLuNmLt36YukHdpNWZwFmcn9iKs46bj9Se4l6YlBXYydmLqwicr9ybj9Se4l6YlBXYydmLqwCcq9ybj9Se4l6YlBXYydmLqIiOiMXbEJCLiMVVJN4UF5kI0ISYONkIsUWdyRnOiwmdFJCLiYzMyUjNxIDNxUDO5gTM5IiOiQWSiwSfdtlOicGbmJCLlNHbhZmOiI7ckJye0ICbuFkI1pjIEJCLi4TPRtGOhtWWEFWd4IDOLRVRvx4SyMGcDhTW6n4ep', }, }; </script> <script src="/dataviewsjs/demos/node_modules/jquery/dist/jquery.min.js" type="text/javascript"></script> <script src="https://cdn.jsdelivr.net/npm/ag-grid-enterprise@21.0.1/dist/ag-grid-enterprise.js" type="text/javascript" ></script> <script src="/dataviewsjs/demos/node_modules/devextreme/dist/js/dx.all.debug.js" type="text/javascript"></script> <script src="//www.igniteui.com/js/modernizr.min.js" type="text/javascript"></script> <script src="https://cdn.jsdelivr.net/npm/jqueryui@1.11.1/jquery-ui.min.js" type="text/javascript"></script> <script src="//cdn-na.infragistics.com/igniteui/latest/js/infragistics.core.js" type="text/javascript"></script> <script src="//cdn-na.infragistics.com/igniteui/latest/js/infragistics.lob.js" type="text/javascript"></script> <script src="https://ajax.aspnetcdn.com/ajax/globalize/0.1.1/globalize.min.js" type="text/javascript"></script> <script src="//cdn.syncfusion.com/js/assets/external/jsrender.min.js" type="text/javascript"></script> <script src="//cdn.syncfusion.com/15.4.0.17/js/web/ej.web.all.min.js" type="text/javascript"></script> <script src="https://cdn.mescius.com/wijmo/5.20191.615/controls/wijmo.min.js" type="text/javascript"></script> <script src="https://cdn.mescius.com/wijmo/5.20191.615/controls/wijmo.input.min.js" type="text/javascript"></script> <script src="https://cdn.mescius.com/wijmo/5.20191.615/controls/wijmo.grid.min.js" type="text/javascript"></script> <script src="https://cdn.jsdelivr.net/npm/slickgrid@2.4.10/lib/jquery.event.drag-2.3.0.js" type="text/javascript" ></script> <script src="https://cdn.jsdelivr.net/npm/slickgrid@2.4.10/slick.core.min.js" type="text/javascript"></script> <script src="https://cdn.jsdelivr.net/npm/slickgrid@2.4.10/slick.grid.min.js" type="text/javascript"></script> <script src="https://cdn.jsdelivr.net/npm/slickgrid@2.4.10/slick.dataview.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/lodash/lodash.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/platform/platform.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/benchmark/benchmark.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/bowser/es5.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/js/jsperf.ui.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> </head> <body class="theme-default"> <noscript>You need to enable JavaScript to run this app.</noscript> <section id="runner"> <h2>Test runner</h2> <div id="options"> <div class="option"> <label>Category</label> <select id="test-category" value="render"> <option value="render">Rendering</option> <option value="sort">Sorting + Rendering</option> <option value="filter">Filtering + Rendering</option> <option value="group">Grouping + Rendering</option> </select> </div> <div class="option"> <label>Data size</label> <select id="data-size" value="1000"> <option value="1000">1000</option> <option value="10000">10000</option> <option value="100000">100000</option> </select> </div> </div> <p id="firebug"> <strong>Warning! For accurate results, please disable Firebug before running the tests.</strong> </p> <p id="java"><strong>Java applet disabled.</strong></p> <div id="test-container"> <div id="controls"> <div id="status"></div> <button id="run" type="button">Run again</button> </div> <table id="test-table"> <caption></caption> <thead> <tr> <th>Test</th> <th title="Operations per second (higher is better)">Ops/sec</th> </tr> </thead> <tbody></tbody> </table> <div id="error-info"></div> </div> </section> <script src="app.js" type="text/javascript"></script> </body> </html>
var countries = ['US', 'Germany', 'UK', 'Japan', 'Italy']; var products = ['Widget', 'Gadget', 'Doohickey']; var colors = ['Black', 'White', 'Red', 'Green', 'Blue', 'Yellow', 'Orange', 'Brown']; function generateData(size) { var data = []; var year = new Date().getFullYear(); for (var i = 0; i < size; i++) { data.push({ id: i, date: new Date(year, i % 12, 1), country: countries[Math.floor(Math.random() * countries.length)], product: products[Math.floor(Math.random() * products.length)], color: colors[Math.floor(Math.random() * colors.length)], amount: 1000 + Math.random() * 10000, big: Math.random() > 0.5, }); } return data; } var dataSize = parseInt($('#data-size').val(), 10); var data = generateData(dataSize); $('#data-size').change(function () { var dataSize = parseInt($('#data-size').val(), 10); data = generateData(dataSize); }); function destroyGrid() { var container = document.getElementById('grid'); if (!container) { return; } var grid = container.grid; if (grid && grid.destroy) { grid.destroy(); } if (grid && grid.dispose) { grid.dispose(); } container.parentNode.removeChild(container); } window.onunload = destroyGrid; function currentCategory() { return $('#test-category').val(); } var gridWidth = 600; var gridHeight = 380; function createContainer(className) { var container = document.createElement('div'); container.id = 'grid'; container.className = 'grid ' + (className || ''); container.style.width = gridWidth; container.style.height = gridHeight; document.body.appendChild(container); return container; } function dataViewCase() { var cols = [ { id: 'id', caption: 'ID', dataField: 'id', width: 80, }, { id: 'date', caption: 'Date', dataField: 'date', width: 120, }, { id: 'country', caption: 'Country', dataField: 'country', width: 80, }, { id: 'product', caption: 'Product', dataField: 'product', width: 80, }, { id: 'color', caption: 'Color', dataField: 'color', width: 80, }, { id: 'amount', caption: 'Amount', dataField: 'amount', width: 80, }, { id: 'big', caption: 'Big', dataField: 'big', width: 80, }, ]; var fn = function fn() { destroyGrid(); var category = currentCategory(); var container = createContainer(); var layout = new GC.DataViews.GridLayout({ allowSorting: true, sorting: category === 'sort' ? [ { field: 'country', ascending: true, }, ] : undefined, filtering: category === 'filter' ? "[country] = 'US' && [product] = 'Widget' && [amount] > 5000" : undefined, grouping: category === 'group' ? [ { field: 'country', collapsed: true, }, { field: 'product', collapsed: true, }, ] : undefined, }); var grid = new GC.DataViews.DataView(container, data, cols, layout); container.grid = grid; return grid; }; return { name: 'DataViewsJS', homepage: 'http://developer.mescius.com/dataviewsjs', fn: fn, onComplete: destroyGrid, }; } function agGridCase() { var fn = function fn() { destroyGrid(); var category = currentCategory(); var container = createContainer('ag-theme-fresh'); var cols = [ { colId: 'id', headerName: 'ID', field: 'id', width: 80, }, { colId: 'date', headerName: 'Date', field: 'date', width: 120, }, { colId: 'country', headerName: 'Country', field: 'country', width: 80, filter: 'agTextColumnFilter', }, { colId: 'product', headerName: 'Product', field: 'product', width: 80, filter: 'agTextColumnFilter', }, { colId: 'color', headerName: 'Color', field: 'color', width: 80, }, { colId: 'amount', headerName: 'Amount', field: 'amount', width: 80, filter: 'agNumberColumnFilter', }, { colId: 'big', headerName: 'Big', field: 'big', width: 80, }, ]; var gridOptions = { columnDefs: cols, rowData: data, defaultColDef: { sortable: true, filter: true, }, groupUseEntireRow: true, groupDefaultExpanded: 0, }; var grid = new agGrid.Grid(container, gridOptions); container.grid = grid; if (category === 'sort') { var sort = [ { colId: 'country', sort: 'asc', }, ]; gridOptions.api.setSortModel(sort); } else if (category === 'filter') { var countryFilter = gridOptions.api.getFilterInstance('country'); countryFilter.setModel({ type: 'equals', filter: 'US', }); var productFilter = gridOptions.api.getFilterInstance('product'); productFilter.setModel({ type: 'equals', filter: 'Widget', }); var amountFilter = gridOptions.api.getFilterInstance('amount'); amountFilter.setModel({ type: 'greaterThan', filter: 5000, }); gridOptions.api.onFilterChanged(); } else if (category === 'group') { gridOptions.columnApi.addRowGroupColumn(gridOptions.columnApi.getColumn('country')); gridOptions.columnApi.addRowGroupColumn(gridOptions.columnApi.getColumn('product')); } return grid; }; return { name: 'ag-Grid', homepage: 'http://www.ag-grid.com/', fn: fn, onComplete: destroyGrid, }; } function devExtremeCase() { var cols = [ { name: 'id', caption: 'ID', dataField: 'id', width: 80, }, { name: 'date', caption: 'Date', dataField: 'date', width: 120, }, { name: 'country', caption: 'Country', dataField: 'country', width: 80, allowSorting: true, }, { name: 'product', caption: 'Product', dataField: 'product', width: 80, }, { name: 'color', caption: 'Color', dataField: 'color', width: 80, }, { name: 'amount', caption: 'Amount', dataField: 'amount', width: 80, }, { name: 'big', caption: 'Big', dataField: 'big', width: 80, }, ]; var fn = function fn(done) { destroyGrid(); var category = currentCategory(); var container = createContainer(); var renderedRows = 0; var options = { columns: cols, dataSource: data, loadPanel: { enabled: false, }, scrolling: { mode: 'virtual', }, paging: { enabled: false, }, width: gridWidth, height: gridHeight, onRowPrepared: function onRowPrepared() { renderedRows++; done.resolve(); }, }; $(container).dxDataGrid(options); var grid = $(container).dxDataGrid('instance'); if (category === 'sort') { grid.beginUpdate(); grid.columnOption('country', 'sortIndex', 0); grid.columnOption('country', 'sortOrder', 'asc'); grid.endUpdate(); } else if (category === 'filter') { grid.filter([['country', '=', 'US'], 'and', ['product', '=', 'Widget'], 'and', ['amount', '>', '5000']]); } else if (category === 'group') { grid.beginUpdate(); grid.columnOption('country', 'groupIndex', 0); grid.columnOption('product', 'groupIndex', 1); grid.endUpdate(); } }; return { name: 'DevExpress Grid', homepage: 'http://js.devexpress.com/WebDevelopment/DataGrid/', defer: true, fn: fn, onComplete: destroyGrid, }; } function infragisticsCase() { var columnsDefs = [ { headerText: 'ID', key: 'id', width: 80, }, { headerText: 'Date', key: 'date', width: 120, }, { headerText: 'Country', key: 'country', dataType: 'string', width: 80, }, { headerText: 'Product', key: 'product', width: 80, }, { headerText: 'Color', key: 'color', width: 80, }, { headerText: 'Amount', key: 'amount', dataType: 'number', width: 80, }, { headerText: 'Big', key: 'big', width: 80, }, ]; var option = { autoGenerateColumns: false, width: gridWidth, //allowFiltering: true, columns: columnsDefs, dataSource: data, features: [ { name: 'Sorting', type: 'local', columnSettings: [], }, { name: 'Filtering', type: 'local', mode: 'advanced', columnSettings: [], }, { name: 'GroupBy', columnSettings: [], }, ], }; var fn = function fn() { destroyGrid(); var category = currentCategory(); var container = createContainer(); $(container).igGrid(option); var grid = $(container).data('igGrid'); container.grid = grid; $('.ui-iggrid-groupbyarea').hide(); if (category === 'sort') { $(container).igGridSorting('sortColumn', 'country', 'asc'); } else if (category === 'filter') { $(container).igGridFiltering('filter', [ { fieldName: 'country', expr: 'US', cond: 'equals', logic: 'AND', }, { fieldName: 'product', expr: 'Widget', cond: 'equals', logic: 'AND', }, { fieldName: 'amount', expr: 5000, cond: 'greaterThan', logic: 'AND', }, ]); } else if (category === 'group') { $(container).igGridGroupBy('groupByColumn', 'country'); $(container).igGridGroupBy('groupByColumn', 'product'); } return grid; }; return { name: 'IgniteUI Grid', homepage: 'http://www.igniteui.com/grid/overview', fn: fn, onComplete: destroyGrid, }; } function syncfusionCase() { var cols = [ { field: 'id', headerText: 'ID', isPrimaryKey: true, width: 80, }, { field: 'date', binding: 'Date', width: 120, }, { field: 'country', headerText: 'Country', width: 80, allowSorting: true, }, { field: 'product', headerText: 'Product', width: 80, }, { field: 'color', headerText: 'Color', width: 80, }, { field: 'amount', headerText: 'Amount', width: 80, }, { field: 'big', headerText: 'Big', width: 80, }, ]; var options = { dataSource: data, allowPaging: false, allowSorting: true, allowFiltering: true, allowGrouping: true, columns: cols, }; var fn = function fn() { destroyGrid(); var category = currentCategory(); var container = createContainer(); $(container).ejGrid(options); var grid = $(container).data('ejGrid'); container.grid = grid; if (category === 'sort') { grid.sortColumn('country', 'ascending'); } else if (category === 'filter') { grid.filterColumn([ { field: 'country', operator: 'equal', value: 'US', predicate: 'and', matchcase: true, }, { field: 'product', operator: 'equal', value: 'Widget', predicate: 'and', matchcase: true, }, { field: 'amount', operator: 'greaterthan', value: '5000', predicate: 'and', matchcase: true, }, ]); } else if (category === 'group') { grid.groupColumn('country'); grid.groupColumn('product'); } }; return { name: 'syncfusion', homepage: 'http://www.syncfusion.com/products/javascript/ejgrid', fn: fn, onComplete: destroyGrid, }; } function wijmoCase() { var cols = [ { header: 'ID', binding: 'id', width: 80, }, { header: 'Date', binding: 'date', width: 120, }, { header: 'Country', binding: 'country', width: 80, }, { header: 'Product', binding: 'product', width: 80, }, { header: 'Color', binding: 'color', width: 80, }, { header: 'Amount', binding: 'amount', width: 80, }, { header: 'Big', binding: 'big', width: 80, }, ]; var fn = function fn() { destroyGrid(); var category = currentCategory(); var container = createContainer(); var grid = new wijmo.grid.FlexGrid(container); var cv = new wijmo.collections.CollectionView(data); grid.initialize({ autoGenerateColumns: false, columns: cols, itemsSource: cv, }); if (category === 'sort') { cv.sortDescriptions.splice(0, 1, new wijmo.collections.SortDescription('country', true)); } else if (category === 'filter') { cv.filter = function (item) { return item.country === 'US' && item.product === 'Widget' && item.amount > 5000; }; } else if (category === 'group') { cv.groupDescriptions.push(new wijmo.collections.PropertyGroupDescription('country')); cv.groupDescriptions.push(new wijmo.collections.PropertyGroupDescription('product')); // grid.collapseGroupsToLevel(0); } }; return { name: 'Wijmo FlexGrid', homepage: 'http://wijmo.com/products/wijmo-5/', fn: fn, onComplete: destroyGrid, }; } function slickGridCase() { var cols = [ { id: 'id', name: 'ID', field: 'id', width: 80, }, { id: 'date', name: 'Date', field: 'date', width: 120, }, { id: 'country', name: 'Country', field: 'country', sortable: true, width: 80, }, { id: 'product', name: 'Product', field: 'product', width: 80, }, { id: 'color', name: 'Color', field: 'color', width: 80, }, { id: 'amount', name: 'Amount', field: 'amount', width: 80, }, { id: 'big', name: 'Big', field: 'big', width: 80, }, ]; var options = { editable: true, enableCellNavigation: true, asyncEditorLoading: false, enableColumnReorder: false, autoEdit: true, }; var fn = function fn() { destroyGrid(); var category = currentCategory(); var container = createContainer(); var dataView = new Slick.Data.DataView(); dataView.setItems(data); var grid = new Slick.Grid(container, dataView, cols, options); if (category === 'sort') { var comparer = function comparer(a, b) { var v1 = a.country; var v2 = b.country; return v1 > v2 ? -1 : v1 < v2 ? +1 : 0; }; grid.getData().sort(comparer, false); grid.invalidateAllRows(); grid.render(); } else if (category === 'filter') { var myFilter = function myFilter(item) { return item.country === 'US' && item.product === 'Widget' && item.amount > 5000; }; grid.getData().setFilter(myFilter); grid.invalidateAllRows(); grid.render(); } }; return { name: 'slickGrid', homepage: 'http://slickgrid.net/', fn: fn, onComplete: destroyGrid, }; } $(function () { window.ui.add(dataViewCase()); window.ui.add(agGridCase()); window.ui.add(infragisticsCase()); window.ui.add(syncfusionCase()); window.ui.add(wijmoCase()); window.ui.add(slickGridCase()); });
html, body, h1, h2, h3, fieldset, #faq, #faq dt, #faq dd { margin: 0; padding: 0; border: 0; } table, p, ul, h1, h2, h3, #error-info, form div, #faq, .bs-rt { margin-bottom: 1em; } button, input, textarea, a, .bs-rt { border-radius: 4px; } html, input, textarea, button { font: 1em/1.5 sans-serif; } body { background: #fff; padding: 0 2.5em; margin: 0 auto; min-height: 100%; } a, .btn-link { color: #357ab0; padding: 0.2em; } a:hover, a:focus, .btn-link:hover, .btn-link:focus { text-decoration: none; } .btn-link { background-color: transparent; border: 0; text-decoration: underline; } .btn-link:hover, .btn-link:focus { cursor: pointer; } blockquote { margin: 0 0 1em; border-left: 5px solid #b4b4b4; padding-left: 0.5em; } table { border-collapse: collapse; } thead th, button:hover, button:focus, .submit:hover, .submit:focus, a:hover, a:focus, .btn-link:hover, .btn-link:focus, #comments .meta a:hover, #comments .meta a:focus, li.current a:hover, li.current a:focus, form h3, #comments .owner .meta { background: #1a6ab9; background-image: linear-gradient(top, #6ca5dd, #1a6ab9); color: #fff; } caption, #comments .meta { background: #bcbcbc; background-image: linear-gradient(top, #d0d0d0, #a7a7a7); color: #555; } thead th, caption { font-weight: bold; } .js tbody th:hover, .js tbody th:focus { text-decoration: underline; cursor: pointer; } tbody th, td { border: solid #b4b4b4; border-width: 0 1px 1px 0; } tbody th { background: #dde4ea; width: 150px; } td.results { text-align: center; border-right: 0; } .results span, small { display: block; font-size: 0.8em; } td, th, caption { padding: 0.2em 0.5em; } td.fastest { background: #9cee82; } tr:last-child td, tr:last-child th { border-bottom: 0; } td.slowest, td.error, .invalid { background: pink; } /* needs its own rule because of buggy IE */ :focus:invalid { background: pink; } td.error { text-transform: uppercase; font-weight: bold; } button, .submit { padding: 0.35em 0.5em; cursor: pointer; color: #000; border: 1px solid #999; background: #dadada; background-image: linear-gradient(top, #ebebeb, #b8b8b8); } .login { padding: 0.35em 0.5em; text-decoration: none; cursor: pointer; color: #000; border: 1px solid #999; background: #dadada; background-image: linear-gradient(top, #ebebeb, #b8b8b8); } a:hover span, a:focus span, #comments .owner .meta a { color: #fff; } #options { display: flex; align-items: center; flex-wrap: wrap; } #options label, #options select { margin-right: 5px; } #options .option { display: inline-block; margin-bottom: 0.5em; } #test-container { display: flex; flex-direction: column; max-width: 800px; } #test-table { flex: 1 1; width: 100%; margin: 0.5em 0; } #controls { display: flex; align-items: center; justify-content: space-between; flex: 1 1; width: 100%; margin: 0.5em 0; } .buttons { float: right; } button:hover, button:focus, .submit:hover, .submit:focus { border-color: #357ab0; } #add-buttons button { padding: 0.15em 0.4em; font-size: 11px; font-weight: bold; } form label { float: left; width: 14em; cursor: pointer; text-align: right; margin-right: 1em; padding: 0.4em; } label.inline { float: none; padding: 0; margin: 0; } label[for=visible], label[for$="][defer]"] { position: relative; top: -0.37em; } label span { display: block; font-size: 90%; color: #b4b4b4; } label em { color: red; font-style: normal; } .js #advanced { display: none; } #show-advanced { display: none; } .js #show-advanced { display: block; } section { display: block; margin: 2em 0; } textarea { resize: vertical; height: 15em; width: 42.6em; *width: 42.4em; /* IE < 8 */ } input, textarea { border: 1px solid #b4b4b4; padding: 0.4em; } input[type=search] { -webkit-appearance: none; } #visible, #calibrate { /* checkboxes, for IE */ border: 0; padding: 0; } form h2, form h3, form h4, p.error, .preview, #add-libraries, #add-buttons { padding-left: 250px; display: block; } hgroup h2, #firebug, #java { display: none; } pre { width: 100%; overflow: auto; white-space: pre; white-space: pre-wrap; word-wrap: break-word; } table #results-1 { width: 100px; } table pre { *padding: 1.5em 0; /* IE < 8 */ *overflow-y: hidden; /* IE < 8 */ } table pre, table td.code { width: 600px; } mark { background: #ff9; padding: 0.2em 0.1em; } h1, h2, h3, h4 { font-weight: bold; font-size: 1em; } h1 { padding-top: 1em; font-size: 1.4em; } form h3 { padding-top: 0.2em; padding-bottom: 0.2em; } h1 em { font-style: normal; } h1 strong { font-style: italic; font-family: Monaco, "Lucida Console", monospace; } li.current a { background: #90ee85; } footer { display: block; margin-top: 2em; border-top: 2px solid #c4c4c4; font-size: 0.9em; overflow: hidden; } footer ul { list-style: none; padding: 0; margin: 0; } footer > ul > li { float: left; width: 15%; } footer > ul > li:first-child { width: 55%; } footer ul ul li { margin-bottom: 0.1em; } footer h4 { margin-bottom: 0.2em; } #add-test { margin-right: 0.3em; } #bs-chart { overflow: auto; } #bs-chart-frame { height: 240px; width: 100%; } #bs-logo { margin: 0; } #bs-logo span, applet { position: absolute; left: -9999em; } #bs-logo a { display: block; width: 232px; height: 39px; filter: none; background: url(//www.browserscope.org/static/img/logo.png) 0 0 no-repeat; } #bs-ua { padding: 0.5em 0.5em 0; color: #555; } #bs-results .bs-rt { font-size: 10pt; padding: 0.5em; background: #ddd; } #bs-results td { border: 1px solid #ddd; padding: 0.4em; white-space: nowrap; } #bs-results .rt-ua-cur { font-style: italic; font-weight: bold; } #bs-results .bs-rt-message { padding: 3em; text-align: center; font-weight: bold; color: #555; } #bs-results .google-visualization-table-tr-head td { white-space: normal; } #comments h1 { padding: 0; } #comments .meta img { position: absolute; left: 0; top: 0; margin: 0; } #comments .meta img { top: 2px; left: 2px; } #comments .meta { padding-left: 35px; margin-top: 0; width: 923px; line-height: 30px; } #comments .meta a { font-weight: bold; color: #555; } #comments article div { padding: 0 1em 0; } #comments article { display: block; border: 1px solid #b4b4b4; position: relative; margin-bottom: 1em; } /* needs its own rule (cannot be grouped with `tbody th`) because of buggy IE */ #comments article:target { background: #dde4ea; } #error-info.show, .meta strong, #firebug strong, #java strong, #status strong { background: pink; border: 1px solid #b00b00; padding: 0.4em; } #error-info.show { padding: 0.5em 1em; } #error-info, code, samp, var, textarea, #slug { font-family: Monaco, monospace; font-size: 0.9em; -moz-tab-size: 2; tab-size: 2; } #java strong { background: #ffffdc; border: 1px solid #faa700; } #slug { font-size: 1em; } #faq dt { margin-top: 1em; font-weight: bold; } #faq dt a { display: none; } #faq dt:hover a { display: inline; } #faq dt:target, #faq dt:target + dd { background: #90ee85; margin: 0 -0.8em; padding: 0 0.8em; } #faq dt:target + dd { padding-bottom: 0.5em; margin-bottom: -0.5em; } #faq dt:target { margin-top: 0.5em; padding-top: 0.5em; } #firebug, #java { margin: 0 0 1em; padding: 0.3em 0; } #prep-code pre { max-height: 500px; overflow: auto; } #firebug.show, #java.show { display: block; } .co1, .co2, .coMULTI { font-style: italic; color: #060; } .error { color: #b00b00; } .imp { color: red; } .kw1, .kw3 { color: #006; } .kw2 { color: #036; } .es0 { color: #009; } .br0 { color: #090; } .sy0 { color: #393; } .st0 { color: #36c; } .nu0 { color: #c00; } .me1 { color: #606; } #carbonads { float: right; width: 130px; font-size: 80%; } #carbonads a { display: block; } /* < 1051px */ @media (max-width: 1050px) { table pre, table td.code { width: 550px; } } /* < 1041px */ @media (max-width: 1040px) { body { margin: 0; border: 0; } body, #comments .meta { width: 100%; box-sizing: border-box; } } /* < 801px */ @media (max-width: 800px) { table pre, table td.code { width: 450px; } } /* < 681px */ @media (max-width: 680px) { table pre, table td.code { width: 350px; } } /* < 651px */ @media (max-width: 650px) { table pre, table td.code { width: 200px; } } /*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["Grid/purejs/build.json","Grid/purejs/build.css"],"names":[],"mappings":"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","file":"Grid/purejs/styles.css","sourcesContent":["html,\nbody,\nh1,\nh2,\nh3,\nfieldset,\n#faq,\n#faq dt,\n#faq dd {\n  margin: 0;\n  padding: 0;\n  border: 0;\n}\n\ntable,\np,\nul,\nh1,\nh2,\nh3,\n#error-info,\nform div,\n#faq,\n.bs-rt {\n  margin-bottom: 1em;\n}\n\nbutton,\ninput,\ntextarea,\na,\n.bs-rt {\n  -moz-border-radius: 4px;\n  -webkit-border-radius: 4px;\n  border-radius: 4px;\n}\n\nhtml,\ninput,\ntextarea,\nbutton {\n  font: 1em/1.5 sans-serif;\n}\n\nbody {\n  background: #fff;\n  padding: 0 2.5em;\n  margin: 0 auto;\n  min-height: 100%;\n}\n\na,\n.btn-link {\n  color: #357ab0;\n  padding: 0.2em;\n}\n\na:hover,\na:focus,\n.btn-link:hover,\n.btn-link:focus {\n  text-decoration: none;\n}\n\n.btn-link {\n  background-color: transparent;\n  border: 0;\n  text-decoration: underline;\n}\n\n.btn-link:hover,\n.btn-link:focus {\n  cursor: pointer;\n}\n\nblockquote {\n  margin: 0 0 1em;\n  border-left: 5px solid #b4b4b4;\n  padding-left: 0.5em;\n}\n\ntable {\n  border-collapse: collapse;\n}\n\nthead th,\nbutton:hover,\nbutton:focus,\n.submit:hover,\n.submit:focus,\na:hover,\na:focus,\n.btn-link:hover,\n.btn-link:focus,\n#comments .meta a:hover,\n#comments .meta a:focus,\nli.current a:hover,\nli.current a:focus,\nform h3,\n#comments .owner .meta {\n  background: #1a6ab9;\n  background-image: linear-gradient(top, #6ca5dd, #1a6ab9);\n  color: #fff;\n}\n\ncaption,\n#comments .meta {\n  background: #bcbcbc;\n  background-image: linear-gradient(top, #d0d0d0, #a7a7a7);\n  color: #555;\n}\n\nthead th,\ncaption {\n  font-weight: bold;\n}\n\n.js tbody th:hover,\n.js tbody th:focus {\n  text-decoration: underline;\n  cursor: pointer;\n}\n\ntbody th,\ntd {\n  border: solid #b4b4b4;\n  border-width: 0 1px 1px 0;\n}\n\ntbody th {\n  background: #dde4ea;\n  width: 150px;\n}\n\ntd.results {\n  text-align: center;\n  border-right: 0;\n}\n\n.results span,\nsmall {\n  display: block;\n  font-size: 0.8em;\n}\n\ntd,\nth,\ncaption {\n  padding: 0.2em 0.5em;\n}\n\ntd.fastest {\n  background: #9cee82;\n}\n\ntr:last-child td,\ntr:last-child th {\n  border-bottom: 0;\n}\n\ntd.slowest,\ntd.error,\n.invalid {\n  background: pink;\n}\n\n/* needs its own rule because of buggy IE */\n:focus:invalid {\n  background: pink;\n}\n\ntd.error {\n  text-transform: uppercase;\n  font-weight: bold;\n}\n\nbutton,\n.submit {\n  padding: 0.35em 0.5em;\n  cursor: pointer;\n  color: #000;\n  border: 1px solid #999;\n  background: #dadada;\n  background-image: linear-gradient(top, #ebebeb, #b8b8b8);\n}\n\n.login {\n  padding: 0.35em 0.5em;\n  text-decoration: none;\n  cursor: pointer;\n  color: #000;\n  border: 1px solid #999;\n  background: #dadada;\n  background-image: linear-gradient(top, #ebebeb, #b8b8b8);\n}\n\na:hover span,\na:focus span,\n#comments .owner .meta a {\n  color: #fff;\n}\n\n#options {\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n\n  label,\n  select {\n    margin-right: 5px;\n  }\n\n  .option {\n    display: inline-block;\n    margin-bottom: 0.5em;\n  }\n}\n\n#test-container {\n  display: flex;\n  flex-direction: column;\n  max-width: 800px;\n}\n\n#test-table {\n  flex: 1 1;\n  width: 100%;\n  margin: 0.5em 0;\n}\n\n#controls {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  flex: 1 1;\n  width: 100%;\n  margin: 0.5em 0;\n}\n\n.buttons {\n  float: right;\n}\n\nbutton:hover,\nbutton:focus,\n.submit:hover,\n.submit:focus {\n  border-color: #357ab0;\n}\n\n#add-buttons button {\n  padding: 0.15em 0.4em;\n  font-size: 11px;\n  font-weight: bold;\n}\n\nform label {\n  float: left;\n  width: 14em;\n  cursor: pointer;\n  text-align: right;\n  margin-right: 1em;\n  padding: 0.4em;\n}\n\nlabel.inline {\n  float: none;\n  padding: 0;\n  margin: 0;\n}\n\nlabel[for='visible'],\nlabel[for$='][defer]'] {\n  position: relative;\n  top: -0.37em;\n}\n\nlabel span {\n  display: block;\n  font-size: 90%;\n  color: #b4b4b4;\n}\n\nlabel em {\n  color: red;\n  font-style: normal;\n}\n\n.js #advanced {\n  display: none;\n}\n\n#show-advanced {\n  display: none;\n}\n\n.js #show-advanced {\n  display: block;\n}\n\nsection {\n  display: block;\n  margin: 2em 0;\n}\n\ntextarea {\n  resize: vertical;\n  height: 15em;\n  width: 42.6em;\n  *width: 42.4em; /* IE < 8 */\n}\n\ninput,\ntextarea {\n  border: 1px solid #b4b4b4;\n  padding: 0.4em;\n}\n\ninput[type='search'] {\n  -webkit-appearance: none;\n}\n\n#visible,\n#calibrate {\n  /* checkboxes, for IE */\n  border: 0;\n  padding: 0;\n}\n\nform h2,\nform h3,\nform h4,\np.error,\n.preview,\n#add-libraries,\n#add-buttons {\n  padding-left: 250px;\n  display: block;\n}\n\nhgroup h2,\n#firebug,\n#java {\n  display: none;\n}\n\npre {\n  width: 100%;\n  overflow: auto;\n  white-space: pre;\n  white-space: pre-wrap;\n  word-wrap: break-word;\n}\n\ntable #results-1 {\n  width: 100px;\n}\n\ntable pre {\n  *padding: 1.5em 0; /* IE < 8 */\n  *overflow-y: hidden; /* IE < 8 */\n}\n\ntable pre,\ntable td.code {\n  width: 600px;\n}\n\nmark {\n  background: #ff9;\n  padding: 0.2em 0.1em;\n}\n\nh1,\nh2,\nh3,\nh4 {\n  font-weight: bold;\n  font-size: 1em;\n}\n\nh1 {\n  padding-top: 1em;\n  font-size: 1.4em;\n}\n\nform h3 {\n  padding-top: 0.2em;\n  padding-bottom: 0.2em;\n}\n\nh1 em {\n  font-style: normal;\n}\n\nh1 strong {\n  font-style: italic;\n  font-family: Monaco, 'Lucida Console', monospace;\n}\n\nli.current a {\n  background: #90ee85;\n}\n\nfooter {\n  display: block;\n  margin-top: 2em;\n  border-top: 2px solid #c4c4c4;\n  font-size: 0.9em;\n  overflow: hidden;\n}\n\nfooter ul {\n  list-style: none;\n  padding: 0;\n  margin: 0;\n}\n\nfooter > ul > li {\n  float: left;\n  width: 15%;\n}\n\nfooter > ul > li:first-child {\n  width: 55%;\n}\n\nfooter ul ul li {\n  margin-bottom: 0.1em;\n}\n\nfooter h4 {\n  margin-bottom: 0.2em;\n}\n\n#add-test {\n  margin-right: 0.3em;\n}\n\n#bs-chart {\n  overflow: auto;\n}\n\n#bs-chart-frame {\n  height: 240px;\n  width: 100%;\n}\n\n#bs-logo {\n  margin: 0;\n}\n\n#bs-logo span,\napplet {\n  position: absolute;\n  left: -9999em;\n}\n\n#bs-logo a {\n  display: block;\n  width: 232px;\n  height: 39px;\n  filter: none;\n  background: url(//www.browserscope.org/static/img/logo.png) 0 0 no-repeat;\n}\n\n#bs-ua {\n  padding: 0.5em 0.5em 0;\n  color: #555;\n}\n\n#bs-results .bs-rt {\n  font-size: 10pt;\n  padding: 0.5em;\n  background: #ddd;\n}\n\n#bs-results td {\n  border: 1px solid #ddd;\n  padding: 0.4em;\n  white-space: nowrap;\n}\n\n#bs-results .rt-ua-cur {\n  font-style: italic;\n  font-weight: bold;\n}\n\n#bs-results .bs-rt-message {\n  padding: 3em;\n  text-align: center;\n  font-weight: bold;\n  color: #555;\n}\n\n#bs-results .google-visualization-table-tr-head td {\n  white-space: normal;\n}\n\n#comments h1 {\n  padding: 0;\n}\n\n#comments .meta img {\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 0;\n}\n\n#comments .meta img {\n  top: 2px;\n  left: 2px;\n}\n\n#comments .meta {\n  padding-left: 35px;\n  margin-top: 0;\n  width: 923px;\n  line-height: 30px;\n}\n\n#comments .meta a {\n  font-weight: bold;\n  color: #555;\n}\n\n#comments article div {\n  padding: 0 1em 0;\n}\n\n#comments article {\n  display: block;\n  border: 1px solid #b4b4b4;\n  position: relative;\n  margin-bottom: 1em;\n}\n\n/* needs its own rule (cannot be grouped with `tbody th`) because of buggy IE */\n#comments article:target {\n  background: #dde4ea;\n}\n\n#error-info.show,\n.meta strong,\n#firebug strong,\n#java strong,\n#status strong {\n  background: pink;\n  border: 1px solid #b00b00;\n  padding: 0.4em;\n}\n\n#error-info.show {\n  padding: 0.5em 1em;\n}\n\n#error-info,\ncode,\nsamp,\nvar,\ntextarea,\n#slug {\n  font-family: Monaco, monospace;\n  font-size: 0.9em;\n  -moz-tab-size: 2;\n  -o-tab-size: 2;\n  tab-size: 2;\n}\n\n#java strong {\n  background: #ffffdc;\n  border: 1px solid #faa700;\n}\n\n#slug {\n  font-size: 1em;\n}\n\n#faq dt {\n  margin-top: 1em;\n  font-weight: bold;\n}\n\n#faq dt a {\n  display: none;\n}\n\n#faq dt:hover a {\n  display: inline;\n}\n\n#faq dt:target,\n#faq dt:target + dd {\n  background: #90ee85;\n  margin: 0 -0.8em;\n  padding: 0 0.8em;\n}\n\n#faq dt:target + dd {\n  padding-bottom: 0.5em;\n  margin-bottom: -0.5em;\n}\n\n#faq dt:target {\n  margin-top: 0.5em;\n  padding-top: 0.5em;\n}\n\n#firebug,\n#java {\n  margin: 0 0 1em;\n  padding: 0.3em 0;\n}\n\n#prep-code pre {\n  max-height: 500px;\n  overflow: auto;\n}\n\n#firebug.show,\n#java.show {\n  display: block;\n}\n\n.co1,\n.co2,\n.coMULTI {\n  font-style: italic;\n  color: #060;\n}\n\n.error {\n  color: #b00b00;\n}\n\n.imp {\n  color: red;\n}\n\n.kw1,\n.kw3 {\n  color: #006;\n}\n\n.kw2 {\n  color: #036;\n}\n\n.es0 {\n  color: #009;\n}\n\n.br0 {\n  color: #090;\n}\n\n.sy0 {\n  color: #393;\n}\n\n.st0 {\n  color: #36c;\n}\n\n.nu0 {\n  color: #c00;\n}\n\n.me1 {\n  color: #606;\n}\n\n#carbonads {\n  float: right;\n  width: 130px;\n  font-size: 80%;\n}\n\n#carbonads a {\n  display: block;\n}\n\n/* < 1051px */\n@media (max-width: 1050px) {\n  table pre,\n  table td.code {\n    width: 550px;\n  }\n}\n\n/* < 1041px */\n@media (max-width: 1040px) {\n  body {\n    margin: 0;\n    border: 0;\n  }\n\n  body,\n  #comments .meta {\n    width: 100%;\n    -webkit-box-sizing: border-box;\n    -moz-box-sizing: border-box;\n    box-sizing: border-box;\n  }\n}\n\n/* < 801px */\n@media (max-width: 800px) {\n  table pre,\n  table td.code {\n    width: 450px;\n  }\n}\n\n/* < 681px */\n@media (max-width: 680px) {\n  table pre,\n  table td.code {\n    width: 350px;\n  }\n}\n\n/* < 651px */\n@media (max-width: 650px) {\n  table pre,\n  table td.code {\n    width: 200px;\n  }\n}\n","html,\nbody,\nh1,\nh2,\nh3,\nfieldset,\n#faq,\n#faq dt,\n#faq dd {\n  margin: 0;\n  padding: 0;\n  border: 0;\n}\n\ntable,\np,\nul,\nh1,\nh2,\nh3,\n#error-info,\nform div,\n#faq,\n.bs-rt {\n  margin-bottom: 1em;\n}\n\nbutton,\ninput,\ntextarea,\na,\n.bs-rt {\n  -moz-border-radius: 4px;\n  -webkit-border-radius: 4px;\n  border-radius: 4px;\n}\n\nhtml,\ninput,\ntextarea,\nbutton {\n  font: 1em/1.5 sans-serif;\n}\n\nbody {\n  background: #fff;\n  padding: 0 2.5em;\n  margin: 0 auto;\n  min-height: 100%;\n}\n\na,\n.btn-link {\n  color: #357ab0;\n  padding: 0.2em;\n}\n\na:hover,\na:focus,\n.btn-link:hover,\n.btn-link:focus {\n  text-decoration: none;\n}\n\n.btn-link {\n  background-color: transparent;\n  border: 0;\n  text-decoration: underline;\n}\n\n.btn-link:hover,\n.btn-link:focus {\n  cursor: pointer;\n}\n\nblockquote {\n  margin: 0 0 1em;\n  border-left: 5px solid #b4b4b4;\n  padding-left: 0.5em;\n}\n\ntable {\n  border-collapse: collapse;\n}\n\nthead th,\nbutton:hover,\nbutton:focus,\n.submit:hover,\n.submit:focus,\na:hover,\na:focus,\n.btn-link:hover,\n.btn-link:focus,\n#comments .meta a:hover,\n#comments .meta a:focus,\nli.current a:hover,\nli.current a:focus,\nform h3,\n#comments .owner .meta {\n  background: #1a6ab9;\n  background-image: linear-gradient(top, #6ca5dd, #1a6ab9);\n  color: #fff;\n}\n\ncaption,\n#comments .meta {\n  background: #bcbcbc;\n  background-image: linear-gradient(top, #d0d0d0, #a7a7a7);\n  color: #555;\n}\n\nthead th,\ncaption {\n  font-weight: bold;\n}\n\n.js tbody th:hover,\n.js tbody th:focus {\n  text-decoration: underline;\n  cursor: pointer;\n}\n\ntbody th,\ntd {\n  border: solid #b4b4b4;\n  border-width: 0 1px 1px 0;\n}\n\ntbody th {\n  background: #dde4ea;\n  width: 150px;\n}\n\ntd.results {\n  text-align: center;\n  border-right: 0;\n}\n\n.results span,\nsmall {\n  display: block;\n  font-size: 0.8em;\n}\n\ntd,\nth,\ncaption {\n  padding: 0.2em 0.5em;\n}\n\ntd.fastest {\n  background: #9cee82;\n}\n\ntr:last-child td,\ntr:last-child th {\n  border-bottom: 0;\n}\n\ntd.slowest,\ntd.error,\n.invalid {\n  background: pink;\n}\n\n/* needs its own rule because of buggy IE */\n:focus:invalid {\n  background: pink;\n}\n\ntd.error {\n  text-transform: uppercase;\n  font-weight: bold;\n}\n\nbutton,\n.submit {\n  padding: 0.35em 0.5em;\n  cursor: pointer;\n  color: #000;\n  border: 1px solid #999;\n  background: #dadada;\n  background-image: linear-gradient(top, #ebebeb, #b8b8b8);\n}\n\n.login {\n  padding: 0.35em 0.5em;\n  text-decoration: none;\n  cursor: pointer;\n  color: #000;\n  border: 1px solid #999;\n  background: #dadada;\n  background-image: linear-gradient(top, #ebebeb, #b8b8b8);\n}\n\na:hover span,\na:focus span,\n#comments .owner .meta a {\n  color: #fff;\n}\n\n#options {\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n}\n#options label,\n#options select {\n  margin-right: 5px;\n}\n#options .option {\n  display: inline-block;\n  margin-bottom: 0.5em;\n}\n\n#test-container {\n  display: flex;\n  flex-direction: column;\n  max-width: 800px;\n}\n\n#test-table {\n  flex: 1 1;\n  width: 100%;\n  margin: 0.5em 0;\n}\n\n#controls {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  flex: 1 1;\n  width: 100%;\n  margin: 0.5em 0;\n}\n\n.buttons {\n  float: right;\n}\n\nbutton:hover,\nbutton:focus,\n.submit:hover,\n.submit:focus {\n  border-color: #357ab0;\n}\n\n#add-buttons button {\n  padding: 0.15em 0.4em;\n  font-size: 11px;\n  font-weight: bold;\n}\n\nform label {\n  float: left;\n  width: 14em;\n  cursor: pointer;\n  text-align: right;\n  margin-right: 1em;\n  padding: 0.4em;\n}\n\nlabel.inline {\n  float: none;\n  padding: 0;\n  margin: 0;\n}\n\nlabel[for=visible],\nlabel[for$=\"][defer]\"] {\n  position: relative;\n  top: -0.37em;\n}\n\nlabel span {\n  display: block;\n  font-size: 90%;\n  color: #b4b4b4;\n}\n\nlabel em {\n  color: red;\n  font-style: normal;\n}\n\n.js #advanced {\n  display: none;\n}\n\n#show-advanced {\n  display: none;\n}\n\n.js #show-advanced {\n  display: block;\n}\n\nsection {\n  display: block;\n  margin: 2em 0;\n}\n\ntextarea {\n  resize: vertical;\n  height: 15em;\n  width: 42.6em;\n  *width: 42.4em;\n  /* IE < 8 */\n}\n\ninput,\ntextarea {\n  border: 1px solid #b4b4b4;\n  padding: 0.4em;\n}\n\ninput[type=search] {\n  -webkit-appearance: none;\n}\n\n#visible,\n#calibrate {\n  /* checkboxes, for IE */\n  border: 0;\n  padding: 0;\n}\n\nform h2,\nform h3,\nform h4,\np.error,\n.preview,\n#add-libraries,\n#add-buttons {\n  padding-left: 250px;\n  display: block;\n}\n\nhgroup h2,\n#firebug,\n#java {\n  display: none;\n}\n\npre {\n  width: 100%;\n  overflow: auto;\n  white-space: pre;\n  white-space: pre-wrap;\n  word-wrap: break-word;\n}\n\ntable #results-1 {\n  width: 100px;\n}\n\ntable pre {\n  *padding: 1.5em 0;\n  /* IE < 8 */\n  *overflow-y: hidden;\n  /* IE < 8 */\n}\n\ntable pre,\ntable td.code {\n  width: 600px;\n}\n\nmark {\n  background: #ff9;\n  padding: 0.2em 0.1em;\n}\n\nh1,\nh2,\nh3,\nh4 {\n  font-weight: bold;\n  font-size: 1em;\n}\n\nh1 {\n  padding-top: 1em;\n  font-size: 1.4em;\n}\n\nform h3 {\n  padding-top: 0.2em;\n  padding-bottom: 0.2em;\n}\n\nh1 em {\n  font-style: normal;\n}\n\nh1 strong {\n  font-style: italic;\n  font-family: Monaco, \"Lucida Console\", monospace;\n}\n\nli.current a {\n  background: #90ee85;\n}\n\nfooter {\n  display: block;\n  margin-top: 2em;\n  border-top: 2px solid #c4c4c4;\n  font-size: 0.9em;\n  overflow: hidden;\n}\n\nfooter ul {\n  list-style: none;\n  padding: 0;\n  margin: 0;\n}\n\nfooter > ul > li {\n  float: left;\n  width: 15%;\n}\n\nfooter > ul > li:first-child {\n  width: 55%;\n}\n\nfooter ul ul li {\n  margin-bottom: 0.1em;\n}\n\nfooter h4 {\n  margin-bottom: 0.2em;\n}\n\n#add-test {\n  margin-right: 0.3em;\n}\n\n#bs-chart {\n  overflow: auto;\n}\n\n#bs-chart-frame {\n  height: 240px;\n  width: 100%;\n}\n\n#bs-logo {\n  margin: 0;\n}\n\n#bs-logo span,\napplet {\n  position: absolute;\n  left: -9999em;\n}\n\n#bs-logo a {\n  display: block;\n  width: 232px;\n  height: 39px;\n  filter: none;\n  background: url(//www.browserscope.org/static/img/logo.png) 0 0 no-repeat;\n}\n\n#bs-ua {\n  padding: 0.5em 0.5em 0;\n  color: #555;\n}\n\n#bs-results .bs-rt {\n  font-size: 10pt;\n  padding: 0.5em;\n  background: #ddd;\n}\n\n#bs-results td {\n  border: 1px solid #ddd;\n  padding: 0.4em;\n  white-space: nowrap;\n}\n\n#bs-results .rt-ua-cur {\n  font-style: italic;\n  font-weight: bold;\n}\n\n#bs-results .bs-rt-message {\n  padding: 3em;\n  text-align: center;\n  font-weight: bold;\n  color: #555;\n}\n\n#bs-results .google-visualization-table-tr-head td {\n  white-space: normal;\n}\n\n#comments h1 {\n  padding: 0;\n}\n\n#comments .meta img {\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 0;\n}\n\n#comments .meta img {\n  top: 2px;\n  left: 2px;\n}\n\n#comments .meta {\n  padding-left: 35px;\n  margin-top: 0;\n  width: 923px;\n  line-height: 30px;\n}\n\n#comments .meta a {\n  font-weight: bold;\n  color: #555;\n}\n\n#comments article div {\n  padding: 0 1em 0;\n}\n\n#comments article {\n  display: block;\n  border: 1px solid #b4b4b4;\n  position: relative;\n  margin-bottom: 1em;\n}\n\n/* needs its own rule (cannot be grouped with `tbody th`) because of buggy IE */\n#comments article:target {\n  background: #dde4ea;\n}\n\n#error-info.show,\n.meta strong,\n#firebug strong,\n#java strong,\n#status strong {\n  background: pink;\n  border: 1px solid #b00b00;\n  padding: 0.4em;\n}\n\n#error-info.show {\n  padding: 0.5em 1em;\n}\n\n#error-info,\ncode,\nsamp,\nvar,\ntextarea,\n#slug {\n  font-family: Monaco, monospace;\n  font-size: 0.9em;\n  -moz-tab-size: 2;\n  -o-tab-size: 2;\n  tab-size: 2;\n}\n\n#java strong {\n  background: #ffffdc;\n  border: 1px solid #faa700;\n}\n\n#slug {\n  font-size: 1em;\n}\n\n#faq dt {\n  margin-top: 1em;\n  font-weight: bold;\n}\n\n#faq dt a {\n  display: none;\n}\n\n#faq dt:hover a {\n  display: inline;\n}\n\n#faq dt:target,\n#faq dt:target + dd {\n  background: #90ee85;\n  margin: 0 -0.8em;\n  padding: 0 0.8em;\n}\n\n#faq dt:target + dd {\n  padding-bottom: 0.5em;\n  margin-bottom: -0.5em;\n}\n\n#faq dt:target {\n  margin-top: 0.5em;\n  padding-top: 0.5em;\n}\n\n#firebug,\n#java {\n  margin: 0 0 1em;\n  padding: 0.3em 0;\n}\n\n#prep-code pre {\n  max-height: 500px;\n  overflow: auto;\n}\n\n#firebug.show,\n#java.show {\n  display: block;\n}\n\n.co1,\n.co2,\n.coMULTI {\n  font-style: italic;\n  color: #060;\n}\n\n.error {\n  color: #b00b00;\n}\n\n.imp {\n  color: red;\n}\n\n.kw1,\n.kw3 {\n  color: #006;\n}\n\n.kw2 {\n  color: #036;\n}\n\n.es0 {\n  color: #009;\n}\n\n.br0 {\n  color: #090;\n}\n\n.sy0 {\n  color: #393;\n}\n\n.st0 {\n  color: #36c;\n}\n\n.nu0 {\n  color: #c00;\n}\n\n.me1 {\n  color: #606;\n}\n\n#carbonads {\n  float: right;\n  width: 130px;\n  font-size: 80%;\n}\n\n#carbonads a {\n  display: block;\n}\n\n/* < 1051px */\n@media (max-width: 1050px) {\n  table pre,\ntable td.code {\n    width: 550px;\n  }\n}\n/* < 1041px */\n@media (max-width: 1040px) {\n  body {\n    margin: 0;\n    border: 0;\n  }\n\n  body,\n#comments .meta {\n    width: 100%;\n    -webkit-box-sizing: border-box;\n    -moz-box-sizing: border-box;\n    box-sizing: border-box;\n  }\n}\n/* < 801px */\n@media (max-width: 800px) {\n  table pre,\ntable td.code {\n    width: 450px;\n  }\n}\n/* < 681px */\n@media (max-width: 680px) {\n  table pre,\ntable td.code {\n    width: 350px;\n  }\n}\n/* < 651px */\n@media (max-width: 650px) {\n  table pre,\ntable td.code {\n    width: 200px;\n  }\n}"]} */