<html>
<head>
<title>Custom Table Demo</title>
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta name="viewport" content="width=device-width" />
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-animate.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-loader.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-sanitize.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-cookies.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-touch.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-resource.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/0.14.3/ui-bootstrap.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/0.14.3/ui-bootstrap-tpls.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.2.13/angular-ui-router.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui/0.4.0/angular-ui-ieshiv.min.js"></script>
<script type='text/javascript' src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui/0.4.0/angular-ui.min.js"></script>
<link rel="stylesheet" type="text/css" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.4/css/bootstrap.css">
<link rel="stylesheet" type="text/css" href="style.css">
<script type='text/javascript' src="script.js"></script>
<script type='text/javascript' src="https://rawgit.com/long2know/angular-directives-general/master/src/customTable.js"></script>
<script type='text/javascript' src="https://rawgit.com/long2know/angular-directives-general/master/src/triStateCheckbox.js"></script>
<script type='text/javascript' src="https://rawgit.com/long2know/angular-directives-general/master/src/multiselect.js"></script>
<script type='text/javascript' src="https://rawgit.com/long2know/angular-services-general/master/src/watchCountService.js"></script>
</head>
<body class="flex-layout" ng-app="myApp">
<div class="container-fluid row" ng-controller="myCtrl as vm">
<div class="buttons">
<button class="btn btn-default" ng-click="vm.addItems(100)">Add 100 Items</button>
<button class="btn btn-default" ng-click="vm.addItems(1000)">Add 1000 Items</button>
<button class="btn btn-default" ng-click="vm.removeItems(100)">Remove 100 Items</button>
<button class="btn btn-default" ng-click="vm.removeItems(1000)">Remove 1000 Items</button>
<button class="btn btn-default" ng-click="vm.toggleTable1()">Toggle Repeater Table</button>
<button class="btn btn-default" ng-click="vm.toggleTable2()">Toggle Non-Repeater Table</button>
<span style="font-weight:bold">$Watchers: </span>
<span style="font-weight:bold" ng-bind="vm.watchCount" />
</div>
<div>
<h3>
<span>Table with Repeater</span>
<span>Row Count</span>
<span ng-bind="vm.table1Options.records.length"></span>
</h3>
</div>
<div class="flex-scroll-content table1-container" ng-if="vm.isTable1Visible">
<custom-table options="vm.table1Options"></custom-table>
</div>
<br />
<div>
<h3>
<span>Table Rendered Directly to DOM</span>
<span>Row Count</span>
<span ng-bind="vm.table2Options.records.length"></span>
</h3>
</div>
<div class="flex-scroll-content table2-container" ng-if="vm.isTable2Visible">
<custom-table options="vm.table2Options"></custom-table>
</div>
</div>
</body>
</html>
html, body, .container-fluid {
height: 100%;
}
body {
-moz-box-flex: 2;
-moz-box-flex: 2;
-webkit-box-flex: 2;
-ms-flex: 2;
flex: 2;
}
.row {
margin-left: 15px;
margin-right:15px;
}
.buttons {
margin-bottom:10px;
margin-top:10px;
}
.btn-default {
background-color: #F7F7F7;
border: 1px solid #eaeaea;
}
body, .container-fluid, .flex-layout
{
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-box-orient: vertical;
-moz-box-orient: vertical;
-webkit-box-direction: normal;
-moz-box-direction: normal;
-webkit-flex-direction: column;
-ms-flex-direction: column;
flex-direction: column;
}
.flex-scroll-content {
overflow-y: auto;
/*for IE10*/
-ms-flex-shrink: 1;
flex-shrink: 1;
min-height: 85px;
-moz-box-flex: 2;
-moz-box-flex: 2;
-webkit-box-flex: 2;
-ms-flex: 2;
flex: 2;
margin-bottom:10px;
/*border: solid 1px;*/
/*padding:5px;*/
}
multiselect {
display: block;
}
multiselect > .btn-group:not(.single),
customselect > .btn-group:not(.single) {
min-width: 150px;
}
multiselect > .btn-group.single,
customselect > .btn-group.single {
min-width: 75px;
}
multiselect > .btn-group,
.modal-form customselect > .btn-group {
width: 100%;
}
multiselect .btn,
customselect .btn {
width: 100%;
background-color: #FFF;
}
multiselect .btn.has-error,
customselect.btn.has-error {
border: 1px solid #a94442 !important;
color: #db524b;
}
.multi-select-popup {
max-height: 400px;
min-width: 200px;
overflow-y: auto;
}
.custom-select-popup {
max-height: 400px;
min-width: 350px;
overflow-y: auto;
overflow-x: hidden;
}
.custom-select-popup > li > .form-group > input {
max-width: none;
width: 100%;
}
.custom-select-popup > li > .form-group > ul {
max-width: 330px;
}
.multi-select-popup .filter,
.custom-select-popup .filter {
width: 100%;
}
.multi-select-popup .filter > input,
.custom-select-popup .filter > input {
width: 99%;
max-width: none;
}
.multi-select-popup .filter .glyphicon,
.custom-select-popup .filter .glyphicon {
cursor: pointer;
pointer-events: all;
}
.multi-select-popup,
.custom-select-popup {
box-sizing: border-box;
padding: 2px;
}
multiselect > .btn-group > button,
customselect > .btn-group > button {
padding-right: 20px;
}
multiselect > .btn-group > button > .caret,
customselect > .btn-group > button > .caret {
right: 5px;
top: 45%;
position: absolute;
}
multiselect > .btn-group:not(.dropup) > button > .caret,
customselect > .btn-group:not(.dropup) > button > .caret {
border-left: 4px solid transparent;
border-right: 4px solid transparent;
border-top: 4px solid black;
}
.multi-select-popup > li:not(.filter-container),
.custom-select-popup > li:not(.filter-container) {
padding-right: 10px;
}
.multi-select-popup .filter-container input::-ms-clear,
.date-field::-ms-clear {
display: none;
width: 0;
height: 0;
}
.multi-select-popup .filter-container input::-ms-reveal,
.date-field::-ms-reveal {
display: none;
width: 0;
height: 0;
}
.multi-select-popup .filter-container input::-webkit-search-decoration,
.multi-select-popup .filter-container input::-webkit-search-cancel-button,
.multi-select-popup .filter-container input::-webkit-search-results-button,
.multi-select-popup .filter-container input::-webkit-search-results-decoration,
.date-field::-webkit-search-decoration,
.date-field::-webkit-search-cancel-button,
.date-field::-webkit-search-results-button,
.date-field::-webkit-search-results-decoration {
display: none;
}
.multi-select-popup > li > a,
.custom-select-popup > li > a {
padding: 3px 10px;
cursor: pointer;
}
.multi-select-popup > li > a i,
.custom-select-popup > li > a i {
margin-right: 4px;
}
/*Add padding if pagination is preceeded by another element with pagniation class*/
.pagination ~ ul.pagination {
padding-left: 10px !important;
}
.pagination {
font-size: .8em;
height: 2.8em;
padding-bottom: 0;
margin-bottom: 0;
}
.pagination multiselect > .btn-group > button {
font-size: 1.0em;
}
.multiselect-label ~ multiselect {
display: inline-block;
}
.pagination multiselect > .btn-group > button {
font-size: 1.0em;
}
.multiselect-label ~ multiselect {
display: inline-block;
}
/* TABLE STYLING */
.custom-table {
margin: 0 0 25px;
background-color: #f9f9f9;
border: 1px solid #D7D7D7;
width: 100%;
}
.custom-table.sticky-header {
margin: 0;
}
.custom-table th {
background-color: #F7F7F7;
border-bottom: 1px solid #D7D7D7;
border-left: 1px solid #D7D7D7;
color: #5C5C5C;
font-size: 13px;
height: 40px;
line-height: 40px;
text-align: left;
white-space: nowrap;
}
.custom-table .header-check {
padding-left: 17px;
padding-top: 4px;
min-width: 50px;
}
.custom-table .toggle-all {
width: 15px;
}
.custom-table .th-checkbox, .custom-table .td-checkbox {
width: 20px;
}
.custom-table .btn-default {
border: none;
}
.custom-table > tbody > tr:nth-child(odd) {
background: none;
}
.custom-table > tbody > tr:nth-child(even) {
background-color: #F7F7F7;
}
.custom-table > tbody > tr:hover {
background-color: #f5f5f5;
}
.custom-table tbody td, table.no-border tbody td {
height: 50px;
font-size: 11px;
}
.custom-table tbody td .center, table.no-border tbody td .center {
text-align: center;
}
.custom-table tbody .td-checkbox {
padding: 0;
}
.custom-table tbody .td-checkbox input {
margin-left: 3px;
width: 15px;
}
.custom-table thead th span {
padding-right: 20px;
}
.custom-table tbody td {
border-right: 1px solid #d7d7d7;
padding: 0 4px 0 7px;
}
.custom-table {
background-color: white;
}
.custom-table thead th {
padding-left: 7px;
}
.custom-table thead th:first-child {
padding: 2px 2px 0 3px;
}
.footer .custom-table {
margin-bottom: 5px;
}
table thead .sorting,
table thead .sorting_asc,
table thead .sorting_desc,
table thead .sorting_asc_disabled,
table thead .sorting_desc_disabled {
background-repeat: no-repeat;
background-position: center right;
}
table thead .sorting {
background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAYAAAByUDbMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEzNDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBNYWNpbnRvc2giIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MTRDMDM5NjkyMkMxMTFFMUExRjFBREFENUIyQTUzOEMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MTRDMDM5NkEyMkMxMTFFMUExRjFBREFENUIyQTUzOEMiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDoxNEMwMzk2NzIyQzExMUUxQTFGMUFEQUQ1QjJBNTM4QyIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDoxNEMwMzk2ODIyQzExMUUxQTFGMUFEQUQ1QjJBNTM4QyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pm8NGvcAAADkSURBVHjaYvz//z8DtQATAxUBCzbBu3fvInO5gLgNiMuA+BdMUFlZmSyXZQNxFhCnUupNLSDOA2JWIC4AOYhcwxiBuBiIZaB8FajBjOQY5gDEgWhiiUBsTaphvEBcC8SCWMRrgJidFMNCoC74gQU7AnEQ1nChZqLFlc4igdQCIP6HwzcZwHQ2n1hvrgPi/UDMgQUfBeI1pITZTyBuAeLPaOLvgbgZizjBpAFyAbpX1gPxAXLSGShmJgHxHSj/CRD3QsXJyk6gHD8BiH9DDb5GcmyigdlArArEUwkpZBy0hSNAgAEA5Ho0sMdEmU8AAAAASUVORK5CYII=);
cursor: pointer;
}
table thead .sorting_asc {
background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAYAAAByUDbMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA2ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEzNDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDowMTgwMTE3NDA3MjA2ODExQjM4MkY2QzVGRUYwRTJDNCIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo4MkFEQzYxNjIyQzExMUUxQTFGMUFEQUQ1QjJBNTM4QyIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDo4MkFEQzYxNTIyQzExMUUxQTFGMUFEQUQ1QjJBNTM4QyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ1M1IE1hY2ludG9zaCI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjAyODAxMTc0MDcyMDY4MTFCMzgyRjZDNUZFRjBFMkM0IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjAxODAxMTc0MDcyMDY4MTFCMzgyRjZDNUZFRjBFMkM0Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+z5ABTAAAAI5JREFUeNpi/P//PwO1ABMDFQELIQXVjfe4gFQbEJe11iv9otRl2UCcBcSphBQy4gszoKu0gNROIJYB4jtA7AF03V2SXQY0iBFIFUMNAgEVIM6DipPsTQcgDkQTSwRia5IMA9rOC6RqgVgQTQokXgOUZyfFZSFQF/zAgh2BOIjkCBjQRDtq2Khh9DAMIMAAT9AmNBDSXegAAAAASUVORK5CYII=);
cursor: pointer;
}
table thead .sorting_desc {
background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAYAAAByUDbMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA2ZpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEzNDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDowMTgwMTE3NDA3MjA2ODExQjM4MkY2QzVGRUYwRTJDNCIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo4MkFEQzYxQTIyQzExMUUxQTFGMUFEQUQ1QjJBNTM4QyIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDo4MkFEQzYxOTIyQzExMUUxQTFGMUFEQUQ1QjJBNTM4QyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ1M1IE1hY2ludG9zaCI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjAyODAxMTc0MDcyMDY4MTFCMzgyRjZDNUZFRjBFMkM0IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjAxODAxMTc0MDcyMDY4MTFCMzgyRjZDNUZFRjBFMkM0Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+1fsfwAAAAJdJREFUeNpi/P//PwO1ABMDFcGoYaOG0cMwFmyC1Y33IoHUAiD+h8MBGa31SvOJddk6IN4PxBxY8FEgXkO0N4G2/gRSLUD8GU3qPRA3A+U/kxpmIBege2U9EB/ApYERX6kBDDtlILUDiFWA+AkQuwNddY2s2ARqvAukJgDxbyCehM8gnLGJBmYDsSoQTyWkkHHQFo4AAQYAAA0piq4hbqwAAAAASUVORK5CYII=);
cursor: pointer;
}
table thead .sorting_asc_disabled {
background-image: url(data:image/png;base64,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);
}
table thead .sorting_desc_disabled {
background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABMAAAATCAYAAAByUDbMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMC1jMDYwIDYxLjEzNDc3NywgMjAxMC8wMi8xMi0xNzozMjowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNSBNYWNpbnRvc2giIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NDNGQ0VGRjQyMkMxMTFFMUExRjFBREFENUIyQTUzOEMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NDNGQ0VGRjUyMkMxMTFFMUExRjFBREFENUIyQTUzOEMiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDoxNEMwMzk2QjIyQzExMUUxQTFGMUFEQUQ1QjJBNTM4QyIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDoxNEMwMzk2QzIyQzExMUUxQTFGMUFEQUQ1QjJBNTM4QyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pnt2WfgAAACJSURBVHjaYvz//z8DtQATAxXBqGGjhtHDMBZsgnfv3o0EUguA+B8OB2QoKyvPJ9Zl64B4PxBzYMFHgXgNKd78CcQtQPwZTfw9EDdjEScYZiAXoHtlPRAfICcCQMXJJCC+A+U/AeJeqDhZsXkXiCcA8W+owddIjk00MBuIVYF4KiGFjIO2cAQIMAAzGSDTlIC38gAAAABJRU5ErkJggg==);
}
td.is-negative {
color: #FFFFFF;
background-color: #B1504A !important;
}
.is-error,
.is-error-add.is-error-add-active {
color: #FFFFFF;
background-color: #a94442;
}
.is-error a, .is-error-add.is-error-add-active a {
color: #FFFFFF;
}
.is-error-remove.is-error-remove-active {
background-color: #FFFFFF !important;
}
.is-error-add, .is-error-remove {
-webkit-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
-moz-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
-o-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
}
.table-striped > tbody > tr.is-error:nth-of-type(odd),
.table-striped > tbody > tr.is-error-add.is-error-add-active:nth-of-type(odd) {
color: #FFFFFF;
background-color: #a94442;
}
.table-striped > tbody > tr.is-error:nth-of-type(even),
.table-striped > tbody > tr.is-error-add.is-error-add-active:nth-of-type(even) {
color: #FFFFFF;
background-color: #b15654;
}
.table-striped.table-bordered > tbody > tr.is-error:nth-of-type(odd) td {
border-bottom: 1px solid #dc7675;
}
.table-striped.table-bordered > tbody > tr.is-error:nth-of-type(even) td {
border-bottom: 1px solid #dc7675;
}
.table-hover > tbody > tr.is-error:hover {
background-color: #dc7675;
}
.is-summary,
.is-summary-add.is-summary-add-active {
color: black;
background-color: #bfccdd;
}
.is-summary a, .is-summary-add.is-summary-add-active a {
color: black;
}
.is-summary-remove.is-summary-remove-active {
background-color: #FFFFFF !important;
}
.is-summary-add, .is-summary-remove {
-webkit-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
-moz-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
-o-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 0.5s;
}
.table-striped > tbody > tr.is-summary:nth-of-type(odd),
.table-striped > tbody > tr.is-summary-add.is-summary-add-active:nth-of-type(odd) {
color: black;
background-color: #a7b4c5;
}
.table-striped > tbody > tr.is-summary:nth-of-type(even),
.table-striped > tbody > tr.is-summary-add.is-summary-add-active:nth-of-type(even) {
color: black;
background-color: #bfccdd;
}
.table-striped.table-bordered > tbody > tr.is-summary:nth-of-type(odd) td {
border-bottom: 1px solid #99a4b2;
}
.table-striped.table-bordered > tbody > tr.is-summary:nth-of-type(even) td {
border-bottom: 1px solid #99a4b2;
}
.table-hover > tbody > tr.is-summary:hover {
background-color: #99a4b2;
}
(function () {
angular.module('myApp.controllers', []);
var myApp = angular.module('myApp', [
'long2know',
'myApp.controllers',
'ngSanitize',
'ui.bootstrap',
'ui.router',
'ui']);
var myController = function ($scope, $timeout, $animate, $log, watchCountService) {
var vm = this,
addItems = function (count) {
for (var i = 0; i < count; i++) {
var suffix = vm.table1Options.records.length.toString();
var money = (Math.random() * 1000).toFixed(2);
var date = new Date();
date.setDate(date.getDate() + vm.table1Options.records.length);
vm.table1Options.records.push({
id: suffix, column2: "Column2_" + suffix, column3: "Column3_" + suffix, column4: "Column4_" + suffix, column5: "Column5_" + suffix,
column6: money, column7: "Column7_" + suffix, column8: date
});
vm.table2Options.records.push({
id: suffix, column2: "Column2_" + suffix, column3: "Column3_" + suffix, column4: "Column4_" + suffix, column5: "Column5_" + suffix,
column6: money, column7: "Column7_" + suffix, column8: date
});
}
},
init = function () {
var columns = [
{ name: 'Column 1', value: 'column1', binding: "r.column3 + \" / \" + r.column4", style: {}, isWatched: true, isAnchor: false, isComputed: true, srefBinding: 'state expression here' },
{ name: 'Column 2', value: 'column2', binding: 'column2', isWatched: true, style: {} },
{ name: 'Column 3', value: 'column3', binding: 'column3', isWatechhed: true, style: {} },
{ name: 'Column 4', value: 'column4', binding: 'column4', isWatched: true, style: {} },
{ name: 'Column 5', value: 'column5', binding: 'column5', style: {} },
{ name: 'Column 6', value: 'column6', binding: 'column6', filter: "currency", isWatched: true, style: {} },
{ name: 'Column 7', value: 'column7', binding: 'column7', style: {} },
{ name: 'Column 8', value: 'column8', binding: 'column8', filter: "date:\"MM/dd/yyyy\"", style: {} }
];
vm.watchCount = 0;
vm.isTable1Visible = false;
vm.isTable2Visible = false;
vm.table1Options = {
records: [],
updatedRecords: [],
columnDefns: columns,
rowDefns: {
computedClass: "{ 'is-error': r.isError, 'is-summary': r.isSummary }"
},
config: {
sortBy: "column1",
sortDirection: "asc",
trackBy: "id",
pageSize: 50,
pageNumber: 1,
totalCount: 0,
totalPages: 0,
maxSize: 10,
useRepeat: true,
showSelectCheckbox: true,
showSelectAll: true,
showSort: true,
clientSort: true,
clientPaging: true,
displayPager: true,
displayPageSize: true,
stickyHeader: true,
stickyHeaderOffset: 0,
stickyContainer: '.table1-container'
},
callbacks: {
sortHeaderClicked: function (data) { },
pageChanged: function (data) { },
pageSizeChanged: function (data) { },
checkboxClicked: function (data) {
data.item.isError = data.item.isSelected;
},
masterClicked: function () {
var updatedRecords = [];
angular.forEach(vm.table1Options.pagedData, function (item) {
item.isError = item.isSelected;
updatedRecords.push(item);
});
$timeout(function () {
vm.table1Options.updatedRecords = updatedRecords;
}, 0);
},
}
};
vm.table2Options = {
records: [],
updatedRecords: [],
columnDefns: columns,
rowDefns: {
computedClass: "{ 'is-error': r.isError, 'is-summary': r.isSummary }"
},
config: {
sortBy: "column1",
sortDirection: "asc",
trackBy: "id",
pageSize: 20,
pageNumber: 1,
totalCount: 0,
totalPages: 0,
maxSize: 10,
useRepeat: false,
showSelectCheckbox: true,
showSelectAll: true,
showSort: true,
clientSort: true,
clientPaging: false,
stickyHeader: true,
stickyHeaderOffset: 0,
stickyContainer: '.table2-container'
},
callbacks: {
sortHeaderClicked: function (data) { },
pageChanged: function (data) { },
pageSizeChanged: function (data) { },
checkboxClicked: function (data) {
data.item.isSummary = data.item.isSelected;
var updatedRecords = [data.item];
$timeout(function () {
vm.table2Options.updatedRecords = updatedRecords;
}, 0);
},
masterClicked: function () {
var updatedRecords = [];
angular.forEach(vm.table2Options.pagedData, function (item) {
item.isSummary = item.isSelected;
updatedRecords.push(item);
});
$timeout(function () {
vm.table2Options.updatedRecords = updatedRecords;
}, 0);
},
}
};
$scope.$watch(
function watchCountExpression() {
return (watchCountService.getWatchCount());
},
function handleWatchCountChange(newValue) {
vm.watchCount = newValue;
});
$scope.$on('tableSortHeaderClicked', function (event, data) {
});
addItems(100);
vm.toggleTable1();
vm.toggleTable2();
};
vm.addItems = function (numItems) {
addItems(numItems);
};
vm.removeItems = function (numItems) {
if (vm.table1Options.records.length >= numItems) {
$timeout(function () {
vm.table1Options.records.splice(-1 * numItems, numItems);
vm.table2Options.records.splice(-1 * numItems, numItems);
$scope.$apply();
}, 0);
}
};
vm.toggleTable1 = function () {
$timeout(function () {
vm.isTable1Visible = !vm.isTable1Visible; $scope.$apply();
}, 1);
};
vm.toggleTable2 = function () {
$timeout(function () {
vm.isTable2Visible = !vm.isTable2Visible;
}, 1);
};
init();
};
myController.$inject = ['$scope', '$timeout', '$animate', '$log', 'watchCountService'];
angular.module('myApp.controllers')
.controller('myCtrl', myController);
myApp.config(['$modalProvider', '$locationProvider',
function ($modalProvider, $locationProvider) {
$modalProvider.options = { dialogFade: true, backdrop: 'static', keyboard: false };
$locationProvider.html5Mode(false);
}]);
myApp.run(['$log', function ($log) { $log.log("Start."); }]);
})()
This Pen doesn't use any external CSS resources.
This Pen doesn't use any external JavaScript resources.