Product Catalog

This example uses a common control slicer to filter in DataViews.

<p>This example uses a common control slicer to filter in DataViews. This demo implements an Amazon-like filter panel with the Card Layout Engine to present a product catalog.</p> <p>The slicer allows the user to filter the data in the grid using multiple options. This demo filters TVs by size, resolution, and customer reviews.</p> <p>Try using the filters in the filter panel to pick the type of items that are shown in the grid.</p>
<!DOCTYPE html> <html lang="en"> <head> <base href="/dataviewsjs/demos/en/sample/Showcase/ProductCatalog/purejs/" /> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="keywords" content="filtering" /> <meta name="description" content="This example uses a common control slicer to filter in DataViews." /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Product Catalog | 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.cardlayout.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: 'E674186349827489#B0LYWQMpFdP3WSHlVaGdjTFtyLCxUQjdFV5MHey9kTyBnY0pkY6tWcr34caJjSPlEVlR6QpJnZEdjSj9kbkRUZChzMsRFS99mN4ZGO72yK7FXe5tmN59Eai5UM7dEVvgUeYN5MqdUTIpWTpBnSTJEWv24YwoFWr9mWEl6UNVmVMxUd5ckUQdlUNV4MDhENaV5KNNWbJtiSwFUYCVUax4GUuBjZDN7T5dWdDpFNyJjSxJkes3mUt94QrdnMK5mZORGeFZ4QyFTMmdWOWdlMmJ4ZJhTS5MmZatyZ7k5c0JXVB3mWVNke7AFRiojITJCLikjNBNjNzcjI0ICSiwSN8AjN9YjMwUTM0IicfJye35XX3JSWUVVOiojIDJCLiEjdgMlSzdXZpZVY4FGRiojIOJyebpjIkJHUiwiI9MDMykDMggDM8ATOxAjMiojI4J7QiwiIt36YukHdpNWZwFmcn9iKiojIz5GRiwiIj9WSgkHdpNUZwFmcHJiOiEmTDJCLlVnc4pjIsZXRiwiI9gDN7IDO9QzM6gTM4cjNiojIklkI1pjIEJCLi4TPn3UZuJ7cPZTW5hUMtN7MJN6aQFnT5gmd9FEZ4EETlFmW63kU8IGdiRGTJZle5UDbZJHTR34T0JzZoZmbalXQwNmM8EndEFEdSVlMiVnckFmQUJTOahmc7AzRHhlU4I4Vs3kN6lHaHR4LuhWULNIe', SJS_LICENSE_KEY: '*.grapecity.com,E613631884219496#B0qRgJHWSJ7NyBlc8BjNMRHW7g7YldTZXFTQuFnW4hVOCplVSlVV09ERlhEZuVTVKlTazE4Q6VGSw2CdWZUWSVmbjVXbrxmWFVWR8ZzQro7U84WMGdlbuVHb73kS5kjUTN4NvFVdLdXWVR4Nox6Z7UUSysEcXJEMsN6bDN4TxMDVwVmWBRzKxhkTzAXTaJmdD3CRFJTd8R4R6M5RklWa6oUaLlXMwR4R8ZUdtRWVxUUaQh6VXNDdEhlZ7FHR6QXTPJTVvkWcyZnbSdHRtZHcYF6TKN4axYGcZNjTDF7TvFTTr24VqZjVHVjcLd7QkRmdNxkI0IyUiwiI5gDOEF4QGVjI0ICSiwiMzkTO9kTOyMTM0IicfJye35XX3JSSGljQiojIDJCLiITMuYHITpEIkFWZyB7UiojIOJyebpjIkJHUiwiI4MDMyEDMgkDM8ATOxAjMiojI4J7QiwiIt36YukHdpNWZwFmcn9iKiojIz5GRiwiIj9WagkHdpNUZwFmcHJiOiEmTDJCLlVnc4pjIsZXRiwiI6kDN9EjM4gDOxMjNzEjNiojIklkIs4XZzxWYmpjIyNHZisnOiwmbBJye0ICRiwiI34TQ72kNBV6YXpXdGxGWxdHcol4MyUGUHJVbQVHRx44Sw84YxRkS4QnZadDNmhWWxV5QxFlTlZEbBJ5N8gUNQlDb7J6Kl36YHVnb4NGN92UMFdlNORFU8VDSaFlQSVlS4EHTrA5Ohh', }, }; </script> <script src="/dataviewsjs/demos/node_modules/lodash/lodash.min.js" type="text/javascript"></script> <script src="//cdn.grapecity.com/spreadjs/hosted/scripts/gc.spread.common.12.0.0.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.cardlayout.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/js/license.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 class="demo-container"> <div class="mobile-filter-entry"> <div class="filter-condition"> <span class="filter-label">Filter</span> <span class="fa fa-angle-down"></span> </div> </div> <div class="filter-panel"> <div class="filter-header">Refine by</div> <div id="tv_display_size" class="slicer"></div> <div id="tv_resolution" class="slicer"></div> <div id="customer_review_star" class="slicer"></div> </div> <div id="grid"></div> </div> <script src="data.js" type="text/javascript"></script> <script src="app.js" type="text/javascript"></script> </body> </html>
var rowTemplate = '<div>\n <div data-column="image"></div>\n <div data-column="description"></div>\n <div data-column="brand"></div>\n <div data-column="price"></div>\n <div data-column="starsIcon"></div>\n</div>'; var imagePresenter = '<img class="tv-image" src={{=it.image}} />'; var descriptionPresenter = '<a><b>{{=it.description}}</b></a>'; var brandPresenter = '<div class="tv-brand"><label>by {{=it.brand}}</label></div>'; var pricePresenter = '<div>${{=it.price}}</div>'; var startPresenter = '<div class="stars-box {{=it.starsIcon}}"></div>'; var cols = [ { id: 'image', caption: 'Image', dataField: 'image', presenter: imagePresenter, }, { id: 'description', caption: 'Description', dataField: 'description', presenter: descriptionPresenter, }, { id: 'brand', caption: 'Brand', dataField: 'brand', presenter: brandPresenter, }, { id: 'price', caption: 'Price', dataField: 'price', presenter: pricePresenter, }, { id: 'starsIcon', caption: 'StarsIcon', dataField: 'starsIcon', presenter: startPresenter, }, { id: 'size', caption: 'TV Display Size', dataField: 'size', }, { id: 'refreshRate', caption: 'RefreshRate', dataField: 'refreshRate', }, { id: 'resolution', caption: 'Television Resolution', dataField: 'resolution', }, { id: 'starsValue', caption: 'Avg. Customer Review', dataField: 'starsValue', }, ]; var getCaption = function getCaption(id) { return _.find(cols, function(col) { return col.id === id; }).caption; }; var layout = new GC.DataViews.CardLayout({ cardHeight: 300, cardWidth: 210, rowTemplate: rowTemplate, }); var dataView = new GC.DataViews.DataView(document.getElementById('grid'), data, cols, layout); function Filter(container, columnName, rangeInfo) { this.container = container; this.columnName = columnName; this.rangeInfo = rangeInfo; dataSource.attachListener(this); this.onDataLoaded(); } Object.assign(Filter.prototype, { onDataLoaded: function onDataLoaded() { var _this = this; var container = this.container; var html = this.render(); container.append(html); container.find('.slicer-item input[type=checkbox]').on('click', function(e) { e.preventDefault(); }); container.find('.slicer-item').on('mousedown', function(e) { var slicerItem = $(e.currentTarget); var targetInput = slicerItem.find('input[type=checkbox]'); if (!targetInput.prop('disabled')) { if (targetInput) { targetInput.prop('checked', !targetInput.prop('checked')); } var condition = _this.getFilterCondition(); if (!condition) { dataSource.doUnfilter(_this.columnName); } else { dataSource.doFilter(_this.columnName, condition); } } }); }, onFiltered: function onFiltered(args) { this.clearSlicerItemClass(); this.updateSlicerItem(); var newData = _.map(args.rowIndexes, function(index) { return data[index]; }); dataView.data.setSource_(newData); // Need to be replaced dataView.invalidate(); }, clearSlicerItemClass: function clearSlicerItemClass() { var items = this.container.find('.slicer-item'); var classes = ['filtered', 'filteredOutByOther']; _.each(items, function(item) { _.each(classes, function(itemClass) { $(item).removeClass(itemClass); }); $(item) .find('input[type=checkbox]') .prop('disabled', false); }); }, render: function render() { var _this2 = this; var columnName = this.columnName; var data = this.rangeInfo || dataSource.getExclusiveData(columnName); var header = '<div class="filter-details">'.concat(getCaption(columnName), '</div>'); var body = _.map(data, function(it, idx) { if (_this2.rangeInfo) { var count = dataSource.getData(columnName, it.range).length; return _this2.renderItem(it.label, count); } else { var _count = dataSource.getRowIndexes(columnName, idx).length; return _this2.renderItem(it, _count); } }).join(''); return header + body; }, renderItem: function renderItem(label, count) { var span = '<span>'.concat(label, '</span>'); var badge = '<span class="count-badge">('.concat(count, ')</span>'); return '<div class="slicer-item"><input type="checkbox" />'.concat(span).concat(badge, '</div>'); }, getFilterCondition: function getFilterCondition() { var _this3 = this; var container = this.container; var inputs = container.find('input[type=checkbox]'); if (this.rangeInfo) { var ranges = []; _.each(inputs, function(item, i) { if (item.checked) { ranges.push(_this3.rangeInfo[i].range); } }); return ranges.length ? { ranges: ranges, } : null; } else { var indexes = []; _.each(inputs, function(item, i) { if (item.checked) { indexes.push(i); } }); return indexes.length ? { exclusiveRowIndexes: indexes, } : null; } }, updateSlicerItem: function updateSlicerItem() { var _getItemStates = getItemStates(dataSource, this.rangeInfo, this.columnName), filtered = _getItemStates.filtered, filteredOut = _getItemStates.filteredOut; var items = this.container.find('.slicer-item'); for (var k = 0; k < items.length; k++) { if (filtered.has(k)) { $(items[k]).addClass('filtered'); } if (filteredOut.has(k)) { this.filterOut(items[k]); } } }, filterOut: function filterOut(item) { $(item) .addClass('filteredOutByOther') .find('input[type=checkbox]') .prop('disabled', true); }, }); var sizeRanges = [ { range: { min: -Infinity, max: 32, }, label: '32 Inches & Under', }, { range: { min: 33, max: 43, }, label: '33 to 43 Inches', }, { range: { min: 44, max: 49, }, label: '44 to 49 Inches', }, { range: { min: 50, max: 59, }, label: '50 to 59 Inches', }, { range: { min: 60, max: 69, }, label: '60 to 69 Inches', }, { range: { min: 70, max: Infinity, }, label: '70 Inches & Up', }, ]; var reviewRanges = _.rangeRight(1, 5).map(function(min) { return { range: { min: min, max: Infinity, }, label: '<span><span class="stars-box stars-'.concat(min, '"></span><span class="label">&Up</span></span>'), }; }); new Filter($('#tv_display_size'), 'size', sizeRanges); new Filter($('#tv_resolution'), 'resolution'); new Filter($('#customer_review_star'), 'starsValue', reviewRanges); $('.filter-condition').click(function() { $('.filter-panel').toggle(); }); window.addEventListener('resize', function() { var isMobile = $('.mobile-filter-entry').is(':visible'); $('.filter-panel').toggle(!isMobile); });
var SITE_ROOT = window.process.env.SITE_ROOT; var data = [ { size: 42, refreshRate: 60, resolution: '1080p', price: 399.49, brand: 'LG', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/51RgQIPeyfL._AA160_.jpg', shipToChina: true, description: 'LG Electronics 42LF5600 42-Inch 1080p 60Hz LED TV', }, { size: 105, refreshRate: 120, resolution: '4K', price: 119999.99, brand: 'Samsung', starsIcon: 'stars-4', starsValue: 4, image: SITE_ROOT + '/images/411r27g4Y4L._AA160_.jpg', shipToChina: true, description: 'Samsung UN105S9 Curved 105-Inch 4K Ultra HD 120Hz 3D Smart LED TV', }, { size: 32, refreshRate: 60, resolution: '720p', price: 237.99, brand: 'Samsung', starsIcon: 'stars-5', starsValue: 5, image: SITE_ROOT + '/images/510PicygL._AA160_.jpg', shipToChina: false, description: 'Samsung UN32J4000 32-Inch 720p LED TV', }, { size: 22, refreshRate: 60, resolution: '1080p', price: 167.99, brand: 'Samsung', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/41yd3HTcniL._AA160_.jpg', shipToChina: false, description: 'Samsung UN22F5000 22-Inch 1080p 60Hz LED HDTV (2013 Model)', }, { size: 42, refreshRate: 60, resolution: '1080p', price: 499.99, brand: 'LG', starsIcon: 'stars-3', starsValue: 3, image: SITE_ROOT + '/images/517B8PMhPNL._AA160_.jpg', shipToChina: false, description: 'LG 42LB5600 42-Inch TV (2014 Model)', }, { size: 45, refreshRate: 60, resolution: '1080p', price: 259.99, brand: 'Samsung', starsIcon: 'stars-4', starsValue: 4, image: SITE_ROOT + '/images/516z8QST2CL._AA160_.jpg', shipToChina: true, description: 'Samsung UN32H5203 45-Inch 1080p 60Hz Smart LED TV', }, { size: 46, refreshRate: 60, resolution: '1080p', price: 497.99, brand: 'Samsung', starsIcon: 'stars-3', starsValue: 3, image: SITE_ROOT + '/images/41H0LXbYcXL._AA160_.jpg', shipToChina: true, description: 'Samsung UN32J6300 46-Inch 1080p Smart LED TV', }, { size: 32, refreshRate: 60, resolution: '720p', price: 179.99, brand: 'Upstar', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/41JXS3PTiJL._AA160_.jpg', shipToChina: false, description: 'Upstar P32ES8 32-Inch 720p 60Hz LED TV', }, { size: 40, refreshRate: 60, resolution: '480p', price: 327.99, brand: 'Samsung', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/51JegzA81lL._AA160_.jpg', shipToChina: false, description: 'Samsung UN40H5003 40-Inch 480p 60Hz LED TV', }, { size: 55, refreshRate: 120, resolution: '1080p', price: 727.25, brand: 'LG', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/51yUo1AhEdL._AA160_.jpg', shipToChina: false, description: 'LG Electronics 55LB5900 55-Inch 1080p 120Hz LED TV (2014 Model)', }, { size: 55, refreshRate: 120, resolution: '1080p', price: 679.99, brand: 'LG', starsIcon: 'stars-4', starsValue: 4, image: SITE_ROOT + '/images/4112L6fBNLL._AA160_.jpg', shipToChina: false, description: 'LG Electronics 55LF6000 55-Inch 1080p 120Hz LED TV', }, { size: 24, refreshRate: 60, resolution: '1080p', price: 178.99, brand: 'VIZIO', starsIcon: 'stars-4', starsValue: 4, image: SITE_ROOT + '/images/51tJrIAnF0L._AA160_.jpg', shipToChina: true, description: 'VIZIO E241i-B1 24-Inch 1080p 60Hz Smart LED HDTV (Black)', }, { size: 40, refreshRate: 60, resolution: '1080p', price: 353.7, brand: 'TCL', starsIcon: 'stars-5', starsValue: 5, image: SITE_ROOT + '/images/41iZ3NkxiL._AA160_.jpg', shipToChina: true, description: 'TCL 40FS4610R 40-Inch 1080p Smart LED TV (Roku TV)', }, { size: 55, refreshRate: 60, resolution: '1080p', price: 1000.42, brand: 'Samsung', starsIcon: 'stars-3', starsValue: 3, image: SITE_ROOT + '/images/41H0LXbYcXL._AA160_.jpg', shipToChina: false, description: 'Samsung UN55J6300 55-Inch 1080p Smart LED TV', }, { size: 39, refreshRate: 60, resolution: '1080p', price: 279.99, brand: 'VIZIO', starsIcon: 'stars-5', starsValue: 5, image: SITE_ROOT + '/images/41Voh4kl2hL._AA160_.jpg', shipToChina: false, description: 'VIZIO E390-A1 39-Inch 1080p 60Hz LED TV (Refurbished)', }, { size: 60, refreshRate: 120, resolution: '1080p', price: 899.99, brand: 'LG', starsIcon: 'stars-4', starsValue: 4, image: SITE_ROOT + '/images/51Gx1C4mEFL._AA160_.jpg', shipToChina: false, description: 'LG Electronics 60LB5900 60-Inch 1080p 120Hz LED TV (2014 Model)', }, { size: 32, refreshRate: 60, resolution: '1080p', price: 299.99, brand: 'LG', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/51RgQIPeyfL._AA160_.jpg', shipToChina: false, description: 'LG Electronics 32LF5600 32-Inch 1080p 60Hz LED TV', }, { size: 40, refreshRate: 60, resolution: '1080p', price: 307.99, brand: 'TCL', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/416bLnX49L._AA160_.jpg', shipToChina: false, description: 'TCL LE40FHDE3010 40-Inch 1080p 60Hz LED TV', }, { size: 28, refreshRate: 60, resolution: '720p', price: 165.99, brand: 'Samsung', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/51y45mtIPgL._AA160_.jpg', shipToChina: false, description: 'Samsung UN28H4000 28-Inch 720p 60Hz LED TV', }, { size: 43, refreshRate: 60, resolution: '1080p', price: 445.49, brand: 'VIZIO', starsIcon: 'stars-4-5', starsValue: 4.5, image: SITE_ROOT + '/images/51OEEpDqNHL._AA160_.jpg', shipToChina: false, description: 'VIZIO E43-C2 43-Inch 1080p Smart LED HDTV', }, ]; var dataNames = _.keys(data[0]); var dataValues = _.map(data, function(item) { return _.values(item); }); var dataSource = new GC.Spread.Slicers.GeneralSlicerData(dataValues, dataNames); var getItemStates = function getItemStates(dataSource, rangeState, columnName) { var byOtherColumns = GC.Spread.Slicers.FilteredOutDataType.byOtherColumns; var filteredIndexes = dataSource.getFilteredIndexes(columnName); var filteredOutIndexes = dataSource.getFilteredOutIndexes(columnName, byOtherColumns); var filtered = new Set(); var filteredOut = new Set(); if (rangeState) { var exclusiveData = dataSource.getExclusiveData(columnName); var filteredValues = filteredIndexes.map(function(i) { return exclusiveData[i]; }); var filteredOutValues = filteredOutIndexes.map(function(i) { return exclusiveData[i]; }); var _loop = function _loop(k) { var range = rangeState[k].range; var inrange = function inrange(val) { return val >= range.min && val <= range.max; }; if (filteredValues.some(inrange)) { filtered.add(k); } if (filteredOutValues.some(inrange)) { filteredOut.add(k); } }; for (var k = 0; k < rangeState.length; k++) { _loop(k); } } else { filteredIndexes.forEach(function(k) { filtered.add(k); }); filteredOutIndexes.forEach(function(k) { filteredOut.add(k); }); } return { filtered: filtered, filteredOut: filteredOut, }; };
label { font-weight: normal; margin: 0; } .card-layout.gc-grid { border: 0; } .card-layout .gc-row { padding: 3px; text-align: center; } .card-layout .gc-row .gc-cell { justify-content: center; } #grid { height: 100%; left: 220px; position: absolute; right: 0; } .demo-container { height: 100%; position: relative; -webkit-user-select: none; -ms-user-select: none; user-select: none; width: 100%; } .filter-panel { border: 0; display: block; float: left; height: 100%; overflow: auto; padding-left: 8px; position: static; width: 219px; z-index: auto; } .filter-header { color: #999; font-size: 17px; padding-bottom: 10px; padding-top: 6px; } .filter-details { font-size: 14px; font-weight: 700; padding-bottom: 3px; } .stars-box { background-image: url("/dataviewsjs/demos/images/star-ratings.png"); display: inline-block; height: 13px; overflow: hidden; vertical-align: middle; width: 65px; margin-right: 4px; } .stars-0 { background-position: -65px 0; } .stars-0-5 { background-position: -52px -19px; } .stars-1 { background-position: -52px 0; } .stars-1-5 { background-position: -39px -19px; } .stars-2 { background-position: -39px 0; } .stars-2-5 { background-position: -26px -19px; } .stars-3 { background-position: -26px 0; } .stars-3-5 { background-position: -13px -19px; } .stars-4 { background-position: -13px 0; } .stars-4-5 { background-position: 0 -18px; } .stars-5 { background-position: 0 0; } .tv-image { margin-left: 10px; } .tv-brand { color: #d3d3d3; font-size: 13px; } .tv-price { color: #b12704; } .mobile-filter-entry { display: none; } .filter-condition { border: 1px solid #d3d3d3; cursor: pointer; display: inline-block; font-size: 16px; height: 25px; text-align: center; width: 100px; } .filter-condition .filter-label { margin-right: 5px; } .slicer { margin: 10px 0; } .slicer-item { align-items: center; cursor: pointer; display: flex; margin: 2px 0; } .slicer-item.selected { color: #337ab7; } .slicer-item.selected .label { font-weight: bold; } .slicer-item:hover { color: #e47911; } .slicer-item.filtered { background-color: #fff; } .slicer-item.filteredOutByOther { color: #a6a8b1; } .slicer-item.filteredOutBySelf { background-color: #fff; } .slicer-item input { margin-right: 4px; } .slicer-item .count-badge { margin-left: 4px; color: #a29999; } @media only screen and (max-width: 768px) { #grid { height: 90%; position: static; } .filter-panel { background: #fff; border: 1px solid #d3d3d3; display: none; height: calc(100% - 25px); margin-top: -1px; overflow: auto; padding: 5px 0 0 10px; position: absolute; width: 100%; z-index: 1; } .mobile-filter-entry { display: block; height: 25px; } } /*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["Showcase/ProductCatalog/purejs/styles.scss","Showcase/ProductCatalog/purejs/styles.css"],"names":[],"mappings":"AAAA;EACE,mBAAA;EACA,SAAA;ACCF;;ADEA;EACE,SAAA;ACCF;;ADEA;EACE,YAAA;EACA,kBAAA;ACCF;ADCE;EACE,uBAAA;ACCJ;;ADGA;EACE,YAAA;EACA,WAAA;EACA,kBAAA;EACA,QAAA;ACAF;;ADGA;EACE,YAAA;EACA,kBAAA;EACA,yBAAA;MAAA,qBAAA;UAAA,iBAAA;EACA,WAAA;ACAF;;ADGA;EACE,SAAA;EACA,cAAA;EACA,WAAA;EACA,YAAA;EACA,cAAA;EACA,iBAAA;EACA,gBAAA;EACA,YAAA;EACA,aAAA;ACAF;;ADGA;EACE,WAAA;EACA,eAAA;EACA,oBAAA;EACA,gBAAA;ACAF;;ADGA;EACE,eAAA;EACA,gBAAA;EACA,mBAAA;ACAF;;ADGA;EACE,mEAAA;EACA,qBAAA;EACA,YAAA;EACA,gBAAA;EACA,sBAAA;EACA,WAAA;EACA,iBAAA;ACAF;;ADGA;EACE,4BAAA;ACAF;;ADGA;EACE,gCAAA;ACAF;;ADGA;EACE,4BAAA;ACAF;;ADGA;EACE,gCAAA;ACAF;;ADGA;EACE,4BAAA;ACAF;;ADGA;EACE,gCAAA;ACAF;;ADGA;EACE,4BAAA;ACAF;;ADGA;EACE,gCAAA;ACAF;;ADGA;EACE,4BAAA;ACAF;;ADGA;EACE,4BAAA;ACAF;;ADGA;EACE,wBAAA;ACAF;;ADGA;EACE,iBAAA;ACAF;;ADGA;EACE,cAAA;EACA,eAAA;ACAF;;ADGA;EACE,cAAA;ACAF;;ADGA;EACE,aAAA;ACAF;;ADGA;EACE,yBAAA;EACA,eAAA;EACA,qBAAA;EACA,eAAA;EACA,YAAA;EACA,kBAAA;EACA,YAAA;ACAF;ADEE;EACE,iBAAA;ACAJ;;ADIA;EACE,cAAA;ACDF;;ADIA;EACE,mBAAA;EACA,eAAA;EAGA,aAAA;EACA,aAAA;ACDF;ADGE;EACE,cAAA;ACDJ;ADGI;EACE,iBAAA;ACDN;ADKE;EACE,cAAA;ACHJ;ADME;EACE,sBAAA;ACJJ;ADOE;EACE,cAAA;ACLJ;ADQE;EACE,sBAAA;ACNJ;ADSE;EACE,iBAAA;ACPJ;ADUE;EACE,gBAAA;EACA,cAAA;ACRJ;;ADYA;EACE;IACE,WAAA;IACA,gBAAA;ECTF;;EDYA;IACE,gBAAA;IACA,yBAAA;IACA,aAAA;IACA,yBAAA;IACA,gBAAA;IACA,cAAA;IACA,qBAAA;IACA,kBAAA;IACA,WAAA;IACA,UAAA;ECTF;;EDYA;IACE,cAAA;IACA,YAAA;ECTF;AACF","file":"Showcase/ProductCatalog/purejs/styles.css","sourcesContent":["label {\n  font-weight: normal;\n  margin: 0;\n}\n\n.card-layout.gc-grid {\n  border: 0;\n}\n\n.card-layout .gc-row {\n  padding: 3px;\n  text-align: center;\n\n  .gc-cell {\n    justify-content: center;\n  }\n}\n\n#grid {\n  height: 100%;\n  left: 220px;\n  position: absolute;\n  right: 0;\n}\n\n.demo-container {\n  height: 100%;\n  position: relative;\n  user-select: none;\n  width: 100%;\n}\n\n.filter-panel {\n  border: 0;\n  display: block;\n  float: left;\n  height: 100%;\n  overflow: auto;\n  padding-left: 8px;\n  position: static;\n  width: 219px;\n  z-index: auto;\n}\n\n.filter-header {\n  color: #999;\n  font-size: 17px;\n  padding-bottom: 10px;\n  padding-top: 6px;\n}\n\n.filter-details {\n  font-size: 14px;\n  font-weight: 700;\n  padding-bottom: 3px;\n}\n\n.stars-box {\n  background-image: url('/dataviewsjs/demos/images/star-ratings.png');\n  display: inline-block;\n  height: 13px;\n  overflow: hidden;\n  vertical-align: middle;\n  width: 65px;\n  margin-right: 4px;\n}\n\n.stars-0 {\n  background-position: -65px 0;\n}\n\n.stars-0-5 {\n  background-position: -52px -19px;\n}\n\n.stars-1 {\n  background-position: -52px 0;\n}\n\n.stars-1-5 {\n  background-position: -39px -19px;\n}\n\n.stars-2 {\n  background-position: -39px 0;\n}\n\n.stars-2-5 {\n  background-position: -26px -19px;\n}\n\n.stars-3 {\n  background-position: -26px 0;\n}\n\n.stars-3-5 {\n  background-position: -13px -19px;\n}\n\n.stars-4 {\n  background-position: -13px 0;\n}\n\n.stars-4-5 {\n  background-position: 0 -18px;\n}\n\n.stars-5 {\n  background-position: 0 0;\n}\n\n.tv-image {\n  margin-left: 10px;\n}\n\n.tv-brand {\n  color: #d3d3d3;\n  font-size: 13px;\n}\n\n.tv-price {\n  color: #b12704;\n}\n\n.mobile-filter-entry {\n  display: none;\n}\n\n.filter-condition {\n  border: 1px solid #d3d3d3;\n  cursor: pointer;\n  display: inline-block;\n  font-size: 16px;\n  height: 25px;\n  text-align: center;\n  width: 100px;\n\n  .filter-label {\n    margin-right: 5px;\n  }\n}\n\n.slicer {\n  margin: 10px 0;\n}\n\n.slicer-item {\n  align-items: center;\n  cursor: pointer;\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  margin: 2px 0;\n\n  &.selected {\n    color: #337ab7;\n\n    .label {\n      font-weight: bold;\n    }\n  }\n\n  &:hover {\n    color: #e47911;\n  }\n\n  &.filtered {\n    background-color: #fff;\n  }\n\n  &.filteredOutByOther {\n    color: #a6a8b1;\n  }\n\n  &.filteredOutBySelf {\n    background-color: #fff;\n  }\n\n  input {\n    margin-right: 4px;\n  }\n\n  .count-badge {\n    margin-left: 4px;\n    color: #a29999;\n  }\n}\n\n@media only screen and (max-width: 768px) {\n  #grid {\n    height: 90%;\n    position: static;\n  }\n\n  .filter-panel {\n    background: #fff;\n    border: 1px solid #d3d3d3;\n    display: none;\n    height: calc(100% - 25px);\n    margin-top: -1px;\n    overflow: auto;\n    padding: 5px 0 0 10px;\n    position: absolute;\n    width: 100%;\n    z-index: 1;\n  }\n\n  .mobile-filter-entry {\n    display: block;\n    height: 25px;\n  }\n}\n","label {\n  font-weight: normal;\n  margin: 0;\n}\n\n.card-layout.gc-grid {\n  border: 0;\n}\n\n.card-layout .gc-row {\n  padding: 3px;\n  text-align: center;\n}\n.card-layout .gc-row .gc-cell {\n  justify-content: center;\n}\n\n#grid {\n  height: 100%;\n  left: 220px;\n  position: absolute;\n  right: 0;\n}\n\n.demo-container {\n  height: 100%;\n  position: relative;\n  user-select: none;\n  width: 100%;\n}\n\n.filter-panel {\n  border: 0;\n  display: block;\n  float: left;\n  height: 100%;\n  overflow: auto;\n  padding-left: 8px;\n  position: static;\n  width: 219px;\n  z-index: auto;\n}\n\n.filter-header {\n  color: #999;\n  font-size: 17px;\n  padding-bottom: 10px;\n  padding-top: 6px;\n}\n\n.filter-details {\n  font-size: 14px;\n  font-weight: 700;\n  padding-bottom: 3px;\n}\n\n.stars-box {\n  background-image: url(\"/dataviewsjs/demos/images/star-ratings.png\");\n  display: inline-block;\n  height: 13px;\n  overflow: hidden;\n  vertical-align: middle;\n  width: 65px;\n  margin-right: 4px;\n}\n\n.stars-0 {\n  background-position: -65px 0;\n}\n\n.stars-0-5 {\n  background-position: -52px -19px;\n}\n\n.stars-1 {\n  background-position: -52px 0;\n}\n\n.stars-1-5 {\n  background-position: -39px -19px;\n}\n\n.stars-2 {\n  background-position: -39px 0;\n}\n\n.stars-2-5 {\n  background-position: -26px -19px;\n}\n\n.stars-3 {\n  background-position: -26px 0;\n}\n\n.stars-3-5 {\n  background-position: -13px -19px;\n}\n\n.stars-4 {\n  background-position: -13px 0;\n}\n\n.stars-4-5 {\n  background-position: 0 -18px;\n}\n\n.stars-5 {\n  background-position: 0 0;\n}\n\n.tv-image {\n  margin-left: 10px;\n}\n\n.tv-brand {\n  color: #d3d3d3;\n  font-size: 13px;\n}\n\n.tv-price {\n  color: #b12704;\n}\n\n.mobile-filter-entry {\n  display: none;\n}\n\n.filter-condition {\n  border: 1px solid #d3d3d3;\n  cursor: pointer;\n  display: inline-block;\n  font-size: 16px;\n  height: 25px;\n  text-align: center;\n  width: 100px;\n}\n.filter-condition .filter-label {\n  margin-right: 5px;\n}\n\n.slicer {\n  margin: 10px 0;\n}\n\n.slicer-item {\n  align-items: center;\n  cursor: pointer;\n  display: -webkit-box;\n  display: -ms-flexbox;\n  display: flex;\n  margin: 2px 0;\n}\n.slicer-item.selected {\n  color: #337ab7;\n}\n.slicer-item.selected .label {\n  font-weight: bold;\n}\n.slicer-item:hover {\n  color: #e47911;\n}\n.slicer-item.filtered {\n  background-color: #fff;\n}\n.slicer-item.filteredOutByOther {\n  color: #a6a8b1;\n}\n.slicer-item.filteredOutBySelf {\n  background-color: #fff;\n}\n.slicer-item input {\n  margin-right: 4px;\n}\n.slicer-item .count-badge {\n  margin-left: 4px;\n  color: #a29999;\n}\n\n@media only screen and (max-width: 768px) {\n  #grid {\n    height: 90%;\n    position: static;\n  }\n\n  .filter-panel {\n    background: #fff;\n    border: 1px solid #d3d3d3;\n    display: none;\n    height: calc(100% - 25px);\n    margin-top: -1px;\n    overflow: auto;\n    padding: 5px 0 0 10px;\n    position: absolute;\n    width: 100%;\n    z-index: 1;\n  }\n\n  .mobile-filter-entry {\n    display: block;\n    height: 25px;\n  }\n}"]} */