Trellis Board

This demo shows how to use TrellisGrouping to simulate a technical support scrum whiteboard.

This demo shows how to use TrellisGrouping to simulate a technical support scrum whiteboard. Try adding groups using the included menu, or edit items in those groups.
<!DOCTYPE html> <html lang="en"> <head> <base href="/dataviewsjs/demos/en/sample/Showcase/TrellisBoard/purejs/" /> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="keywords" content="trello, trellis" /> <meta name="description" content="This demo shows how to use TrellisGrouping to simulate a technical support scrum whiteboard." /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Trellis Board | 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/node_modules/ispin/dist/ispin.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="/dataviewsjs/demos/static/dataviews/gc.dataviews.trellis.min.css" rel="stylesheet" type="text/css" /> <link href="styles.css" rel="stylesheet" type="text/css" /> <!-- Google Tag Manager --> <script> (function (w, d, s, l, i) { w[l] = w[l] || []; w[l].push({ 'gtm.start': new Date().getTime(), event: 'gtm.js' }); var f = d.getElementsByTagName(s)[0], j = d.createElement(s), dl = l != 'dataLayer' ? '&l=' + l : ''; j.async = true; j.src = 'https://www.googletagmanager.com/gtm.js?id=' + i + dl; f.parentNode.insertBefore(j, f); })(window, document, 'script', 'dataLayer', 'GTM-WT462SJ'); </script> <!-- End Google Tag Manager --> <script src="/dataviewsjs/demos/static/js/app-polyfills.min.js" type="text/javascript"></script> <script type="text/javascript"> window.process = { env: { NODE_ENV: 'production', USE_NPM: false, USE_CDN: false, SITE_ROOT: '/dataviewsjs/demos', FRAMEWORK: 'purejs', DVJS_LICENSE_KEY: 'GrapeCity-Internal-Use-Only,GrapeCity,E195393772372914#B0KV4Ny56Vr5Wb7w6buJWeGRWb4NXUnNXRlFWWXl6SoN5VzVkYslmQ95WTENkTllVQzd4QhpEejdDNJZlWOp6M7oERQNnWspkaaB5QMhnR7dmUkRnVJR4L5cHTKNkZZdDbRBzZIxmSSR6NrpVQaVUQrBlc6ImYysSd4UlUEZGbw2kMl9UOzQVMId6ZXtUN83CO5RzaZt4VY5kM5pkUGpUUUV7UExUeGpUdTV5dFJ4bPhTc8pGeXJHWrkzNlFzdUtWTr5UQDdVckdGbSVUWr2yMPNzctZVRxEEW9lEbsZHUKJnVaRXT5p6Z0tWMqJGVrtSTIZnaopGSWZXbVNjY0hzQB5We4dnUr3ER8MkI0IyUiwiIGZUNwEkN5MjI0ICSiwSM9ETO6czNygTM0IicfJye#4Xfd5nIZRVV9IiOiMkIsISM6ByUKN7dllmVhRXYEJiOi8kI1tlOiQmcQJCLiEDMzATOwAyMwgDMwIDMyIiOiQncDJCLiI7au26YukHdpNWZwFmcn9iKsAnau26YukHdpNWZwFmcn9iKs86Yu46bj9Se4l6YlBXYydmLqwSbvNmL6VGZ9RXajVGchJ7ZuoCLt36YukHdpNWZwFmcn9iKiojIz5GRiwiI9RXaDVGchJ7RiojIh94QiwSZ5JHd0ICb6VkIsICNxkjM7MjM7czM9MTN9EjI0ICZJJye0ICRiwiI34zZN3yZGNlUnJDe5wkQPVlcBh7SppmUNBlU9dWS7J4ZMRES4MTZkRXTxM7Uq5GeQdHcyFHVup6dQd6ZDpEVrNDSh9kbNdzZrl4dwdPQ', SJS_LICENSE_KEY: '*.grapecity.com,E613631884219496#B0qRgJHWSJ7NyBlc8BjNMRHW7g7YldTZXFTQuFnW4hVOCplVSlVV09ERlhEZuVTVKlTazE4Q6VGSw2CdWZUWSVmbjVXbrxmWFVWR8ZzQro7U84WMGdlbuVHb73kS5kjUTN4NvFVdLdXWVR4Nox6Z7UUSysEcXJEMsN6bDN4TxMDVwVmWBRzKxhkTzAXTaJmdD3CRFJTd8R4R6M5RklWa6oUaLlXMwR4R8ZUdtRWVxUUaQh6VXNDdEhlZ7FHR6QXTPJTVvkWcyZnbSdHRtZHcYF6TKN4axYGcZNjTDF7TvFTTr24VqZjVHVjcLd7QkRmdNxkI0IyUiwiI5gDOEF4QGVjI0ICSiwiMzkTO9kTOyMTM0IicfJye35XX3JSSGljQiojIDJCLiITMuYHITpEIkFWZyB7UiojIOJyebpjIkJHUiwiI4MDMyEDMgkDM8ATOxAjMiojI4J7QiwiIt36YukHdpNWZwFmcn9iKiojIz5GRiwiIj9WagkHdpNUZwFmcHJiOiEmTDJCLlVnc4pjIsZXRiwiI6kDN9EjM4gDOxMjNzEjNiojIklkIs4XZzxWYmpjIyNHZisnOiwmbBJye0ICRiwiI34TQ72kNBV6YXpXdGxGWxdHcol4MyUGUHJVbQVHRx44Sw84YxRkS4QnZadDNmhWWxV5QxFlTlZEbBJ5N8gUNQlDb7J6Kl36YHVnb4NGN92UMFdlNORFU8VDSaFlQSVlS4EHTrA5Ohh', }, }; </script> <script src="/dataviewsjs/demos/node_modules/jquery/dist/jquery.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/imask/dist/imask.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/ispin/dist/ispin.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.common.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.core.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.grid.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.trellis.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/js/license.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/systemjs/dist/system.js" type="text/javascript"></script> <script src="systemjs.config.js" type="text/javascript"></script> </head> <body class="theme-default"> <!-- Google Tag Manager (noscript) --> <noscript ><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-WT462SJ" height="0" width="0" style="display: none; visibility: hidden;" ></iframe ></noscript> <!-- End Google Tag Manager (noscript) --> <noscript>You need to enable JavaScript to run this app.</noscript> <template id="trellis-card" style="display: none;"> <div class="card-container"> <div class="card-title-icon"> <span class="title-icon card-edit fa fa-edit" title="Edit card"></span> <span class="title-icon card-remove fa fa-trash-alt" title="Remove card"></span> </div> {{? it.priority}} <div class="card-label" data-column="priority"></div> {{?}} <div class="card-content card-description" data-column="description"></div> {{? it.image}} <div class="card-image" data-column="image"></div> {{?}} {{? it.evaluation}} <div class="card-evaluation" data-column="evaluation"></div> {{?}} </div> </template> <div class="main-container"> <div class="wrapper"> <div class="board-header"> <span class="title">Hornet scrum whiteboard</span> <a class="pull-right" onclick="showMenuPanel();">Show Menu</a> </div> <div class="board-content"> <div class="grid-container"> <div id="grid"></div> </div> <div id="trellis-menu" class="trellis-menu"> <div class="trellis-menu-header"> <span class="header-title">Menu</span> <span class="fa fa-times pull-right" onclick="showMenuPanel();"></span> </div> <div class="trellis-menu-body"> <div class="trellis-menu-group-label">Add Group</div> <div id="add-group-container" class="add-group-container"> <input class="trellis-addGroupInput" placeholder="Input Group Name..." /> <button type="button" class="btn btn-default trellis-editBtn" onclick="addNewGroup();">Add</button> </div> <div class="activities-container"> <div class="split-line"></div> <div class="trellis-menu-group-label">Activity</div> <div class="trellis-menu-activities"></div> </div> </div> </div> </div> </div> </div> <script type="text/javascript"> System.import('./app.js'); </script> </body> </html>
import { GridLayout } from '@grapecity/dataviews.grid'; import TrellisGrouping from '@grapecity/dataviews.trellis'; import { getPanelWidth } from './utils'; import { appClickHandler, handleMoveCard } from './handlers'; const colors = ['#00D8FF', '#74ACC8', '#808080', '#F5A623', '#D0021B']; window.colors = colors; const priorityPresenter = '<div style="display: inline-block;background: {{=colors[it.priority/100 -1]}}; width:100%;height:3px;margin:3px 3px 3px 0;"></div>'; const imagePresenter = '<div style="padding:8px; height:auto"><img style="width:100%;" src={{=it.image}} /></div>'; const evaluationPresenter = '<div style="padding-bottom: 5px"><span title="Evaluation" style="background: {{=colors[it.priority/100 -1]}};">{{=it.evaluation}}</span></div>'; const cols = [ { id: 'image', dataField: 'image', presenter: imagePresenter }, { id: 'priority', dataField: 'priority', presenter: priorityPresenter }, { id: 'description', dataField: 'description' }, { id: 'evaluation', dataField: 'evaluation', presenter: evaluationPresenter }, ]; const trellisGrouping = new TrellisGrouping({ panelUnitWidth: getPanelWidth(), }); const layout = new GridLayout({ grouping: [ { field: 'category', header: { height: 35, template: `<div class="trellis-card-header"> <span>{{=it.name}}</span> <div class="group-header-options"> <span class="group-remove fa fa-trash-alt"></span> </div> </div>`, }, footer: { visible: true, height: 24, template: '<div class="trellis-card-add">Add a item...</div>', }, preDefinedGroups: ['STORIES', 'TO DO/ISSUES', 'PROCESSING', 'DONE'], }, ], rowTemplate: '#trellis-card', groupStrategy: trellisGrouping, autoRowHeight: true, }); let dataView; $(() => { $.getJSON('data.json', function (data) { data.forEach((record) => { if (record.image) { record.image = window.process.env.SITE_ROOT + record.image; } }); dataView = new GC.DataViews.DataView(document.getElementById('grid'), data, cols, layout); }); }); trellisGrouping.dragDropping.addHandler(handleMoveCard); document.addEventListener('click', appClickHandler); window.addEventListener('resize', () => { if (dataView) { trellisGrouping.options.panelUnitWidth = getPanelWidth(); dataView.invalidate(); } }); window.showMenuPanel = function showMenuPanel() { $('#trellis-menu').toggleClass('hide'); };
[ { "category": "TO DO/ISSUES", "priority": 500, "evaluation": 1.5, "description": "Facebook demo can't scroll well.", "image": "/images/t_facebook.png" }, { "category": "TO DO/ISSUES", "priority": 100, "evaluation": 0.5, "description": "Format is not correct in new version." }, { "category": "TO DO/ISSUES", "priority": 200, "evaluation": 0.25, "description": "There is no response when clicking the group header.", "image": "/images/t_groupHeader.png" }, { "category": "TO DO/ISSUES", "priority": 400, "evaluation": 2, "description": "Horizontal layout engine layout is incorrect when ending editing.", "image": "/images/t_horizontal.png" }, { "category": "TO DO/ISSUES", "priority": 400, "evaluation": 3, "description": "SearchBox can't work in IE or FireFox.", "image": "/images/t_searchbox.png" }, { "category": "PROCESSING", "priority": 400, "evaluation": 2.5, "description": "The font style is different. We need to make it unified.", "image": "/images/t_font.jpg" }, { "category": "PROCESSING", "priority": 300, "evaluation": 1, "description": "The tool panel don't support mousewheel event." }, { "category": "PROCESSING", "priority": 300, "evaluation": 3, "description": "There is no drag drop indicator when dragging the column header in the Horizontal Layout Engine." }, { "category": "PROCESSING", "priority": 300, "evaluation": 1, "description": "The button style is different.", "image": "/images/t_buttons.jpg" }, { "category": "PROCESSING", "priority": 400, "evaluation": 3, "description": "The items in the drop down list in SearchBox should be customizable.", "image": "/images/t_dropdown.png" }, { "category": "DONE", "priority": 200, "evaluation": 3, "description": "The chat row template demo can't load data normally.", "image": "/images/t_chat.png" }, { "category": "DONE", "priority": 500, "evaluation": 3, "description": "If the group header is selected, the whole group items should be selected." }, { "category": "DONE", "priority": 500, "evaluation": 3, "description": "If the tree header is selected, its children should not be selected.", "image": "/images/t_select.png" }, { "category": "DONE", "priority": 200, "evaluation": 3, "description": "The layout goes wrong when resizing with row template." }, { "category": "DONE", "priority": 200, "evaluation": 3, "description": "The inline edit can't commit values when clicking another row." }, { "category": "STORIES", "priority": 400, "evaluation": 1, "description": "Group footer should not be selected." }, { "category": "STORIES", "priority": 400, "evaluation": 2, "description": "Group header and footer should support template." }, { "category": "STORIES", "priority": 500, "evaluation": 3, "description": "Hierarchical footer should not be selected." }, { "category": "STORIES", "priority": 400, "evaluation": 2, "description": "Select an item in SearchBox, and then press delete, the item should be deleted." }, { "category": "STORIES", "priority": 400, "evaluation": 1, "description": "The sort icon should be placed in front of the column header caption." } ]
import { createElement, getGroupInfo, encodeValue, getDataView } from './utils'; import { pushActivity } from './log'; const dialogId = 'card-edit-dialog'; export function openEditDialog(hitTestInfo) { const overlay = createElement('<div class="popup-overlay"></div>'); document.body.appendChild(overlay); const row = hitTestInfo.groupInfo.row; const groupInfo = getGroupInfo(hitTestInfo.groupInfo.path); const record = row >= 0 ? groupInfo.getItem(row) : { description: '', category: groupInfo.name, priority: 100, evaluation: 0.25, }; const priority = record.priority; const description = record.description || ''; const evaluation = !isNaN(record.evaluation) ? record.evaluation : ''; const palette = [ { priority: 'lowest', color: '#00D8FF', weight: 100 }, { priority: 'low', color: '#74ACC8', weight: 200 }, { priority: 'medium', color: '#808080', weight: 300 }, { priority: 'high', color: '#F5A623', weight: 400 }, { priority: 'highest', color: '#D0021B', weight: 500 }, ]; const colorPicker = palette.map((it) => { const checked = priority && priority === 100 * (1 + colors.indexOf(it.color)) ? ' checked' : ''; const className = `color-picker-item${checked}`; const style = `background-color:${it.color}`; return `<div title="${it.priority}" data-color="${it.color}" style="${style}" class="${className}">${it.weight}</div>`; }); const html = `<div id="${dialogId}" class="edit-dialog" style="position: absolute;"> <div class="flex0"> <div class="text-label">Priority</div> <div class="color-picker-group">${colorPicker.join('')}</div> </div> <div class="description-editor flex1"> <div class="text-label">Description</div> <textarea placeholder="Here is Description...">${description}</textarea> </div> <div class="evaluation-picker flex0"> <div class="text-label">Workloads</div> <div> <input class="workInput" type="text" min="0.25" max="40" step="0.25" placeholder="Here is Evaluation..." value="${evaluation}" /> </div> </div> <div class="modify-card-footer flex0"> <button type="button" class="btn btn-default cancel-button">Cancel</button> <button type="button" class="btn btn-default ok-button">OK</button> </div> </div>`; const dialog = createElement(html); document.body.appendChild(dialog); const rect = dialog.getBoundingClientRect(); const windowWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth; const left = parseInt((windowWidth - rect.width) / 2 + window.pageXOffset, 10); dialog.style.left = left + 'px'; dialog.style.top = '10px'; dialog.style.bottom = '10px'; dialog.querySelector('textarea').focus(); const close = () => { $(`#${dialogId} *`).off(); dialog.parentNode.removeChild(dialog); overlay.removeEventListener('click', close); overlay.parentNode.removeChild(overlay); }; const submit = () => { const pickedColor = dialog.querySelector('.color-picker-item.checked'); const color = pickedColor && pickedColor.getAttribute('data-color'); const description = dialog.querySelector('.description-editor textarea'); const evaluation = dialog.querySelector('.evaluation-picker input'); close(); const oldData = _.clone(record); const round = (value) => Math.round(value * 4) / 4; _.assign(record, { priority: 100 * (colors.indexOf(color) + 1), description: encodeValue(description.value), evaluation: round(parseFloat(evaluation.value)), }); const dataView = getDataView(); if (row >= 0) { dataView.invalidate(); pushActivity({ action: 'editCard', oldValue: oldData, value: record, }); } else { dataView.data.insertDataItems(record); pushActivity({ action: 'addCard', value: record.description, group: groupInfo.name, }); } }; overlay.addEventListener('click', close); $(`#${dialogId} .color-picker-item`) .off() .click(function () { if (!$(this).hasClass('checked')) { $(`#${dialogId} .color-picker-item`).removeClass('checked'); $(this).addClass('checked'); } }); const okBtn = $(`#${dialogId} .ok-button`); okBtn.off().click(submit); $(`#${dialogId} .cancel-button`).off().click(close); workInput($(`#${dialogId} .workInput`).off()); } function workInput(el) { const opts = { mask: Number, radix: '.', min: parseFloat(el.attr('min')), max: parseFloat(el.attr('max')), }; const mask = IMask(el[0], opts); el.change(function () { mask.updateValue(el.val()); }); // emulate number input new ISpin(el[0], { step: parseFloat(el.attr('step')), min: opts.min, max: opts.max, }); }
import _ from 'lodash'; import { getDataView, getPanelWidth, getGroupInfo } from './utils'; import { pushActivity } from './log'; import { openEditDialog } from './edit'; export function addNewGroup() { const nameInput = document.getElementById('add-group-container').querySelector('input'); const name = (nameInput.value || '').toUpperCase(); if (!name) { return; } nameInput.value = ''; const dataView = getDataView(); const groups = dataView.data.groups; const existingGroup = _.find(groups, (g) => g.name === name); if (existingGroup) { return; } let descriptors = dataView.data.groupDescriptors; if (descriptors.length) { const grouping = _.cloneDeep(descriptors[0]); grouping.preDefinedGroups = [...grouping.preDefinedGroups, name]; descriptors = [grouping]; } const trellisGrouping = dataView.options.groupStrategy; trellisGrouping.options.panelUnitWidth = getPanelWidth(); dataView.data.groupDescriptors = descriptors; pushActivity({ action: 'addGroup', group: name, }); dataView.invalidate(); } export function removeGroup(hitTestInfo) { const dataView = getDataView(); var len = dataView.data.groups.length; if (len <= 1) { return; } const path = hitTestInfo.groupInfo.path; const groupInfo = getGroupInfo(path); const groupDescriptors = dataView.data.groupDescriptors; _.remove(groupDescriptors[0].preDefinedGroups, function (value) { return value === groupInfo.name; }); dataView.data.suspendRefresh(); dataView.data.groupDescriptors = groupDescriptors; var indexes = _.map(groupInfo.getItems(), 'sourceIndex'); indexes = indexes.sort(function (a, b) { return b - a; }); _.each(indexes, function (index) { dataView.data.removeDataItems(index); }); dataView.data.resumeRefresh(); dataView.data.removeEmptyGroup(); const trellisGrouping = dataView.options.groupStrategy; trellisGrouping.options.panelUnitWidth = getPanelWidth(); dataView.invalidate(); pushActivity({ action: 'removeGroup', group: groupInfo.name, }); } let oldHitInfo; export function handleMoveCard(args) { if (args.status === 'beforeDragging') { oldHitInfo = args.hitInfo; } if (args.status === 'beforeDropping') { const oldGroup = oldHitInfo.groupInfo; if (args.hitInfo && args.hitInfo.groupInfo) { const newGroup = args.hitInfo.groupInfo; if (!_.isEqual(newGroup.path, oldGroup.path) || newGroup.row !== oldGroup.row) { pushActivity({ action: 'movingCard', newGroup: getGroupInfo(newGroup.path).name, oldGroup: getGroupInfo(oldGroup.path).name, }); } } } } export function removeCard(hitTestInfo) { const dataView = getDataView(); const row = hitTestInfo.groupInfo.row; const groupInfo = getGroupInfo(hitTestInfo.groupInfo.path); const item = groupInfo.getItems()[row]; dataView.data.removeDataItems(item.sourceIndex); pushActivity({ action: 'removeCard', group: groupInfo.name, value: item.description, }); } // for purejs demo window.addNewGroup = addNewGroup; export function appClickHandler(event) { const dataView = getDataView(); const hitTestInfo = dataView.hitTest(event); let target = event.target; while (target) { if ($(target).hasClass('gc-row') && hitTestInfo.groupInfo.area === 'groupContent') { openEditDialog(hitTestInfo); break; } else if ($(target).hasClass('trellis-card-add')) { openEditDialog(hitTestInfo); break; } else if ($(target).hasClass('card-remove')) { removeCard(hitTestInfo); break; } else if ($(target).hasClass('card-edit')) { openEditDialog(hitTestInfo); break; } else if ($(target).hasClass('group-remove')) { removeGroup(hitTestInfo); break; } else { target = target.parentNode; } } }
import { createElement } from './utils'; function renderContent(activity) { switch (activity.action) { case 'addCard': return `<span>Add card ${activity.value} to group ${activity.group}</span>`; case 'removeCard': return `<span>Remove card ${activity.value} from group ${activity.group}</span>`; case 'editCard': { const oldValue = activity.oldValue; const value = activity.value; const header = `<span>Edit card <i>${oldValue.description}</i>:<br /></span>`; const fields = ['priority', 'description', 'evaluation']; const content = fields .map((field) => { if (oldValue[field] === value[field]) { return undefined; } if (field === 'description') { return `<span>change description to "${value.description}"<br /></span>`; } return `<span>change ${field} from ${oldValue[field]} to ${value[field]}<br /></span>`; }) .filter((s) => !!s); return header + content.join(''); } case 'movingCard': return `<span>Move item from group ${activity.oldGroup} to group ${activity.newGroup}</span>`; case 'addGroup': return `<span><b>Add group </b>${activity.group}</span>`; case 'removeGroup': return `<span><b>Remove group </b>${activity.group}</span>`; default: return ''; } } export function pushActivity(activity) { const content = renderContent(activity); const container = document.querySelector('#trellis-menu .trellis-menu-activities'); const children = container.children; if (children.length) { const element = createElement(`<div>${content}<div class="split-line"></div><div>`); container.insertBefore(element, children[0]); } else { const element = createElement(`<div>${content}<div>`); container.appendChild(element); } }
.main-container { overflow: hidden; height: 100%; } .wrapper { position: relative; height: 100%; } .grid-container { height: 100%; } .grid-container #grid { height: 100%; } .board-header { padding: 6px 12px; background: #0b3954; height: 32px; } .board-header a { color: white; font-size: 15px; font-weight: bold; } .board-header .title { color: #fff; } .board-content { height: calc(100% - 32px); } .gc-grid { border: none; font-family: inherit; } .gc-cell { padding: 0; margin: 2px; } .trellis-grouping .gc-trellis-group-header { text-align: left; padding: 6px 12px; font-size: 20px; font-weight: 300; color: black; font-family: inherit; } .trellis-grouping .gc-trellis-viewport { background: white; } .trellis-grouping .gc-trellis-row { background: transparent; padding: 6px 12px; } .trellis-grouping .gc-trellis-group-header, .trellis-grouping .gc-trellis-group-content { background: none; } .trellis-grouping .gc-trellis-group-footer { background: none; padding: 6px 12px; } .gc-trellis-group-footer:hover { cursor: pointer; color: #000; } .gc-cell { white-space: normal; } .card-container { border: 1px solid #e0e0e0; background: white; position: relative; border-radius: 4px; border-bottom-width: 3px; padding: 0.4em; } .gc-trellis-row:hover .card-container { background: #f1f1f1; } .gc-trellis-row:hover .card-title-icon { display: inline-block; } .card-label { font-size: 0; } .card-title-icon { position: absolute; right: 12px; top: 6px; display: none; background: #0b3954; border-radius: 4px; } .card-title-icon .title-icon { display: inline-block; width: 11px; height: 13px; margin: 3px; color: #fff; } .card-title-icon .title-icon:hover { cursor: pointer; opacity: 1; } .card-evaluation span { display: inline-block; padding: 0 5px; min-width: 30px; line-height: 30px; border-radius: 50%; background: lightgrey; text-align: center; color: white; font-weight: 600; } .group-header-options { font-size: 16px; } .group-header-options span { opacity: 0.5; } .group-header-options span:hover { cursor: pointer; opacity: 1; } .hide { display: none !important; } .edit-dialog { display: flex; flex-direction: column; background: white; width: 300px; padding: 10px; border-radius: 4px; z-index: 11111; } .edit-dialog .flex0 { flex-shrink: 0; flex-grow: 0; } .edit-dialog .flex1 { flex-shrink: 1; flex-grow: 1; } .edit-dialog .color-picker-group { height: 35px; } .edit-dialog .color-picker-group .color-picker-item { display: inline-block; width: 54px; line-height: 35px; height: 100%; position: relative; color: white; text-align: center; cursor: pointer; } .edit-dialog .color-picker-group .color-picker-item.checked:after { content: ""; background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAAAOCAYAAAAfSC3RAAAAn0lEQVQoU53SYQ3DIBCG4fcUbBIqYRYmYQqWOaiTTkKdrBIqZQ6+5Qg0hbK2gV9A8uTu4zAalzU6TkNJV6Azs9mLnYIRfYAb8DKz8RAWKCQzXymjpB6YUit+X0NZRUkj8AS+wN3xHloySnJwidV9/wCGmCk1FbKlQ2hVkoeeVricUoayV93BG7QZRwVXUXWOEXuW9zpT2fvhHP99yWb4A7pfPQ9SebFhAAAAAElFTkSuQmCC"); position: absolute; right: 0px; top: 3px; height: 15px; width: 15px; } .edit-dialog .description-editor { margin-top: 5px; } .edit-dialog .description-editor textarea { width: 100%; height: 130px; resize: none; border: 2px inset #eee; } .edit-dialog .modify-card-footer { height: 40px; margin-top: 10px; } .text-label { height: 25px; line-height: 25px; font-size: 15px; font-weight: bold; } .popup-overlay { position: fixed; width: 100%; height: 100%; left: 0; top: 0; background: rgba(0, 0, 0, 0.6); } .trellis-menu { width: 270px; height: 100%; position: absolute; right: 0; top: 0; background: #f5f5f5; overflow: hidden; display: flex; flex-direction: column; } .trellis-menu-header { padding: 6px 12px; background: #e0e0e0; flex: 0 0 auto; } .split-line { border-top: 1px solid lightgrey; height: 1px; margin-top: 8px; margin-bottom: 8px; flex: 0 0 auto; } .trellis-menu-group-label { font-size: 15px; margin-bottom: 5px; font-weight: bold; flex: 0 0 auto; } .btn { border-radius: 0px; width: 70px; font-weight: bold; } .cancel-button, .ok-button { float: right; margin-left: 10px; } .trellis-addGroupInput { width: 100%; padding: 6px 12px; margin-bottom: 0.4em; } .menu-setting-option { padding: 5px; } .menu-setting-option:hover { cursor: pointer; background: lightgrey; } .add-group-container { overflow: hidden; flex: 0 0 auto; } log, .activities-container { display: flex; flex-direction: column; flex: 1; } .trellis-menu-body { position: relative; padding: 6px 12px; flex: 1; display: flex; flex-direction: column; } .trellis-menu-activities { height: 400px; overflow: auto; flex: 1; } .trellis-card-header { display: flex; align-items: center; justify-content: space-between; height: 35px; width: 100%; } .trellis-card-header > span:first-child { display: block; width: 100%; flex-grow: 1; flex-shrink: 1; overflow: hidden; text-overflow: ellipsis; text-align: center; } .pull-right { margin-top: 3px; cursor: pointer; } /*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["Showcase/TrellisBoard/purejs/styles.scss","Showcase/TrellisBoard/purejs/styles.css"],"names":[],"mappings":"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","file":"Showcase/TrellisBoard/purejs/styles.css","sourcesContent":[".main-container {\n  overflow: hidden;\n  height: 100%;\n}\n\n.wrapper {\n  position: relative;\n  height: 100%;\n}\n\n.grid-container {\n  height: 100%;\n\n  #grid {\n    height: 100%;\n  }\n}\n\n.board-header {\n  padding: 6px 12px;\n  background: #0b3954;\n  height: 32px;\n\n  a {\n    color: white;\n    font-size: 15px;\n    font-weight: bold;\n  }\n}\n\n.board-header .title {\n  color: #fff;\n}\n\n.board-content {\n  height: calc(100% - 32px);\n}\n\n.gc-grid {\n  border: none;\n  font-family: inherit;\n}\n\n.gc-cell {\n  padding: 0;\n  margin: 2px;\n}\n\n.trellis-grouping .gc-trellis-group-header {\n  text-align: left;\n  padding: 6px 12px;\n  font-size: 20px;\n  font-weight: 300;\n  color: black;\n  font-family: inherit;\n}\n\n.trellis-grouping .gc-trellis-viewport {\n  background: white;\n}\n\n.trellis-grouping .gc-trellis-row {\n  background: transparent;\n  padding: 6px 12px;\n}\n\n.trellis-grouping .gc-trellis-group-header,\n.trellis-grouping .gc-trellis-group-content {\n  background: none;\n}\n\n.trellis-grouping .gc-trellis-group-footer {\n  background: none;\n  padding: 6px 12px;\n}\n\n.gc-trellis-group-footer:hover {\n  cursor: pointer;\n  color: #000;\n}\n\n.gc-cell {\n  white-space: normal;\n}\n\n.card-container {\n  border: 1px solid #e0e0e0;\n  background: white;\n  position: relative;\n  border-radius: 4px;\n  border-bottom-width: 3px;\n  padding: 0.4em;\n}\n\n.gc-trellis-row:hover .card-container {\n  background: #f1f1f1;\n}\n\n.gc-trellis-row:hover .card-title-icon {\n  display: inline-block;\n}\n\n.card-label {\n  font-size: 0;\n}\n\n.card-title-icon {\n  position: absolute;\n  right: 12px;\n  top: 6px;\n  display: none;\n  background: #0b3954;\n  border-radius: 4px;\n}\n\n.card-title-icon .title-icon {\n  display: inline-block;\n  width: 11px;\n  height: 13px;\n  margin: 3px;\n  color: #fff;\n}\n\n.card-title-icon .title-icon:hover {\n  cursor: pointer;\n  opacity: 1;\n}\n\n.card-evaluation span {\n  display: inline-block;\n  padding: 0 5px;\n  min-width: 30px;\n  line-height: 30px;\n  border-radius: 50%;\n  background: lightgrey;\n  text-align: center;\n  color: white;\n  font-weight: 600;\n}\n\n.group-header-options {\n  font-size: 16px;\n}\n\n.group-header-options span {\n  opacity: 0.5;\n}\n\n.group-header-options span:hover {\n  cursor: pointer;\n  opacity: 1;\n}\n\n.hide {\n  display: none !important;\n}\n\n.edit-dialog {\n  display: flex;\n  flex-direction: column;\n  background: white;\n  width: 300px;\n  padding: 10px;\n  border-radius: 4px;\n  z-index: 11111;\n\n  .flex0 {\n    flex-shrink: 0;\n    flex-grow: 0;\n  }\n\n  .flex1 {\n    flex-shrink: 1;\n    flex-grow: 1;\n  }\n\n  .color-picker-group {\n    height: 35px;\n\n    .color-picker-item {\n      display: inline-block;\n      width: 54px;\n      line-height: 35px;\n      height: 100%;\n      position: relative;\n      color: white;\n      text-align: center;\n      cursor: pointer;\n\n      &.checked:after {\n        content: '';\n        background: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAAAOCAYAAAAfSC3RAAAAn0lEQVQoU53SYQ3DIBCG4fcUbBIqYRYmYQqWOaiTTkKdrBIqZQ6+5Qg0hbK2gV9A8uTu4zAalzU6TkNJV6Azs9mLnYIRfYAb8DKz8RAWKCQzXymjpB6YUit+X0NZRUkj8AS+wN3xHloySnJwidV9/wCGmCk1FbKlQ2hVkoeeVricUoayV93BG7QZRwVXUXWOEXuW9zpT2fvhHP99yWb4A7pfPQ9SebFhAAAAAElFTkSuQmCC');\n        position: absolute;\n        right: 0px;\n        top: 3px;\n        height: 15px;\n        width: 15px;\n      }\n    }\n  }\n\n  .description-editor {\n    margin-top: 5px;\n\n    textarea {\n      width: 100%;\n      height: 130px;\n      resize: none;\n      border: 2px inset #eee;\n    }\n  }\n\n  .modify-card-footer {\n    height: 40px;\n    margin-top: 10px;\n  }\n}\n\n.text-label {\n  height: 25px;\n  line-height: 25px;\n  font-size: 15px;\n  font-weight: bold;\n}\n\n.popup-overlay {\n  position: fixed;\n  width: 100%;\n  height: 100%;\n  left: 0;\n  top: 0;\n  background: rgba(0, 0, 0, 0.6);\n}\n\n.trellis-menu {\n  width: 270px;\n  height: 100%;\n  position: absolute;\n  right: 0;\n  top: 0;\n  background: #f5f5f5;\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n}\n\n.trellis-menu-header {\n  padding: 6px 12px;\n  background: #e0e0e0;\n  flex: 0 0 auto;\n}\n\n.split-line {\n  border-top: 1px solid lightgrey;\n  height: 1px;\n  margin-top: 8px;\n  margin-bottom: 8px;\n  flex: 0 0 auto;\n}\n\n.trellis-menu-group-label {\n  font-size: 15px;\n  margin-bottom: 5px;\n  font-weight: bold;\n  flex: 0 0 auto;\n}\n\n.btn {\n  border-radius: 0px;\n  width: 70px;\n  font-weight: bold;\n}\n\n.cancel-button,\n.ok-button {\n  float: right;\n  margin-left: 10px;\n}\n\n.trellis-addGroupInput {\n  width: 100%;\n  padding: 6px 12px;\n  margin-bottom: 0.4em;\n}\n\n.menu-setting-option {\n  padding: 5px;\n}\n\n.menu-setting-option:hover {\n  cursor: pointer;\n  background: lightgrey;\n}\n\n.add-group-container {\n  overflow: hidden;\n  flex: 0 0 auto;\n}\n\nlog,\n.activities-container {\n  display: flex;\n  flex-direction: column;\n  flex: 1;\n}\n\n.trellis-menu-body {\n  position: relative;\n  padding: 6px 12px;\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n}\n\n.trellis-menu-activities {\n  height: 400px;\n  overflow: auto;\n  flex: 1;\n}\n\n.trellis-card-header {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  height: 35px;\n  width: 100%;\n}\n\n.trellis-card-header > span:first-child {\n  display: block;\n  width: 100%;\n  flex-grow: 1;\n  flex-shrink: 1;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  text-align: center;\n}\n\n.pull-right {\n  margin-top: 3px;\n  cursor: pointer;\n}\n",".main-container {\n  overflow: hidden;\n  height: 100%;\n}\n\n.wrapper {\n  position: relative;\n  height: 100%;\n}\n\n.grid-container {\n  height: 100%;\n}\n.grid-container #grid {\n  height: 100%;\n}\n\n.board-header {\n  padding: 6px 12px;\n  background: #0b3954;\n  height: 32px;\n}\n.board-header a {\n  color: white;\n  font-size: 15px;\n  font-weight: bold;\n}\n\n.board-header .title {\n  color: #fff;\n}\n\n.board-content {\n  height: calc(100% - 32px);\n}\n\n.gc-grid {\n  border: none;\n  font-family: inherit;\n}\n\n.gc-cell {\n  padding: 0;\n  margin: 2px;\n}\n\n.trellis-grouping .gc-trellis-group-header {\n  text-align: left;\n  padding: 6px 12px;\n  font-size: 20px;\n  font-weight: 300;\n  color: black;\n  font-family: inherit;\n}\n\n.trellis-grouping .gc-trellis-viewport {\n  background: white;\n}\n\n.trellis-grouping .gc-trellis-row {\n  background: transparent;\n  padding: 6px 12px;\n}\n\n.trellis-grouping .gc-trellis-group-header,\n.trellis-grouping .gc-trellis-group-content {\n  background: none;\n}\n\n.trellis-grouping .gc-trellis-group-footer {\n  background: none;\n  padding: 6px 12px;\n}\n\n.gc-trellis-group-footer:hover {\n  cursor: pointer;\n  color: #000;\n}\n\n.gc-cell {\n  white-space: normal;\n}\n\n.card-container {\n  border: 1px solid #e0e0e0;\n  background: white;\n  position: relative;\n  border-radius: 4px;\n  border-bottom-width: 3px;\n  padding: 0.4em;\n}\n\n.gc-trellis-row:hover .card-container {\n  background: #f1f1f1;\n}\n\n.gc-trellis-row:hover .card-title-icon {\n  display: inline-block;\n}\n\n.card-label {\n  font-size: 0;\n}\n\n.card-title-icon {\n  position: absolute;\n  right: 12px;\n  top: 6px;\n  display: none;\n  background: #0b3954;\n  border-radius: 4px;\n}\n\n.card-title-icon .title-icon {\n  display: inline-block;\n  width: 11px;\n  height: 13px;\n  margin: 3px;\n  color: #fff;\n}\n\n.card-title-icon .title-icon:hover {\n  cursor: pointer;\n  opacity: 1;\n}\n\n.card-evaluation span {\n  display: inline-block;\n  padding: 0 5px;\n  min-width: 30px;\n  line-height: 30px;\n  border-radius: 50%;\n  background: lightgrey;\n  text-align: center;\n  color: white;\n  font-weight: 600;\n}\n\n.group-header-options {\n  font-size: 16px;\n}\n\n.group-header-options span {\n  opacity: 0.5;\n}\n\n.group-header-options span:hover {\n  cursor: pointer;\n  opacity: 1;\n}\n\n.hide {\n  display: none !important;\n}\n\n.edit-dialog {\n  display: flex;\n  flex-direction: column;\n  background: white;\n  width: 300px;\n  padding: 10px;\n  border-radius: 4px;\n  z-index: 11111;\n}\n.edit-dialog .flex0 {\n  flex-shrink: 0;\n  flex-grow: 0;\n}\n.edit-dialog .flex1 {\n  flex-shrink: 1;\n  flex-grow: 1;\n}\n.edit-dialog .color-picker-group {\n  height: 35px;\n}\n.edit-dialog .color-picker-group .color-picker-item {\n  display: inline-block;\n  width: 54px;\n  line-height: 35px;\n  height: 100%;\n  position: relative;\n  color: white;\n  text-align: center;\n  cursor: pointer;\n}\n.edit-dialog .color-picker-group .color-picker-item.checked:after {\n  content: \"\";\n  background: url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAAAOCAYAAAAfSC3RAAAAn0lEQVQoU53SYQ3DIBCG4fcUbBIqYRYmYQqWOaiTTkKdrBIqZQ6+5Qg0hbK2gV9A8uTu4zAalzU6TkNJV6Azs9mLnYIRfYAb8DKz8RAWKCQzXymjpB6YUit+X0NZRUkj8AS+wN3xHloySnJwidV9/wCGmCk1FbKlQ2hVkoeeVricUoayV93BG7QZRwVXUXWOEXuW9zpT2fvhHP99yWb4A7pfPQ9SebFhAAAAAElFTkSuQmCC\");\n  position: absolute;\n  right: 0px;\n  top: 3px;\n  height: 15px;\n  width: 15px;\n}\n.edit-dialog .description-editor {\n  margin-top: 5px;\n}\n.edit-dialog .description-editor textarea {\n  width: 100%;\n  height: 130px;\n  resize: none;\n  border: 2px inset #eee;\n}\n.edit-dialog .modify-card-footer {\n  height: 40px;\n  margin-top: 10px;\n}\n\n.text-label {\n  height: 25px;\n  line-height: 25px;\n  font-size: 15px;\n  font-weight: bold;\n}\n\n.popup-overlay {\n  position: fixed;\n  width: 100%;\n  height: 100%;\n  left: 0;\n  top: 0;\n  background: rgba(0, 0, 0, 0.6);\n}\n\n.trellis-menu {\n  width: 270px;\n  height: 100%;\n  position: absolute;\n  right: 0;\n  top: 0;\n  background: #f5f5f5;\n  overflow: hidden;\n  display: flex;\n  flex-direction: column;\n}\n\n.trellis-menu-header {\n  padding: 6px 12px;\n  background: #e0e0e0;\n  flex: 0 0 auto;\n}\n\n.split-line {\n  border-top: 1px solid lightgrey;\n  height: 1px;\n  margin-top: 8px;\n  margin-bottom: 8px;\n  flex: 0 0 auto;\n}\n\n.trellis-menu-group-label {\n  font-size: 15px;\n  margin-bottom: 5px;\n  font-weight: bold;\n  flex: 0 0 auto;\n}\n\n.btn {\n  border-radius: 0px;\n  width: 70px;\n  font-weight: bold;\n}\n\n.cancel-button,\n.ok-button {\n  float: right;\n  margin-left: 10px;\n}\n\n.trellis-addGroupInput {\n  width: 100%;\n  padding: 6px 12px;\n  margin-bottom: 0.4em;\n}\n\n.menu-setting-option {\n  padding: 5px;\n}\n\n.menu-setting-option:hover {\n  cursor: pointer;\n  background: lightgrey;\n}\n\n.add-group-container {\n  overflow: hidden;\n  flex: 0 0 auto;\n}\n\nlog,\n.activities-container {\n  display: flex;\n  flex-direction: column;\n  flex: 1;\n}\n\n.trellis-menu-body {\n  position: relative;\n  padding: 6px 12px;\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n}\n\n.trellis-menu-activities {\n  height: 400px;\n  overflow: auto;\n  flex: 1;\n}\n\n.trellis-card-header {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  height: 35px;\n  width: 100%;\n}\n\n.trellis-card-header > span:first-child {\n  display: block;\n  width: 100%;\n  flex-grow: 1;\n  flex-shrink: 1;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  text-align: center;\n}\n\n.pull-right {\n  margin-top: 3px;\n  cursor: pointer;\n}"]} */
import _ from 'lodash'; import { getControlByElement } from '@grapecity/dataviews.core'; export function classNames(...args) { const t = args.filter(_.identity).map((a) => (_.isString(a) ? a : Object.keys(a).filter((k) => !!a[k]))); return _.flatten(t).join(' '); } export function getDataView() { return getControlByElement(document.body); } export function getPanelWidth() { const windowWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth; return Math.min(300, Math.max(100, parseInt((windowWidth - 50) / 4, 10))); } export function getGroupInfo(path) { const dataView = getDataView(); const groups = dataView.data.groups; let currentGroup = groups[path[0]]; for (let i = 1; i < path.length; i++) { if (currentGroup && currentGroup.groups) { currentGroup = currentGroup.groups[path[i]]; } else { return null; } } return currentGroup; } export function createElement(html) { const div = document.createElement('div'); div.innerHTML = html; return div.children[0]; } export function encodeValue(value) { const elem = document.createElement('textarea'); elem.textContent = value; return elem.innerHTML; }
(function () { const IS_PROD = window.process.env.NODE_ENV === 'production'; const USE_NPM = window.process.env.USE_NPM; const USE_CDN = window.process.env.USE_CDN; const SITE_ROOT = window.process.env.SITE_ROOT; const FRAMEWORK = window.process.env.FRAMEWORK; const ext = IS_PROD ? '.min.js' : '.js'; function js(name) { return name + ext; } function npm(t) { if (!t.file) { t.file = IS_PROD ? t.prod : t.dev; } const version = USE_CDN && t.version ? '@' + t.version : ''; const path = t.pkg + version + '/' + t.file; if (USE_CDN) { return 'https://unpkg.com/' + path; } return 'npm:' + path; } function dv(t) { if (USE_CDN || USE_NPM) { t.file = 'dist/' + t.file + '.min.js'; return npm(t); } return SITE_ROOT + '/static/dataviews/' + js(t.file); } const isTypeScript = FRAMEWORK === 'angular'; const babelConfig = { es2015: true, react: true, }; const meta = { js: { babelOptions: babelConfig, }, ts: { typescriptOptions: { tsconfig: true }, }, }; const map = { // gc.dataviews packages '@grapecity/dataviews.common': dv({pkg:'@grapecity/dataviews.common',file:'gc.dataviews.common',version:'1.8.7'}), '@grapecity/dataviews.core': dv({pkg:'@grapecity/dataviews.core',file:'gc.dataviews.core',version:'1.8.7'}), '@grapecity/dataviews.grid': dv({pkg:'@grapecity/dataviews.grid',file:'gc.dataviews.grid',version:'1.8.7'}), '@grapecity/dataviews.cardlayout': dv({pkg:'@grapecity/dataviews.cardlayout',file:'gc.dataviews.cardlayout',version:'1.8.7'}), '@grapecity/dataviews.masonry': dv({pkg:'@grapecity/dataviews.masonry',file:'gc.dataviews.masonry',version:'1.8.7'}), '@grapecity/dataviews.calendar': dv({pkg:'@grapecity/dataviews.calendar',file:'gc.dataviews.calendar',version:'1.8.7'}), '@grapecity/dataviews.timeline': dv({pkg:'@grapecity/dataviews.timeline',file:'gc.dataviews.timeline',version:'1.8.7'}), '@grapecity/dataviews.trellis': dv({pkg:'@grapecity/dataviews.trellis',file:'gc.dataviews.trellis',version:'1.8.7'}), '@grapecity/dataviews.gantt': dv({pkg:'@grapecity/dataviews.gantt',file:'gc.dataviews.gantt',version:'1.8.7'}), '@grapecity/dataviews.searchbox': dv({pkg:'@grapecity/dataviews.searchbox',file:'gc.dataviews.searchbox',version:'1.8.7'}), '@grapecity/dataviews.react': dv({pkg:'@grapecity/dataviews.react',file:'gc.dataviews.react',version:'1.8.7'}), '@grapecity/dataviews.vue': dv({pkg:'@grapecity/dataviews.vue',file:'gc.dataviews.vue',version:'1.8.7'}), '@grapecity/dataviews.angular': dv({pkg:'@grapecity/dataviews.angular',file:'gc.dataviews.angular',version:'1.8.7'}), '@grapecity/dataviews.csvexport': dv({pkg:'@grapecity/dataviews.angular',file:'gc.dataviews.csvexport',version:'1.8.7'}), // third-party libs react: npm({pkg:'react',prod:'umd/react.production.min.js',dev:'umd/react.development.js',version:'16.13.1'}), 'react-dom': npm({pkg:'react-dom',prod:'umd/react-dom.production.min.js',dev:'umd/react-dom.development.js',version:'16.13.1'}), 'react-router-dom': npm({pkg:'react-router-dom',prod:'umd/react-router-dom.min.js',dev:'umd/react-router-dom.js',version:'5.2.0'}), 'vue': npm({pkg:'vue',file:'dist/vue.js',version:'2.6.11'}), 'vue-router': npm({pkg:'vue-router',file:'dist/vue-router.js',version:'3.3.4'}), 'lodash': npm({pkg: 'lodash', file: js('lodash')}), 'zone.js': npm({pkg: 'zone.js', file: js('dist/zone')}), 'rxjs': npm({pkg: 'rxjs', file: js('bundles/rxjs.umd')}), 'rxjs/operators': npm({pkg:'rxjs-operators-bundle',prod:'dist/bundle.min.js',dev:'dist/bundle.js',version:'1.0.2'}), '@angular/core': npm({pkg: '@angular/core', file: js('bundles/core.umd')}), '@angular/common': npm({pkg: '@angular/common', file: js('bundles/common.umd')}), '@angular/compiler': npm({pkg: '@angular/compiler', file: js('bundles/compiler.umd')}), '@angular/platform-browser': npm({pkg: '@angular/platform-browser', file: js('bundles/platform-browser.umd')}), '@angular/platform-browser-dynamic': npm({pkg: '@angular/platform-browser-dynamic', file: js('bundles/platform-browser-dynamic.umd')}), '@angular/http': npm({pkg: '@angular/http', file: js('bundles/http.umd')}), '@angular/common/http': npm({pkg: '@angular/common', file: js('bundles/common-http.umd')}), '@angular/router': npm({pkg: '@angular/router', file: js('bundles/router.umd')}), '@angular/forms': npm({pkg: '@angular/forms', file: js('bundles/forms.umd')}), // systemjs plugins 'systemjs-plugin-json': npm({pkg:'systemjs-plugin-json',file:'json.js',version:'0.3.0'}), 'systemjs-plugin-css': npm({pkg:'systemjs-plugin-css',file:'css.js',version:'0.1.37'}), 'systemjs-plugin-babel': npm({pkg:'systemjs-plugin-babel',file:'plugin-babel.js',version:'0.0.25'}), 'systemjs-babel-build': npm({pkg:'systemjs-plugin-babel',file:'systemjs-babel-browser.js',version:'0.0.25'}), 'plugin-typescript': npm({pkg:'plugin-typescript',file:'lib/plugin.js',version:'8.0.0'}), 'typescript': npm({pkg:'typescript',file:'lib/typescript.js',version:'3.9.7'}), 'systemjs-vue-browser': npm({pkg:'systemjs-vue-browser',file:'index.js',version:'1.0.11'}), }; const config = { defaultJSExtensions: true, transpiler: isTypeScript ? 'plugin-typescript' : 'systemjs-plugin-babel', typescriptOptions: { tsconfig: true }, meta: { '*.json': {loader: 'systemjs-plugin-json'}, '*.css': {loader: 'systemjs-plugin-css'}, '*.vue': {loader: 'systemjs-vue-browser'}, '*.js': meta.js, '*.ts': meta.ts, 'app.js': { format: 'esm', babelOptions: babelConfig, }, 'typescript': { exports: 'ts', }, '@grapecity/dataviews.common': { format: 'amd', }, '@grapecity/dataviews.core': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.grid': { format: 'amd', deps: [ '@grapecity/dataviews.common', '@grapecity/dataviews.core', ], }, '@grapecity/dataviews.cardlayout': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.masonry': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.calendar': { format: 'amd', deps: [ '@grapecity/dataviews.common', '@grapecity/dataviews.core', ], }, '@grapecity/dataviews.timeline': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.trellis': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.gantt': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.searchbox': { format: 'amd', deps: [ '@grapecity/dataviews.common', ], }, '@grapecity/dataviews.react': { format: 'amd', deps: [ 'react', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.vue': { format: 'amd', deps: [ 'vue', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.angular': { format: 'amd', deps: [ '@angular/core', '@grapecity/dataviews.common', '@grapecity/dataviews.core' ], }, '@grapecity/dataviews.csvexport': { format: 'amd', deps: [ '@grapecity/dataviews.common' ], }, }, paths: { // paths serve as alias 'npm:': SITE_ROOT + '/node_modules/', }, // map tells the System loader where to look for things map: map, // packages tells the System loader how to load when no filename and/or no extension packages: { '.': { defaultExtension: isTypeScript ? 'ts' : 'js' }, node_modules: { defaultExtension: 'js' }, } }; // fast format detection to avoid detection by source code using regexp Object.keys(map).filter(function (key) { return !config.meta[key]; }).forEach(function (key) { const path = map[key]; if (path.indexOf('/umd') >= 0 || path.indexOf('.umd') >= 0) { config.meta[key] = { format: 'amd' }; } if (path.indexOf('/cjs') >= 0) { config.meta[key] = { format: 'cjs' }; } }); System.config(config); })(this);