This demo shows how to configure the group to display in compact mode.
Compact mode looks like a tree when you enable automatic merge in grouped columns.
Normally, the group expand or collapse icon is shown in the group header and the group header does not take into account the automatic merged area, so as a result, the group header may appear cluttered.
In order to solve this problem, DataViews provides a cellMergingSettings.groupedColumn.showIcon option to display the expand or collapse icon in the merged column.
In addition, there is another option, cellMergingSettings.onlyShowFirstRow, which only shows the merged value in the first row of each group.
Note: If the group is collapsed in compact mode, the footer is always shown even if it's set to hidden in the group configuration.
Try checking some of the options and see how it affects the grid.
<!DOCTYPE html>
<html lang="en">
<head>
<base href="/dataviewsjs/demos/en/sample/Features/Grouping/CompactMode/angular/" />
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="keywords" content="columns, auto, merge" />
<meta name="description" content="This demo shows how to configure the group to display in compact mode." />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Compact Mode | Features | MESCIUS DataViewsJS Angular 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" />
<script src="/dataviewsjs/demos/static/js/angular-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: 'angular',
DVJS_LICENSE_KEY:
'E348418822993781#B0EWvwY4dNNVQqJHUDpFROVWe5ZWNYFlVQFmRsJWRht4Z6lDO4Vla7YUaXhEWxd7Z5YXMuRnY7tWTQRHSlVnaYlXNhlEOpdkZ0FHWYJ5QKd6VXN5aR3ieGhUav9kZTBXWahkYBhEVutmZ72CbjdlZvV5TVdGdiplQsZXe95kUmNmZVF5cJ3mcypWNyx4UydESE3UblxGZyE7KQ94R4BjbUxUewsiaoREMxRDNllWREV6Voh4Q4dDZPRjWrIzUJl4TERXcQZWMHp4Sp9WaMZzN5o6StJmVDJXcwIVVmR6UMVGOlxUW8RmTxZDZTJWVN5GZqJHZuVDMkVGSW3WdxNzKCdDdSB7TzY7cqlnMU5GVyNzNP9WMyhDRvEEOFdkQORDM4dFVlFFWqFWSyMjNQJiOiMlIsISQyIkQ9YjQxIiOigkIsUTM7YjNxYTM0IicfJye&Qf35VfikFVVljI0IyQiwiIxYHITp4c7VWaWFGdhRkI0IiTis7W0ICZyBlIsIiNxUTN6ADI8EDMxMjMwIjI0ICdyNkIsIyc59yc5l6YzVWbuoCLwpmLzVXajNXZt9iKs2WauMXdpN6cl5mLqwSbvNmLzVXajNXZt9iKsAnau26YuMXdpN6cl5mLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLuNmLt36YukHdpNWZwFmcn9iKs46bj9Se4l6YlBXYydmLqwicr9ybj9Se4l6YlBXYydmLqwCcq9ybj9Se4l6YlBXYydmLqIiOiMXbEJCLiMVVJN4UF5kI0ISYONkIsUWdyRnOiwmdFJCLiEDO7MTO9IjM8gTM4gDNzIiOiQWSisnOiQkIsISP3EkVxBVUHFDMplzLlVUdGd7cI9UeIt4SshESzV7NvY7ZxlDOuNTb5tzLr',
SJS_LICENSE_KEY:
'E518585142165236#B0wm4nx4QzdlTHRTSOFzcvVnaJdjSnNEeXdTMUtSUzk6bU94QuVXNwZVZjd4SzYjcadXRIVEMzEXTThkVyR7R85UayoHZZBTYQ5mZyh4Shd6VxFXazF4cBNGRG5WTvUGTsV4T6knQYRzKxxUdk9EarplU7d6VLF6KIR7bPJ5N6ZUMWZWaURGRKRDbLJDN5YjSN5mUoxmaxonSD56LEh7Y7RXenpmTvomevZlV9dkaysCO7hTRQFHcGRWQyc5LI9kQmB7QwR4Z7ZHOR3CSXp6SiFWYzFXeXZUSp94K8VDTkFjdwl4KptSYlRWcDxmNE5kS6kzdrkVcNJXROVGbLJkcTNGRzIER8tmd4YGNhh7dxAnMvIHRv46VtBXS4U5KvJ6dZJ6M5p4TxIjd9I5QSpXTTV6SDZXb7lzaL56ZiojITJCLikTQxUTQFV4NiojIIJCLyETO7UzM7kTO0IicfJye&Qf35VfikkR9IkI0IyQiwiIyEjL6ByUKBCZhVmcwNlI0IiTis7W0ICZyBlIsISNwkTN6ADI8EDMxMjMwIjI0ICdyNkIsIyc59yc5l6YzVWbuoCLwpmLzVXajNXZt9iKs2WauMXdpN6cl5mLqwSbvNmLzVXajNXZt9iKsAnau26YuMXdpN6cl5mLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLuNmLt36YukHdpNWZwFmcn9iKs46bj9Se4l6YlBXYydmLqwicr9ybj9Se4l6YlBXYydmLqwCcq9ybj9Se4l6YlBXYydmLqIiOiMXbEJCLiMVVJN4UF5kI0ISYONkIsUWdyRnOiwmdFJCLiYzMyUjNxIDNxUDO5gTM5IiOiQWSiwSfdtlOicGbmJCLlNHbhZmOiI7ckJye0ICbuFkI1pjIEJCLi4TPRtGOhtWWEFWd4IDOLRVRvx4SyMGcDhTW6n4ep',
},
};
</script>
<script src="/dataviewsjs/demos/node_modules/jquery/dist/jquery.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">
<noscript>You need to enable JavaScript to run this app.</noscript>
<app-root></app-root>
<script type="text/javascript">
System.import('./app.ts');
</script>
</body>
</html>
<div class="main-container responsive-container">
<div class="mobile-only toggle-options">
<span class="fa fa-cog"></span>
</div>
<gc-dataview
id="grid"
class="grid main-content"
[data]="data"
[cols]="cols"
[layout]="layout"
[options]="options"
></gc-dataview>
<div class="sample-options">
<div class="option-row">
<input type="checkbox" [(ngModel)]="showIcon" />
<label htmlFor="show-icon">{{ locale.showIcon }}</label>
</div>
<div class="option-row">
<input type="checkbox" [(ngModel)]="onlyShowFirstRow" />
<label htmlFor="show-first-value">{{ locale.showFirstValue }}</label>
</div>
<div class="option-row">
<input type="checkbox" [(ngModel)]="alwaysShowText" />
<label htmlFor="always-show-text">{{ locale.alwaysShowText }}</label>
</div>
</div>
</div>
import { Component } from '@angular/core';
import { GridLayout } from '@grapecity/dataviews.grid';
import { data } from './data';
import locale from './locale';
export const cols = [
{
caption: 'Store',
columns: [
{
caption: 'Area',
columns: [
{
id: 'state',
caption: 'State',
dataField: 'state',
allowCellMerging: true,
width: 70,
},
{
id: 'city',
caption: 'City',
dataField: 'city',
allowCellMerging: true,
width: 125,
},
],
},
{ id: 'id', caption: 'ID', dataField: 'ID' },
],
},
{
caption: 'Goods',
columns: [
{
caption: 'Fruits',
columns: [
{
id: 'grape',
caption: 'Grape',
dataField: 'grape',
groupFooter: '{{=it.eval("=sum([grape])")}}',
},
{
id: 'apple',
caption: 'Apple',
dataField: 'apple',
groupFooter: '{{=it.eval("=sum([apple])")}}',
},
],
},
{
caption: 'Vegetables',
columns: [
{
id: 'potato',
caption: 'Potato',
dataField: 'potato',
groupFooter: '{{=it.eval("=sum([potato])")}}',
},
{
id: 'tomato',
caption: 'Tomato',
dataField: 'tomato',
groupFooter: '{{=it.eval("=sum([tomato])")}}',
},
],
},
{
caption: 'Foods',
columns: [
{
id: 'sandWich',
caption: 'SandWich',
dataField: 'sandWich',
groupFooter: '{{=it.eval("=sum([sandWich])")}}',
},
{
id: 'Hamburger',
caption: 'Hamburger',
dataField: 'Hamburger',
groupFooter: '{{=it.eval("=sum([Hamburger])")}}',
},
],
},
{
id: 'total',
caption: 'Total',
dataType: 'number',
dataField: '=[grape]+[apple]+[potato]+[tomato]+[sandWich]+[Hamburger]',
groupFooter: '{{=it.eval("=sum([total])")}}',
},
],
},
];
const layout = new GridLayout({
allowColumnReorder: false,
allowCellMerging: true,
selectionUnit: 'cell',
showRowHeader: false,
cellMergingSettings: {
groupedColumn: {
showIcon: true,
},
},
grouping: [
{
field: 'state',
header: {
visible: false,
},
footer: {
columns: [
{
id: 'city',
groupFooter: 'Subtotal by State',
},
],
},
collapsed: true,
},
{
field: 'city',
header: {
visible: false,
},
footer: {
columns: [
{
id: 'id',
groupFooter: 'Subtotal by City',
},
],
},
collapsed: true,
},
],
});
@Component({
selector: 'app-root',
templateUrl: 'app.component.html',
})
export class AppComponent {
locale = locale;
data = data;
cols = cols;
layout = layout;
showIcon = true;
onlyShowFirstRow = false;
alwaysShowText = false;
get options() {
return {
cellMergingSettings: {
groupedColumn: { showIcon: this.showIcon },
onlyShowFirstRow: this.onlyShowFirstRow,
alwaysShowText: this.alwaysShowText,
},
};
}
}
import { NgModule, enableProdMode } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { FormsModule } from '@angular/forms';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppComponent } from './app.component';
import { DataViewModule } from '@grapecity/dataviews.angular';
// zone.js should be loaded last to fix error 'ZoneAwarePromise has been overwritten'
import 'zone.js';
@NgModule({
declarations: [AppComponent],
imports: [DataViewModule, BrowserModule, FormsModule],
providers: [],
bootstrap: [AppComponent],
})
export class AppModule {}
if (process.env.NODE_ENV === 'production') {
enableProdMode();
}
platformBrowserDynamic()
.bootstrapModule(AppModule)
.catch((err) => console.error(err));
// helpers for responsive options panel
$(function () {
$('body').on('click', '.toggle-options', function () {
const options = $('.sample-options');
const display = options.css('display');
options.css({ display: display === 'flex' ? 'none' : 'flex' });
$('.toggle-options .fa').toggleClass('fa-cog').toggleClass('fa-times');
});
window.addEventListener('resize', function () {
if ($('.mobile-only').css('visibility') === 'hidden') {
$('.sample-options').css({ display: 'flex' });
}
});
});
export const data = [
{
ID: '001',
state: 'NC',
city: 'Raleigh',
grape: 293,
apple: 114,
potato: 194,
tomato: 109,
sandWich: 152,
Hamburger: 62,
},
{
ID: '002',
state: 'NC',
city: 'Raleigh',
grape: 200,
apple: 293,
potato: 52,
tomato: 186,
sandWich: 140,
Hamburger: 161,
},
{
ID: '003',
state: 'NC',
city: 'Raleigh',
grape: 277,
apple: 99,
potato: 258,
tomato: 214,
sandWich: 3,
Hamburger: 130,
},
{
ID: '004',
state: 'NC',
city: 'Charlotte',
grape: 130,
apple: 90,
potato: 98,
tomato: 202,
sandWich: 214,
Hamburger: 127,
},
{
ID: '005',
state: 'NC',
city: 'Charlotte',
grape: 227,
apple: 80,
potato: 52,
tomato: 228,
sandWich: 6,
Hamburger: 105,
},
{
ID: '006',
state: 'NC',
city: 'Charlotte',
grape: 10,
apple: 283,
potato: 244,
tomato: 181,
sandWich: 232,
Hamburger: 182,
},
{
ID: '007',
state: 'PA',
city: 'Philadelphia',
grape: 271,
apple: 129,
potato: 153,
tomato: 93,
sandWich: 96,
Hamburger: 290,
},
{
ID: '008',
state: 'PA',
city: 'Philadelphia',
grape: 107,
apple: 278,
potato: 10,
tomato: 276,
sandWich: 153,
Hamburger: 246,
},
{
ID: '009',
state: 'PA',
city: 'Philadelphia',
grape: 81,
apple: 128,
potato: 292,
tomato: 267,
sandWich: 71,
Hamburger: 296,
},
{
ID: '010',
state: 'PA',
city: 'Pittsburgh',
grape: 14,
apple: 226,
potato: 92,
tomato: 261,
sandWich: 147,
Hamburger: 228,
},
{
ID: '011',
state: 'PA',
city: 'Pittsburgh',
grape: 71,
apple: 42,
potato: 8,
tomato: 5,
sandWich: 192,
Hamburger: 282,
},
{
ID: '012',
state: 'PA',
city: 'Pittsburgh',
grape: 114,
apple: 180,
potato: 179,
tomato: 92,
sandWich: 169,
Hamburger: 2,
},
];
export default {
showIcon: 'Show group icon',
showFirstValue: 'Only show first row',
alwaysShowText: 'Always show text',
};
.main-container {
display: flex;
width: 100%;
height: 100%;
}
.sample-options {
background: #fbfbfb;
box-sizing: border-box;
height: 100%;
overflow: auto;
padding: 10px;
width: 210px;
}
.sample-options .option-row {
margin-top: 5px;
display: flex;
align-items: center;
}
.sample-options .option-row label {
margin: 0;
margin-left: 5px;
}
.grid {
height: 100%;
width: calc(100% - 210px);
}
.gc-group-footer-cell {
background-color: transparent;
}
@media only screen and (max-width: 768px) {
.sample-options {
display: none;
}
}
.flex-break {
flex-basis: 100%;
height: 0;
}
.mobile-only {
visibility: hidden;
}
.responsive-container {
display: flex;
box-sizing: border-box;
}
.responsive-container .main-content {
box-sizing: border-box;
height: 100%;
flex-grow: 1;
flex-shrink: 1;
min-width: 50%;
max-width: 100%;
}
.responsive-container .sample-options {
box-sizing: border-box;
display: inline-flex;
flex-direction: column;
height: 100%;
flex-grow: 0;
flex-shrink: 1;
}
.responsive-container .sample-options .option-row {
box-sizing: border-box;
display: inline-flex;
align-items: center;
flex-grow: 0;
flex-shrink: 0;
flex-basis: auto;
white-space: nowrap;
padding-right: 10px;
width: auto;
}
.responsive-container .toggle-options {
align-items: center;
justify-content: center;
position: absolute;
top: 5px;
right: 5px;
background-color: #ebebeb;
color: #47a06c;
border-radius: 16px;
cursor: pointer;
width: 36px;
height: 36px;
font-size: 28px;
z-index: 101;
display: none;
}
@media (min-width: 320px) and (max-width: 480px) and (orientation: portrait) {
.mobile-only {
visibility: visible;
}
.responsive-container {
display: block;
position: relative;
}
.responsive-container .main-content {
position: absolute;
display: block;
top: 0;
left: 0;
width: 100%;
max-width: 100%;
z-index: 99;
}
.responsive-container .toggle-options {
display: flex;
}
.responsive-container .sample-options {
display: none;
position: absolute;
top: 0;
left: 0;
width: 100%;
max-width: 100%;
height: 100%;
z-index: 100;
}
.responsive-container .sample-options .option-row {
padding-right: 20px;
}
}
/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["Features/Grouping/CompactMode/angular/styles.scss","Features/Grouping/CompactMode/angular/styles.css"],"names":[],"mappings":"AAAA;EACE,aAAA;EACA,WAAA;EACA,YAAA;ACCF;;ADEA;EACE,mBAAA;EACA,sBAAA;EACA,YAAA;EACA,cAAA;EACA,aAAA;EACA,YAAA;ACCF;ADCE;EACE,eAAA;EACA,aAAA;EACA,mBAAA;ACCJ;ADCI;EACE,SAAA;EACA,gBAAA;ACCN;;ADIA;EACE,YAAA;EACA,yBAAA;ACDF;;ADIA;EACE,6BAAA;ACDF;;ADIA;EACE;IACE,aAAA;ECDF;AACF;ADqBA;EACE,gBAAA;EACA,SAAA;ACnBF;;ADsBA;EACE,kBAAA;ACnBF;;ADsBA;EACE,aAAA;EACA,sBAAA;ACnBF;ADqBE;EACE,sBAAA;EACA,YAAA;EACA,YAAA;EACA,cAAA;EACA,cAAA;EACA,eAAA;ACnBJ;ADsBE;EACE,sBAAA;EACA,oBAAA;EACA,sBAAA;EACA,YAAA;EACA,YAAA;EACA,cAAA;ACpBJ;ADsBI;EACE,sBAAA;EACA,oBAAA;EACA,mBAAA;EACA,YAAA;EACA,cAAA;EACA,gBAAA;EACA,mBAAA;EACA,mBAAA;EACA,WAAA;ACpBN;ADwBE;EA1DA,mBAAA;EACA,uBAAA;EACA,kBAAA;EACA,QAAA;EACA,UAAA;EACA,yBAAA;EACA,cAAA;EACA,mBAAA;EACA,eAAA;EACA,WAAA;EACA,YAAA;EACA,eAAA;EACA,YAAA;EAgDE,aAAA;ACVJ;;ADeA;EACE;IACE,mBAAA;ECZF;;EDcA;IACE,cAAA;IACA,kBAAA;ECXF;EDaE;IACE,kBAAA;IACA,cAAA;IACA,MAAA;IACA,OAAA;IACA,WAAA;IACA,eAAA;IACA,WAAA;ECXJ;EDcE;IACE,aAAA;ECZJ;EDeE;IACE,aAAA;IACA,kBAAA;IACA,MAAA;IACA,OAAA;IACA,WAAA;IACA,eAAA;IACA,YAAA;IACA,YAAA;ECbJ;EDeI;IACE,mBAAA;ECbN;AACF","file":"Features/Grouping/CompactMode/angular/styles.css","sourcesContent":[".main-container {\n  display: flex;\n  width: 100%;\n  height: 100%;\n}\n\n.sample-options {\n  background: #fbfbfb;\n  box-sizing: border-box;\n  height: 100%;\n  overflow: auto;\n  padding: 10px;\n  width: 210px;\n\n  .option-row {\n    margin-top: 5px;\n    display: flex;\n    align-items: center;\n\n    label {\n      margin: 0;\n      margin-left: 5px;\n    }\n  }\n}\n\n.grid {\n  height: 100%;\n  width: calc(100% - 210px);\n}\n\n.gc-group-footer-cell {\n  background-color: transparent;\n}\n\n@media only screen and (max-width: 768px) {\n  .sample-options {\n    display: none;\n  }\n}\n\n// helpers for responsive options panel\n@mixin mobile-btn() {\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: 5px;\n  right: 5px;\n  background-color: #ebebeb;\n  color: #47a06c;\n  border-radius: 16px;\n  cursor: pointer;\n  width: 36px;\n  height: 36px;\n  font-size: 28px;\n  z-index: 101;\n}\n\n.flex-break {\n  flex-basis: 100%;\n  height: 0;\n}\n\n.mobile-only {\n  visibility: hidden;\n}\n\n.responsive-container {\n  display: flex;\n  box-sizing: border-box;\n\n  .main-content {\n    box-sizing: border-box;\n    height: 100%;\n    flex-grow: 1;\n    flex-shrink: 1;\n    min-width: 50%;\n    max-width: 100%;\n  }\n\n  .sample-options {\n    box-sizing: border-box;\n    display: inline-flex;\n    flex-direction: column;\n    height: 100%;\n    flex-grow: 0;\n    flex-shrink: 1;\n\n    .option-row {\n      box-sizing: border-box;\n      display: inline-flex;\n      align-items: center;\n      flex-grow: 0;\n      flex-shrink: 0;\n      flex-basis: auto;\n      white-space: nowrap;\n      padding-right: 10px;\n      width: auto;\n    }\n  }\n\n  .toggle-options {\n    @include mobile-btn;\n    display: none;\n  }\n}\n\n// most smartphones\n@media (min-width: 320px) and (max-width: 480px) and (orientation: portrait) {\n  .mobile-only {\n    visibility: visible;\n  }\n  .responsive-container {\n    display: block;\n    position: relative;\n\n    .main-content {\n      position: absolute;\n      display: block;\n      top: 0;\n      left: 0;\n      width: 100%;\n      max-width: 100%;\n      z-index: 99;\n    }\n\n    .toggle-options {\n      display: flex;\n    }\n\n    .sample-options {\n      display: none;\n      position: absolute;\n      top: 0;\n      left: 0;\n      width: 100%;\n      max-width: 100%;\n      height: 100%;\n      z-index: 100;\n\n      .option-row {\n        padding-right: 20px;\n      }\n    }\n  }\n}\n",".main-container {\n  display: flex;\n  width: 100%;\n  height: 100%;\n}\n\n.sample-options {\n  background: #fbfbfb;\n  box-sizing: border-box;\n  height: 100%;\n  overflow: auto;\n  padding: 10px;\n  width: 210px;\n}\n.sample-options .option-row {\n  margin-top: 5px;\n  display: flex;\n  align-items: center;\n}\n.sample-options .option-row label {\n  margin: 0;\n  margin-left: 5px;\n}\n\n.grid {\n  height: 100%;\n  width: calc(100% - 210px);\n}\n\n.gc-group-footer-cell {\n  background-color: transparent;\n}\n\n@media only screen and (max-width: 768px) {\n  .sample-options {\n    display: none;\n  }\n}\n.flex-break {\n  flex-basis: 100%;\n  height: 0;\n}\n\n.mobile-only {\n  visibility: hidden;\n}\n\n.responsive-container {\n  display: flex;\n  box-sizing: border-box;\n}\n.responsive-container .main-content {\n  box-sizing: border-box;\n  height: 100%;\n  flex-grow: 1;\n  flex-shrink: 1;\n  min-width: 50%;\n  max-width: 100%;\n}\n.responsive-container .sample-options {\n  box-sizing: border-box;\n  display: inline-flex;\n  flex-direction: column;\n  height: 100%;\n  flex-grow: 0;\n  flex-shrink: 1;\n}\n.responsive-container .sample-options .option-row {\n  box-sizing: border-box;\n  display: inline-flex;\n  align-items: center;\n  flex-grow: 0;\n  flex-shrink: 0;\n  flex-basis: auto;\n  white-space: nowrap;\n  padding-right: 10px;\n  width: auto;\n}\n.responsive-container .toggle-options {\n  align-items: center;\n  justify-content: center;\n  position: absolute;\n  top: 5px;\n  right: 5px;\n  background-color: #ebebeb;\n  color: #47a06c;\n  border-radius: 16px;\n  cursor: pointer;\n  width: 36px;\n  height: 36px;\n  font-size: 28px;\n  z-index: 101;\n  display: none;\n}\n\n@media (min-width: 320px) and (max-width: 480px) and (orientation: portrait) {\n  .mobile-only {\n    visibility: visible;\n  }\n\n  .responsive-container {\n    display: block;\n    position: relative;\n  }\n  .responsive-container .main-content {\n    position: absolute;\n    display: block;\n    top: 0;\n    left: 0;\n    width: 100%;\n    max-width: 100%;\n    z-index: 99;\n  }\n  .responsive-container .toggle-options {\n    display: flex;\n  }\n  .responsive-container .sample-options {\n    display: none;\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    max-width: 100%;\n    height: 100%;\n    z-index: 100;\n  }\n  .responsive-container .sample-options .option-row {\n    padding-right: 20px;\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.17'}),
'@grapecity/dataviews.core': dv({pkg:'@grapecity/dataviews.core',file:'gc.dataviews.core',version:'1.8.17'}),
'@grapecity/dataviews.grid': dv({pkg:'@grapecity/dataviews.grid',file:'gc.dataviews.grid',version:'1.8.17'}),
'@grapecity/dataviews.cardlayout': dv({pkg:'@grapecity/dataviews.cardlayout',file:'gc.dataviews.cardlayout',version:'1.8.17'}),
'@grapecity/dataviews.masonry': dv({pkg:'@grapecity/dataviews.masonry',file:'gc.dataviews.masonry',version:'1.8.17'}),
'@grapecity/dataviews.calendar': dv({pkg:'@grapecity/dataviews.calendar',file:'gc.dataviews.calendar',version:'1.8.17'}),
'@grapecity/dataviews.timeline': dv({pkg:'@grapecity/dataviews.timeline',file:'gc.dataviews.timeline',version:'1.8.17'}),
'@grapecity/dataviews.trellis': dv({pkg:'@grapecity/dataviews.trellis',file:'gc.dataviews.trellis',version:'1.8.17'}),
'@grapecity/dataviews.gantt': dv({pkg:'@grapecity/dataviews.gantt',file:'gc.dataviews.gantt',version:'1.8.17'}),
'@grapecity/dataviews.searchbox': dv({pkg:'@grapecity/dataviews.searchbox',file:'gc.dataviews.searchbox',version:'1.8.17'}),
'@grapecity/dataviews.react': dv({pkg:'@grapecity/dataviews.react',file:'gc.dataviews.react',version:'1.8.17'}),
'@grapecity/dataviews.vue': dv({pkg:'@grapecity/dataviews.vue',file:'gc.dataviews.vue',version:'1.8.17'}),
'@grapecity/dataviews.angular': dv({pkg:'@grapecity/dataviews.angular',file:'gc.dataviews.angular',version:'1.8.17'}),
'@grapecity/dataviews.csvexport': dv({pkg:'@grapecity/dataviews.angular',file:'gc.dataviews.csvexport',version:'1.8.17'}),
// 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.12'}),
'vue-router': npm({pkg:'vue-router',file:'dist/vue-router.js',version:'3.4.3'}),
'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:'4.0.2'}),
'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);