jqwidgets-scripts-custom
Version:
jQWidgets is an advanced jQuery, Angular 7, Vue, React, ASP .NET MVC, Custom Elements and HTML5 UI framework.
226 lines (206 loc) • 11.1 kB
HTML
<html lang="en">
<head>
<title id='Description'>Custom Element Kanban KanbanEditing</title>
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
<meta name="viewport" content="width=device-width, initial-scale=1 maximum-scale=1 minimum-scale=1" />
<meta name="description" content="This is an example of the available editing in Custom Element Kanban." />
<link rel="stylesheet" href="../../../jqwidgets/styles/jqx.base.css" type="text/css" />
<link rel="stylesheet" href="../../../styles/demos.css" type="text/css" />
<script type="text/javascript" src="../../../scripts/webcomponents-lite.min.js"></script>
<script type="text/javascript" src="../../../jqwidgets/jqxcore.js"></script>
<script type="text/javascript" src="../../../jqwidgets/jqxcore.elements.js"></script>
<script type="text/javascript" src="../../../jqwidgets/jqxsortable.js"></script>
<script type="text/javascript" src="../../../jqwidgets/jqxkanban.js"></script>
<script type="text/javascript" src="../../../jqwidgets/jqxdata.js"></script>
<script type="text/javascript" src="../../../scripts/demos.js"></script>
<style>
.jqx-kanban-item-color-status {
width: 100%;
height: 25px;
border-top-left-radius: 3px;
border-top-right-radius: 3px;
position: relative;
margin-top: 0px;
overflow: hidden;
top: 0px;
}
.jqx-kanban-item {
padding-top: 0px;
padding-bottom: 0px;
}
.jqx-kanban-item-text {
padding-top: 6px;
padding-bottom: 6px;
}
.jqx-kanban-item-avatar {
top: 9px;
}
.jqx-kanban-template-icon {
position: absolute;
right: 3px;
top: 12px;
}
</style>
<script type="text/javascript">
var fields = [
{ name: 'id', type: 'string' },
{ name: 'status', map: 'state', type: 'string' },
{ name: 'text', map: 'label', type: 'string' },
{ name: 'tags', type: 'string' },
{ name: 'color', map: 'hex', type: 'string' },
{ name: 'resourceId', type: 'number' }
];
var source =
{
localData: [
{ id: '1161', state: 'new', label: 'Make a new Dashboard', tags: 'dashboard', hex: '#36c7d0', resourceId: 3 },
{ id: '1645', state: 'work', label: 'Prepare new release', tags: 'release', hex: '#ff7878', resourceId: 1 },
{ id: '9213', state: 'new', label: 'One item added to the cart', tags: 'cart', hex: '#96c443', resourceId: 3 },
{ id: '6546', state: 'done', label: 'Edit Item Price', tags: 'price, edit', hex: '#ff7878', resourceId: 4 },
{ id: '9034', state: 'new', label: 'Login 404 issue', tags: 'issue, login', hex: '#96c443' }
],
dataType: 'array',
dataFields: fields
};
var dataAdapter = new jqx.dataAdapter(source);
var resourcesAdapterFunc = function () {
var resourcesSource =
{
localData: [
{ id: 0, name: 'No name', image: '../jqwidgets/styles/../../images/common.png', common: true },
{ id: 1, name: 'Andrew Fuller', image: '../../../images/andrew.png' },
{ id: 2, name: 'Janet Leverling', image: '../../../images/janet.png' },
{ id: 3, name: 'Steven Buchanan', image: '../../../images/steven.png' },
{ id: 4, name: 'Nancy Davolio', image: '../../../images/nancy.png' },
{ id: 5, name: 'Michael Buchanan', image: '../../../images/Michael.png' },
{ id: 6, name: 'Margaret Buchanan', image: '../../../images/margaret.png' },
{ id: 7, name: 'Robert Buchanan', image: '../../../images/robert.png' },
{ id: 8, name: 'Laura Buchanan', image: '../../../images/Laura.png' },
{ id: 9, name: 'Laura Buchanan', image: '../../../images/Anne.png' }
],
dataType: 'array',
dataFields: [
{ name: 'id', type: 'number' },
{ name: 'name', type: 'string' },
{ name: 'image', type: 'string' },
{ name: 'common', type: 'boolean' }
]
};
var resourcesDataAdapter = new jqx.dataAdapter(resourcesSource);
return resourcesDataAdapter;
}
var getIconClassName = function () {
switch (theme) {
case 'darkblue':
case 'black':
case 'shinyblack':
case 'ui-le-frog':
case 'metrodark':
case 'orange':
case 'darkblue':
case 'highcontrast':
case 'ui-sunny':
case 'ui-darkness':
return 'jqx-icon-plus-alt-white ';
}
return 'jqx-icon-plus-alt';
}
JQXElements.settings['kanban1'] =
{
template: "<div class='jqx-kanban-item' id=''>"
+ "<div class='jqx-kanban-item-color-status'></div>"
+ "<div style='display: none;' class='jqx-kanban-item-avatar'></div>"
+ "<div class='jqx-icon jqx-icon-close jqx-kanban-item-template-content jqx-kanban-template-icon'></div>"
+ "<div class='jqx-kanban-item-text'></div>"
+ "<div style='display: none;' class='jqx-kanban-item-footer'></div>"
+ "</div>",
resources: resourcesAdapterFunc(),
source: dataAdapter,
// render items.
itemRenderer: function (item, data, resource) {
item[0].querySelector(".jqx-kanban-item-color-status").innerHTML = "<span style='line-height: 23px; margin-left: 5px;'>" + resource.name + "</span>";
item[0].querySelector(".jqx-kanban-item-text").style.background = item.color;
item[0].addEventListener('dblclick', function (event) {
var input = document.createElement('textarea');
input.className = placeholder = 'jqx-input';
input.style.cssText = 'border: none; width: 100%;';
input.placeHolder = '(No Title)';
var header = null;
var textElement = item[0].querySelector(".jqx-kanban-item-text");
input.value = textElement.innerText;
textElement.innerHTML = "";
textElement.appendChild(input);
input.addEventListener('mousedown', function (event) {
event.stopPropagation();
});
input.addEventListener('mouseup', function (event) {
event.stopPropagation();
});
input.addEventListener('blur', function () {
var value = input.value;
textElement.innerHTML = "<span>" + value + "</span>";
input.remove();
});
input.focus();
});
},
columns: [
{ text: "Backlog", iconClassName: getIconClassName(), dataField: "new", maxItems: 6 },
{ text: "In Progress", iconClassName: getIconClassName(), dataField: "work", maxItems: 6 },
{ text: "Done", iconClassName: getIconClassName(), dataField: "done", maxItems: 6 }
],
// render column headers.
columnRenderer: function (element, collapsedElement, column) {
if (element[0]) {
var elementHeaderStatus = element[0].getElementsByClassName('jqx-kanban-column-header-status')[0];
var collapsedElementHeaderStatus = collapsedElement[0].getElementsByClassName('jqx-kanban-column-header-status')[0];
var columnItems = document.querySelector('jqx-kanban').getColumnItems(column.dataField.length);
elementHeaderStatus.innerHTML = ' (' + columnItems + '/' + column.maxItems + ')';
collapsedElementHeaderStatus.innerHTML = ' (' + columnItems + '/' + column.maxItems + ')';
}
}
}
window.onload = function() {
var myKanban = document.createElement('jqx-kanban');
myKanban.addEventListener('itemAttrClicked', function (event) {
var args = event.args;
if (args.attribute == "template") {
myKanban.removeItem(args.item.id);
}
});
myKanban.addEventListener('columnAttrClicked', function (event) {
var args = event.args;
if (args.attribute == "button") {
args.cancelToggle = true;
if (!args.column.collapsed) {
var colors = ['#f19b60', '#5dc3f0', '#6bbd49', '#dddddd']
myKanban.addItem({ status: args.column.dataField, text: "<textarea placeholder='(No Title)' style='width: 96%; margin-top:2px; border-radius: 3px; border:none; line-height:20px; height: 50px;' class='jqx-input' id='newItem" + itemIndex + "' value=''></textarea>", tags: "new task", color: colors[Math.floor(Math.random() * 4)], resourceId: null });
var input = document.querySelector("#newItem" + itemIndex);
input.addEventListener('mousedown', function (event) {
event.stopPropagation();
});
input.addEventListener('mouseup', function (event) {
event.stopPropagation();
});
input.addEventListener('keydown', function (event) {
if (event.keyCode == 13) {
$("<span>" + $(event.target).val() + "</span>").insertBefore($(event.target));
$(event.target).remove();
}
});
input.focus();
itemIndex++;
}
}
});
}
</script>
</head>
<body>
<div class="example-description">
Custom element Kanban Editing. Double click on item's header or text to edit it.
</div>
<jqx-kanban id="kanban1" settings="kanban1"></jqx-kanban>
</body>
</html>