From a594b171b65c32b0fa81e3de69a197c84e175a05 Mon Sep 17 00:00:00 2001 From: Satinder Grewal Date: Fri, 22 Jul 2016 01:12:56 +1200 Subject: [PATCH] Dashboard wallet widgets update - Only Basilisk wallet widgets are activated first - wallet widgets populate dynamically as coins are active - addresses list is updated in each wallet widget --- .../jquery-scrollbar/jquery.scrollbar.css | 791 ++++++++++++++++++ .../jquery-scrollbar/jquery.scrollbar.js | 781 +++++++++++++++++ .../jquery-scrollbar/jquery.scrollbar.min.js | 16 + assets/images/cryptologo/litecoin.png | Bin 0 -> 15138 bytes assets/scripts/dashboard.js | 128 +++ assets/scripts/login.js | 99 +-- index.html | 252 +----- 7 files changed, 1774 insertions(+), 293 deletions(-) create mode 100755 assets/global/vendor/jquery-scrollbar/jquery.scrollbar.css create mode 100755 assets/global/vendor/jquery-scrollbar/jquery.scrollbar.js create mode 100755 assets/global/vendor/jquery-scrollbar/jquery.scrollbar.min.js create mode 100644 assets/images/cryptologo/litecoin.png diff --git a/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.css b/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.css new file mode 100755 index 0000000..9f4e5ba --- /dev/null +++ b/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.css @@ -0,0 +1,791 @@ +/*************** SCROLLBAR BASE CSS ***************/ + +.scroll-wrapper { + overflow: hidden !important; + padding: 0 !important; + position: relative; +} + +.scroll-wrapper > .scroll-content { + border: none !important; + box-sizing: content-box !important; + height: auto; + left: 0; + margin: 0; + max-height: none; + max-width: none !important; + overflow: scroll !important; + padding: 0; + position: relative !important; + top: 0; + width: auto !important; +} + +.scroll-wrapper > .scroll-content::-webkit-scrollbar { + height: 0; + width: 0; +} + +.scroll-element { + display: none; +} +.scroll-element, .scroll-element div { + box-sizing: content-box; +} + +.scroll-element.scroll-x.scroll-scrollx_visible, +.scroll-element.scroll-y.scroll-scrolly_visible { + display: block; +} + +.scroll-element .scroll-bar, +.scroll-element .scroll-arrow { + cursor: default; +} + +.scroll-textarea { + border: 1px solid #cccccc; + border-top-color: #999999; +} +.scroll-textarea > .scroll-content { + overflow: hidden !important; +} +.scroll-textarea > .scroll-content > textarea { + border: none !important; + box-sizing: border-box; + height: 100% !important; + margin: 0; + max-height: none !important; + max-width: none !important; + overflow: scroll !important; + outline: none; + padding: 2px; + position: relative !important; + top: 0; + width: 100% !important; +} +.scroll-textarea > .scroll-content > textarea::-webkit-scrollbar { + height: 0; + width: 0; +} + + + + + + + + + +/*************** SIMPLE INNER SCROLLBAR ***************/ + +.scrollbar-inner > .scroll-element, +.scrollbar-inner > .scroll-element div +{ + border: none; + margin: 0; + padding: 0; + position: absolute; + z-index: 10; +} + +.scrollbar-inner > .scroll-element div { + display: block; + height: 100%; + left: 0; + top: 0; + width: 100%; +} + +.scrollbar-inner > .scroll-element.scroll-x { + bottom: 2px; + height: 8px; + left: 0; + width: 100%; +} + +.scrollbar-inner > .scroll-element.scroll-y { + height: 100%; + right: 2px; + top: 0; + width: 8px; +} + +.scrollbar-inner > .scroll-element .scroll-element_outer { + overflow: hidden; +} + +.scrollbar-inner > .scroll-element .scroll-element_outer, +.scrollbar-inner > .scroll-element .scroll-element_track, +.scrollbar-inner > .scroll-element .scroll-bar { + -webkit-border-radius: 8px; + -moz-border-radius: 8px; + border-radius: 8px; +} + +.scrollbar-inner > .scroll-element .scroll-element_track, +.scrollbar-inner > .scroll-element .scroll-bar { + -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=40)"; + filter: alpha(opacity=40); + opacity: 0.4; +} + +.scrollbar-inner > .scroll-element .scroll-element_track { background-color: #e0e0e0; } +.scrollbar-inner > .scroll-element .scroll-bar { background-color: #c2c2c2; } +.scrollbar-inner > .scroll-element:hover .scroll-bar { background-color: #919191; } +.scrollbar-inner > .scroll-element.scroll-draggable .scroll-bar { background-color: #919191; } + + +/* update scrollbar offset if both scrolls are visible */ + +.scrollbar-inner > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_track { left: -12px; } +.scrollbar-inner > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_track { top: -12px; } + + +.scrollbar-inner > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_size { left: -12px; } +.scrollbar-inner > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_size { top: -12px; } + + + + + + + + + + +/*************** SIMPLE OUTER SCROLLBAR ***************/ + +.scrollbar-outer > .scroll-element, +.scrollbar-outer > .scroll-element div +{ + border: none; + margin: 0; + padding: 0; + position: absolute; + z-index: 10; +} + +.scrollbar-outer > .scroll-element { + background-color: #ffffff; +} + +.scrollbar-outer > .scroll-element div { + display: block; + height: 100%; + left: 0; + top: 0; + width: 100%; +} + +.scrollbar-outer > .scroll-element.scroll-x { + bottom: 0; + height: 12px; + left: 0; + width: 100%; +} + +.scrollbar-outer > .scroll-element.scroll-y { + height: 100%; + right: 0; + top: 0; + width: 12px; +} + +.scrollbar-outer > .scroll-element.scroll-x .scroll-element_outer { height: 8px; top: 2px; } +.scrollbar-outer > .scroll-element.scroll-y .scroll-element_outer { left: 2px; width: 8px; } + +.scrollbar-outer > .scroll-element .scroll-element_outer { overflow: hidden; } +.scrollbar-outer > .scroll-element .scroll-element_track { background-color: #eeeeee; } + +.scrollbar-outer > .scroll-element .scroll-element_outer, +.scrollbar-outer > .scroll-element .scroll-element_track, +.scrollbar-outer > .scroll-element .scroll-bar { + -webkit-border-radius: 8px; + -moz-border-radius: 8px; + border-radius: 8px; +} + +.scrollbar-outer > .scroll-element .scroll-bar { background-color: #d9d9d9; } +.scrollbar-outer > .scroll-element .scroll-bar:hover { background-color: #c2c2c2; } +.scrollbar-outer > .scroll-element.scroll-draggable .scroll-bar { background-color: #919191; } + + +/* scrollbar height/width & offset from container borders */ + +.scrollbar-outer > .scroll-content.scroll-scrolly_visible { left: -12px; margin-left: 12px; } +.scrollbar-outer > .scroll-content.scroll-scrollx_visible { top: -12px; margin-top: 12px; } + +.scrollbar-outer > .scroll-element.scroll-x .scroll-bar { min-width: 10px; } +.scrollbar-outer > .scroll-element.scroll-y .scroll-bar { min-height: 10px; } + + +/* update scrollbar offset if both scrolls are visible */ + +.scrollbar-outer > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_track { left: -14px; } +.scrollbar-outer > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_track { top: -14px; } + +.scrollbar-outer > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_size { left: -14px; } +.scrollbar-outer > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_size { top: -14px; } + + + + + + + + + + +/*************** SCROLLBAR MAC OS X ***************/ + +.scrollbar-macosx > .scroll-element, +.scrollbar-macosx > .scroll-element div +{ + background: none; + border: none; + margin: 0; + padding: 0; + position: absolute; + z-index: 10; +} + +.scrollbar-macosx > .scroll-element div { + display: block; + height: 100%; + left: 0; + top: 0; + width: 100%; +} + +.scrollbar-macosx > .scroll-element .scroll-element_track { display: none; } +.scrollbar-macosx > .scroll-element .scroll-bar { + background-color: #6C6E71; + display: block; + + -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; + filter: alpha(opacity=0); + opacity: 0; + + -webkit-border-radius: 7px; + -moz-border-radius: 7px; + border-radius: 7px; + + -webkit-transition: opacity 0.2s linear; + -moz-transition: opacity 0.2s linear; + -o-transition: opacity 0.2s linear; + -ms-transition: opacity 0.2s linear; + transition: opacity 0.2s linear; +} +.scrollbar-macosx:hover > .scroll-element .scroll-bar, +.scrollbar-macosx > .scroll-element.scroll-draggable .scroll-bar { + -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=70)"; + filter: alpha(opacity=70); + opacity: 0.7; +} + + +.scrollbar-macosx > .scroll-element.scroll-x { + bottom: 0px; + height: 0px; + left: 0; + min-width: 100%; + overflow: visible; + width: 100%; +} + +.scrollbar-macosx > .scroll-element.scroll-y { + height: 100%; + min-height: 100%; + right: 0px; + top: 0; + width: 0px; +} + +/* scrollbar height/width & offset from container borders */ +.scrollbar-macosx > .scroll-element.scroll-x .scroll-bar { height: 7px; min-width: 10px; top: -9px; } +.scrollbar-macosx > .scroll-element.scroll-y .scroll-bar { left: -9px; min-height: 10px; width: 7px; } + +.scrollbar-macosx > .scroll-element.scroll-x .scroll-element_outer { left: 2px; } +.scrollbar-macosx > .scroll-element.scroll-x .scroll-element_size { left: -4px; } + +.scrollbar-macosx > .scroll-element.scroll-y .scroll-element_outer { top: 2px; } +.scrollbar-macosx > .scroll-element.scroll-y .scroll-element_size { top: -4px; } + +/* update scrollbar offset if both scrolls are visible */ +.scrollbar-macosx > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_size { left: -11px; } +.scrollbar-macosx > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_size { top: -11px; } + + + + + + + + + + +/*************** SCROLLBAR LIGHT ***************/ + +.scrollbar-light > .scroll-element, +.scrollbar-light > .scroll-element div { + border: none; + margin: 0; + overflow: hidden; + padding: 0; + position: absolute; + z-index: 10; +} + +.scrollbar-light > .scroll-element { + background-color: #ffffff; +} + +.scrollbar-light > .scroll-element div { + display: block; + height: 100%; + left: 0; + top: 0; + width: 100%; +} + +.scrollbar-light > .scroll-element .scroll-element_outer { + -webkit-border-radius: 10px; + -moz-border-radius: 10px; + border-radius: 10px; +} + +.scrollbar-light > .scroll-element .scroll-element_size { + background: #dbdbdb; + background: url(''); + background: -moz-linear-gradient(left, #dbdbdb 0%, #e8e8e8 100%); + background: -webkit-gradient(linear, left top, right top, color-stop(0%,#dbdbdb), color-stop(100%,#e8e8e8)); + background: -webkit-linear-gradient(left, #dbdbdb 0%,#e8e8e8 100%); + background: -o-linear-gradient(left, #dbdbdb 0%,#e8e8e8 100%); + background: -ms-linear-gradient(left, #dbdbdb 0%,#e8e8e8 100%); + background: linear-gradient(to right, #dbdbdb 0%,#e8e8e8 100%); + + -webkit-border-radius: 10px; + -moz-border-radius: 10px; + border-radius: 10px; +} + +.scrollbar-light > .scroll-element.scroll-x { + bottom: 0; + height: 17px; + left: 0; + min-width: 100%; + width: 100%; +} + +.scrollbar-light > .scroll-element.scroll-y { + height: 100%; + min-height: 100%; + right: 0; + top: 0; + width: 17px; +} + +.scrollbar-light > .scroll-element .scroll-bar { + background: #fefefe; + background: url(''); + background: -moz-linear-gradient(left, #fefefe 0%, #f5f5f5 100%); + background: -webkit-gradient(linear, left top, right top, color-stop(0%,#fefefe), color-stop(100%,#f5f5f5)); + background: -webkit-linear-gradient(left, #fefefe 0%,#f5f5f5 100%); + background: -o-linear-gradient(left, #fefefe 0%,#f5f5f5 100%); + background: -ms-linear-gradient(left, #fefefe 0%,#f5f5f5 100%); + background: linear-gradient(to right, #fefefe 0%,#f5f5f5 100%); + + border: 1px solid #dbdbdb; + -webkit-border-radius: 10px; + -moz-border-radius: 10px; + border-radius: 10px; +} + +/* scrollbar height/width & offset from container borders */ + +.scrollbar-light > .scroll-content.scroll-scrolly_visible { left: -17px; margin-left: 17px; } +.scrollbar-light > .scroll-content.scroll-scrollx_visible { top: -17px; margin-top: 17px; } + +.scrollbar-light > .scroll-element.scroll-x .scroll-bar { height: 10px; min-width: 10px; top: 0px; } +.scrollbar-light > .scroll-element.scroll-y .scroll-bar { left: 0px; min-height: 10px; width: 10px; } + +.scrollbar-light > .scroll-element.scroll-x .scroll-element_outer { height: 12px; left: 2px; top: 2px; } +.scrollbar-light > .scroll-element.scroll-x .scroll-element_size { left: -4px; } + +.scrollbar-light > .scroll-element.scroll-y .scroll-element_outer { left: 2px; top: 2px; width: 12px; } +.scrollbar-light > .scroll-element.scroll-y .scroll-element_size { top: -4px; } + +/* update scrollbar offset if both scrolls are visible */ + +.scrollbar-light > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_size { left: -19px; } +.scrollbar-light > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_size { top: -19px; } + +.scrollbar-light > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_track { left: -19px; } +.scrollbar-light > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_track { top: -19px; } + + + + + + + + + + +/*************** SCROLLBAR RAIL ***************/ + +.scrollbar-rail > .scroll-element, +.scrollbar-rail > .scroll-element div +{ + border: none; + margin: 0; + overflow: hidden; + padding: 0; + position: absolute; + z-index: 10; +} + +.scrollbar-rail > .scroll-element { + background-color: #ffffff; +} + +.scrollbar-rail > .scroll-element div { + display: block; + height: 100%; + left: 0; + top: 0; + width: 100%; +} + +.scrollbar-rail > .scroll-element .scroll-element_size { + background-color: #999; + background-color: rgba(0, 0, 0, 0.3); +} + +.scrollbar-rail > .scroll-element .scroll-element_outer:hover .scroll-element_size { + background-color: #666; + background-color: rgba(0, 0, 0, 0.5); +} + +.scrollbar-rail > .scroll-element.scroll-x { + bottom: 0; + height: 12px; + left: 0; + min-width: 100%; + padding: 3px 0 2px; + width: 100%; +} + +.scrollbar-rail > .scroll-element.scroll-y { + height: 100%; + min-height: 100%; + padding: 0 2px 0 3px; + right: 0; + top: 0; + width: 12px; +} + +.scrollbar-rail > .scroll-element .scroll-bar { + background-color: #d0b9a0; + + -webkit-border-radius: 2px; + -moz-border-radius: 2px; + border-radius: 2px; + + box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5); +} + +.scrollbar-rail > .scroll-element .scroll-element_outer:hover .scroll-bar { + box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.6); +} + +/* scrollbar height/width & offset from container borders */ + +.scrollbar-rail > .scroll-content.scroll-scrolly_visible { left: -17px; margin-left: 17px; } +.scrollbar-rail > .scroll-content.scroll-scrollx_visible { margin-top: 17px; top: -17px; } + +.scrollbar-rail > .scroll-element.scroll-x .scroll-bar { height: 10px; min-width: 10px; top: 1px; } +.scrollbar-rail > .scroll-element.scroll-y .scroll-bar { left: 1px; min-height: 10px; width: 10px; } + +.scrollbar-rail > .scroll-element.scroll-x .scroll-element_outer { height: 15px; left: 5px; } +.scrollbar-rail > .scroll-element.scroll-x .scroll-element_size { height: 2px; left: -10px; top: 5px; } + +.scrollbar-rail > .scroll-element.scroll-y .scroll-element_outer { top: 5px; width: 15px; } +.scrollbar-rail > .scroll-element.scroll-y .scroll-element_size { left: 5px; top: -10px; width: 2px; } + +/* update scrollbar offset if both scrolls are visible */ + +.scrollbar-rail > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_size { left: -25px; } +.scrollbar-rail > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_size { top: -25px; } + +.scrollbar-rail > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_track { left: -25px; } +.scrollbar-rail > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_track { top: -25px; } + + + + + + + + + + +/*************** SCROLLBAR DYNAMIC ***************/ + +.scrollbar-dynamic > .scroll-element, +.scrollbar-dynamic > .scroll-element div +{ + background: none; + border: none; + margin: 0; + padding: 0; + position: absolute; + z-index: 10; +} + +.scrollbar-dynamic > .scroll-element div { + display: block; + height: 100%; + left: 0; + top: 0; + width: 100%; +} + +.scrollbar-dynamic > .scroll-element.scroll-x { + bottom: 2px; + height: 7px; + left: 0; + min-width: 100%; + width: 100%; +} + +.scrollbar-dynamic > .scroll-element.scroll-y { + height: 100%; + min-height: 100%; + right: 2px; + top: 0; + width: 7px; +} + +.scrollbar-dynamic > .scroll-element .scroll-element_outer { + opacity: 0.3; + + -webkit-border-radius: 12px; + -moz-border-radius: 12px; + border-radius: 12px; +} +.scrollbar-dynamic > .scroll-element .scroll-element_size { + background-color: #cccccc; + opacity: 0; + + -webkit-border-radius: 12px; + -moz-border-radius: 12px; + border-radius: 12px; + + -webkit-transition: opacity 0.2s; + -moz-transition: opacity 0.2s; + -o-transition: opacity 0.2s; + -ms-transition: opacity 0.2s; + transition: opacity 0.2s; +} + +.scrollbar-dynamic > .scroll-element .scroll-bar { + background-color: #6c6e71; + + -webkit-border-radius: 7px; + -moz-border-radius: 7px; + border-radius: 7px; +} + +/* scrollbar height/width & offset from container borders */ + +.scrollbar-dynamic > .scroll-element.scroll-x .scroll-bar { + bottom: 0; + height: 7px; + min-width: 24px; + top: auto; +} +.scrollbar-dynamic > .scroll-element.scroll-y .scroll-bar { + left: auto; + min-height: 24px; + right: 0; + width: 7px; +} + +.scrollbar-dynamic > .scroll-element.scroll-x .scroll-element_outer { + bottom: 0; + top: auto; + left: 2px; + + -webkit-transition: height 0.2s; + -moz-transition: height 0.2s; + -o-transition: height 0.2s; + -ms-transition: height 0.2s; + transition: height 0.2s; +} + +.scrollbar-dynamic > .scroll-element.scroll-y .scroll-element_outer { + left: auto; + right: 0; + top: 2px; + + -webkit-transition: width 0.2s; + -moz-transition: width 0.2s; + -o-transition: width 0.2s; + -ms-transition: width 0.2s; + transition: width 0.2s; +} + +.scrollbar-dynamic > .scroll-element.scroll-x .scroll-element_size { left: -4px; } +.scrollbar-dynamic > .scroll-element.scroll-y .scroll-element_size { top: -4px; } + + +/* update scrollbar offset if both scrolls are visible */ + +.scrollbar-dynamic > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_size { left: -11px; } +.scrollbar-dynamic > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_size { top: -11px; } + + +/* hover & drag */ + +.scrollbar-dynamic > .scroll-element:hover .scroll-element_outer, +.scrollbar-dynamic > .scroll-element.scroll-draggable .scroll-element_outer { + overflow: hidden; + + -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=70)"; + filter: alpha(opacity=70); + opacity: 0.7; +} +.scrollbar-dynamic > .scroll-element:hover .scroll-element_outer .scroll-element_size, +.scrollbar-dynamic > .scroll-element.scroll-draggable .scroll-element_outer .scroll-element_size { + opacity: 1; +} +.scrollbar-dynamic > .scroll-element:hover .scroll-element_outer .scroll-bar, +.scrollbar-dynamic > .scroll-element.scroll-draggable .scroll-element_outer .scroll-bar { + height: 100%; + width: 100%; + + -webkit-border-radius: 12px; + -moz-border-radius: 12px; + border-radius: 12px; +} + +.scrollbar-dynamic > .scroll-element.scroll-x:hover .scroll-element_outer, +.scrollbar-dynamic > .scroll-element.scroll-x.scroll-draggable .scroll-element_outer { + height: 20px; + min-height: 7px; +} +.scrollbar-dynamic > .scroll-element.scroll-y:hover .scroll-element_outer, +.scrollbar-dynamic > .scroll-element.scroll-y.scroll-draggable .scroll-element_outer { + min-width: 7px; + width: 20px; +} + + + + + + + + + + +/*************** SCROLLBAR GOOGLE CHROME ***************/ + +.scrollbar-chrome > .scroll-element, +.scrollbar-chrome > .scroll-element div +{ + border: none; + margin: 0; + overflow: hidden; + padding: 0; + position: absolute; + z-index: 10; +} + +.scrollbar-chrome > .scroll-element { + background-color: #ffffff; +} + +.scrollbar-chrome > .scroll-element div { + display: block; + height: 100%; + left: 0; + top: 0; + width: 100%; +} + +.scrollbar-chrome > .scroll-element .scroll-element_outer {} + +.scrollbar-chrome > .scroll-element .scroll-element_track { + background: #f1f1f1; + border: 1px solid #dbdbdb; +} + +.scrollbar-chrome > .scroll-element.scroll-x { + bottom: 0; + height: 16px; + left: 0; + min-width: 100%; + width: 100%; +} + +.scrollbar-chrome > .scroll-element.scroll-y { + height: 100%; + min-height: 100%; + right: 0; + top: 0; + width: 16px; +} + +.scrollbar-chrome > .scroll-element .scroll-bar { + background-color: #d9d9d9; + border: 1px solid #bdbdbd; + cursor: default; + + -webkit-border-radius: 2px; + -moz-border-radius: 2px; + border-radius: 2px; +} + +.scrollbar-chrome > .scroll-element .scroll-bar:hover { + background-color: #c2c2c2; + border-color: #a9a9a9; +} + +.scrollbar-chrome > .scroll-element.scroll-draggable .scroll-bar { + background-color: #919191; + border-color: #7e7e7e; +} + +/* scrollbar height/width & offset from container borders */ + +.scrollbar-chrome > .scroll-content.scroll-scrolly_visible { left: -16px; margin-left: 16px; } +.scrollbar-chrome > .scroll-content.scroll-scrollx_visible { top: -16px; margin-top: 16px; } + +.scrollbar-chrome > .scroll-element.scroll-x .scroll-bar { height: 8px; min-width: 10px; top: 3px; } +.scrollbar-chrome > .scroll-element.scroll-y .scroll-bar { left: 3px; min-height: 10px; width: 8px; } + +.scrollbar-chrome > .scroll-element.scroll-x .scroll-element_outer { border-left: 1px solid #dbdbdb; } +.scrollbar-chrome > .scroll-element.scroll-x .scroll-element_track { height: 14px; left: -3px; } +.scrollbar-chrome > .scroll-element.scroll-x .scroll-element_size { height: 14px; left: -4px; } + +.scrollbar-chrome > .scroll-element.scroll-y .scroll-element_outer { border-top: 1px solid #dbdbdb; } +.scrollbar-chrome > .scroll-element.scroll-y .scroll-element_track { top: -3px; width: 14px; } +.scrollbar-chrome > .scroll-element.scroll-y .scroll-element_size { top: -4px; width: 14px; } + +/* update scrollbar offset if both scrolls are visible */ + +.scrollbar-chrome > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_size { left: -19px; } +.scrollbar-chrome > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_size { top: -19px; } + +.scrollbar-chrome > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_track { left: -19px; } +.scrollbar-chrome > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_track { top: -19px; } + + + + + + + diff --git a/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.js b/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.js new file mode 100755 index 0000000..0f7e3d9 --- /dev/null +++ b/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.js @@ -0,0 +1,781 @@ +/** + * jQuery CSS Customizable Scrollbar + * + * Copyright 2015, Yuriy Khabarov + * Dual licensed under the MIT or GPL Version 2 licenses. + * + * If you found bug, please contact me via email <13real008@gmail.com> + * + * @author Yuriy Khabarov aka Gromo + * @version 0.2.10 + * @url https://github.com/gromo/jquery.scrollbar/ + * + */ +; +(function (root, factory) { + if (typeof define === 'function' && define.amd) { + define(['jquery'], factory); + } else { + factory(root.jQuery); + } +}(this, function ($) { + 'use strict'; + + // init flags & variables + var debug = false; + + var browser = { + data: { + index: 0, + name: 'scrollbar' + }, + macosx: /mac/i.test(navigator.platform), + mobile: /android|webos|iphone|ipad|ipod|blackberry/i.test(navigator.userAgent), + overlay: null, + scroll: null, + scrolls: [], + webkit: /webkit/i.test(navigator.userAgent) && !/edge\/\d+/i.test(navigator.userAgent) + }; + + browser.scrolls.add = function (instance) { + this.remove(instance).push(instance); + }; + browser.scrolls.remove = function (instance) { + while ($.inArray(instance, this) >= 0) { + this.splice($.inArray(instance, this), 1); + } + return this; + }; + + var defaults = { + "autoScrollSize": true, // automatically calculate scrollsize + "autoUpdate": true, // update scrollbar if content/container size changed + "debug": false, // debug mode + "disableBodyScroll": false, // disable body scroll if mouse over container + "duration": 200, // scroll animate duration in ms + "ignoreMobile": false, // ignore mobile devices + "ignoreOverlay": false, // ignore browsers with overlay scrollbars (mobile, MacOS) + "scrollStep": 30, // scroll step for scrollbar arrows + "showArrows": false, // add class to show arrows + "stepScrolling": true, // when scrolling to scrollbar mousedown position + + "scrollx": null, // horizontal scroll element + "scrolly": null, // vertical scroll element + + "onDestroy": null, // callback function on destroy, + "onInit": null, // callback function on first initialization + "onScroll": null, // callback function on content scrolling + "onUpdate": null // callback function on init/resize (before scrollbar size calculation) + }; + + + var BaseScrollbar = function (container) { + + if (!browser.scroll) { + browser.overlay = isScrollOverlaysContent(); + browser.scroll = getBrowserScrollSize(); + updateScrollbars(); + + $(window).resize(function () { + var forceUpdate = false; + if (browser.scroll && (browser.scroll.height || browser.scroll.width)) { + var scroll = getBrowserScrollSize(); + if (scroll.height !== browser.scroll.height || scroll.width !== browser.scroll.width) { + browser.scroll = scroll; + forceUpdate = true; // handle page zoom + } + } + updateScrollbars(forceUpdate); + }); + } + + this.container = container; + this.namespace = '.scrollbar_' + browser.data.index++; + this.options = $.extend({}, defaults, window.jQueryScrollbarOptions || {}); + this.scrollTo = null; + this.scrollx = {}; + this.scrolly = {}; + + container.data(browser.data.name, this); + browser.scrolls.add(this); + }; + + BaseScrollbar.prototype = { + + destroy: function () { + + if (!this.wrapper) { + return; + } + + this.container.removeData(browser.data.name); + browser.scrolls.remove(this); + + // init variables + var scrollLeft = this.container.scrollLeft(); + var scrollTop = this.container.scrollTop(); + + this.container.insertBefore(this.wrapper).css({ + "height": "", + "margin": "", + "max-height": "" + }) + .removeClass('scroll-content scroll-scrollx_visible scroll-scrolly_visible') + .off(this.namespace) + .scrollLeft(scrollLeft) + .scrollTop(scrollTop); + + this.scrollx.scroll.removeClass('scroll-scrollx_visible').find('div').andSelf().off(this.namespace); + this.scrolly.scroll.removeClass('scroll-scrolly_visible').find('div').andSelf().off(this.namespace); + + this.wrapper.remove(); + + $(document).add('body').off(this.namespace); + + if ($.isFunction(this.options.onDestroy)){ + this.options.onDestroy.apply(this, [this.container]); + } + }, + init: function (options) { + + // init variables + var S = this, + c = this.container, + cw = this.containerWrapper || c, + namespace = this.namespace, + o = $.extend(this.options, options || {}), + s = {x: this.scrollx, y: this.scrolly}, + w = this.wrapper; + + var initScroll = { + "scrollLeft": c.scrollLeft(), + "scrollTop": c.scrollTop() + }; + + // do not init if in ignorable browser + if ((browser.mobile && o.ignoreMobile) + || (browser.overlay && o.ignoreOverlay) + || (browser.macosx && !browser.webkit) // still required to ignore nonWebKit browsers on Mac + ) { + return false; + } + + // init scroll container + if (!w) { + this.wrapper = w = $('
').addClass('scroll-wrapper').addClass(c.attr('class')) + .css('position', c.css('position') == 'absolute' ? 'absolute' : 'relative') + .insertBefore(c).append(c); + + if (c.is('textarea')) { + this.containerWrapper = cw = $('
').insertBefore(c).append(c); + w.addClass('scroll-textarea'); + } + + cw.addClass('scroll-content').css({ + "height": "auto", + "margin-bottom": browser.scroll.height * -1 + 'px', + "margin-right": browser.scroll.width * -1 + 'px', + "max-height": "" + }); + + c.on('scroll' + namespace, function (event) { + if ($.isFunction(o.onScroll)) { + o.onScroll.call(S, { + "maxScroll": s.y.maxScrollOffset, + "scroll": c.scrollTop(), + "size": s.y.size, + "visible": s.y.visible + }, { + "maxScroll": s.x.maxScrollOffset, + "scroll": c.scrollLeft(), + "size": s.x.size, + "visible": s.x.visible + }); + } + s.x.isVisible && s.x.scroll.bar.css('left', c.scrollLeft() * s.x.kx + 'px'); + s.y.isVisible && s.y.scroll.bar.css('top', c.scrollTop() * s.y.kx + 'px'); + }); + + /* prevent native scrollbars to be visible on #anchor click */ + w.on('scroll' + namespace, function () { + w.scrollTop(0).scrollLeft(0); + }); + + if (o.disableBodyScroll) { + var handleMouseScroll = function (event) { + isVerticalScroll(event) ? + s.y.isVisible && s.y.mousewheel(event) : + s.x.isVisible && s.x.mousewheel(event); + }; + w.on('MozMousePixelScroll' + namespace, handleMouseScroll); + w.on('mousewheel' + namespace, handleMouseScroll); + + if (browser.mobile) { + w.on('touchstart' + namespace, function (event) { + var touch = event.originalEvent.touches && event.originalEvent.touches[0] || event; + var originalTouch = { + "pageX": touch.pageX, + "pageY": touch.pageY + }; + var originalScroll = { + "left": c.scrollLeft(), + "top": c.scrollTop() + }; + $(document).on('touchmove' + namespace, function (event) { + var touch = event.originalEvent.targetTouches && event.originalEvent.targetTouches[0] || event; + c.scrollLeft(originalScroll.left + originalTouch.pageX - touch.pageX); + c.scrollTop(originalScroll.top + originalTouch.pageY - touch.pageY); + event.preventDefault(); + }); + $(document).on('touchend' + namespace, function () { + $(document).off(namespace); + }); + }); + } + } + if ($.isFunction(o.onInit)){ + o.onInit.apply(this, [c]); + } + } else { + cw.css({ + "height": "auto", + "margin-bottom": browser.scroll.height * -1 + 'px', + "margin-right": browser.scroll.width * -1 + 'px', + "max-height": "" + }); + } + + // init scrollbars & recalculate sizes + $.each(s, function (d, scrollx) { + + var scrollCallback = null; + var scrollForward = 1; + var scrollOffset = (d === 'x') ? 'scrollLeft' : 'scrollTop'; + var scrollStep = o.scrollStep; + var scrollTo = function () { + var currentOffset = c[scrollOffset](); + c[scrollOffset](currentOffset + scrollStep); + if (scrollForward == 1 && (currentOffset + scrollStep) >= scrollToValue) + currentOffset = c[scrollOffset](); + if (scrollForward == -1 && (currentOffset + scrollStep) <= scrollToValue) + currentOffset = c[scrollOffset](); + if (c[scrollOffset]() == currentOffset && scrollCallback) { + scrollCallback(); + } + } + var scrollToValue = 0; + + if (!scrollx.scroll) { + + scrollx.scroll = S._getScroll(o['scroll' + d]).addClass('scroll-' + d); + + if(o.showArrows){ + scrollx.scroll.addClass('scroll-element_arrows_visible'); + } + + scrollx.mousewheel = function (event) { + + if (!scrollx.isVisible || (d === 'x' && isVerticalScroll(event))) { + return true; + } + if (d === 'y' && !isVerticalScroll(event)) { + s.x.mousewheel(event); + return true; + } + + var delta = event.originalEvent.wheelDelta * -1 || event.originalEvent.detail; + var maxScrollValue = scrollx.size - scrollx.visible - scrollx.offset; + + if ((delta > 0 && scrollToValue < maxScrollValue) || (delta < 0 && scrollToValue > 0)) { + scrollToValue = scrollToValue + delta; + if (scrollToValue < 0) + scrollToValue = 0; + if (scrollToValue > maxScrollValue) + scrollToValue = maxScrollValue; + + S.scrollTo = S.scrollTo || {}; + S.scrollTo[scrollOffset] = scrollToValue; + setTimeout(function () { + if (S.scrollTo) { + c.stop().animate(S.scrollTo, 240, 'linear', function () { + scrollToValue = c[scrollOffset](); + }); + S.scrollTo = null; + } + }, 1); + } + + event.preventDefault(); + return false; + }; + + scrollx.scroll + .on('MozMousePixelScroll' + namespace, scrollx.mousewheel) + .on('mousewheel' + namespace, scrollx.mousewheel) + .on('mouseenter' + namespace, function () { + scrollToValue = c[scrollOffset](); + }); + + // handle arrows & scroll inner mousedown event + scrollx.scroll.find('.scroll-arrow, .scroll-element_track') + .on('mousedown' + namespace, function (event) { + + if (event.which != 1) // lmb + return true; + + scrollForward = 1; + + var data = { + "eventOffset": event[(d === 'x') ? 'pageX' : 'pageY'], + "maxScrollValue": scrollx.size - scrollx.visible - scrollx.offset, + "scrollbarOffset": scrollx.scroll.bar.offset()[(d === 'x') ? 'left' : 'top'], + "scrollbarSize": scrollx.scroll.bar[(d === 'x') ? 'outerWidth' : 'outerHeight']() + }; + var timeout = 0, timer = 0; + + if ($(this).hasClass('scroll-arrow')) { + scrollForward = $(this).hasClass("scroll-arrow_more") ? 1 : -1; + scrollStep = o.scrollStep * scrollForward; + scrollToValue = scrollForward > 0 ? data.maxScrollValue : 0; + } else { + scrollForward = (data.eventOffset > (data.scrollbarOffset + data.scrollbarSize) ? 1 + : (data.eventOffset < data.scrollbarOffset ? -1 : 0)); + scrollStep = Math.round(scrollx.visible * 0.75) * scrollForward; + scrollToValue = (data.eventOffset - data.scrollbarOffset - + (o.stepScrolling ? (scrollForward == 1 ? data.scrollbarSize : 0) + : Math.round(data.scrollbarSize / 2))); + scrollToValue = c[scrollOffset]() + (scrollToValue / scrollx.kx); + } + + S.scrollTo = S.scrollTo || {}; + S.scrollTo[scrollOffset] = o.stepScrolling ? c[scrollOffset]() + scrollStep : scrollToValue; + + if (o.stepScrolling) { + scrollCallback = function () { + scrollToValue = c[scrollOffset](); + clearInterval(timer); + clearTimeout(timeout); + timeout = 0; + timer = 0; + }; + timeout = setTimeout(function () { + timer = setInterval(scrollTo, 40); + }, o.duration + 100); + } + + setTimeout(function () { + if (S.scrollTo) { + c.animate(S.scrollTo, o.duration); + S.scrollTo = null; + } + }, 1); + + return S._handleMouseDown(scrollCallback, event); + }); + + // handle scrollbar drag'n'drop + scrollx.scroll.bar.on('mousedown' + namespace, function (event) { + + if (event.which != 1) // lmb + return true; + + var eventPosition = event[(d === 'x') ? 'pageX' : 'pageY']; + var initOffset = c[scrollOffset](); + + scrollx.scroll.addClass('scroll-draggable'); + + $(document).on('mousemove' + namespace, function (event) { + var diff = parseInt((event[(d === 'x') ? 'pageX' : 'pageY'] - eventPosition) / scrollx.kx, 10); + c[scrollOffset](initOffset + diff); + }); + + return S._handleMouseDown(function () { + scrollx.scroll.removeClass('scroll-draggable'); + scrollToValue = c[scrollOffset](); + }, event); + }); + } + }); + + // remove classes & reset applied styles + $.each(s, function (d, scrollx) { + var scrollClass = 'scroll-scroll' + d + '_visible'; + var scrolly = (d == "x") ? s.y : s.x; + + scrollx.scroll.removeClass(scrollClass); + scrolly.scroll.removeClass(scrollClass); + cw.removeClass(scrollClass); + }); + + // calculate init sizes + $.each(s, function (d, scrollx) { + $.extend(scrollx, (d == "x") ? { + "offset": parseInt(c.css('left'), 10) || 0, + "size": c.prop('scrollWidth'), + "visible": w.width() + } : { + "offset": parseInt(c.css('top'), 10) || 0, + "size": c.prop('scrollHeight'), + "visible": w.height() + }); + }); + + // update scrollbar visibility/dimensions + this._updateScroll('x', this.scrollx); + this._updateScroll('y', this.scrolly); + + if ($.isFunction(o.onUpdate)){ + o.onUpdate.apply(this, [c]); + } + + // calculate scroll size + $.each(s, function (d, scrollx) { + + var cssOffset = (d === 'x') ? 'left' : 'top'; + var cssFullSize = (d === 'x') ? 'outerWidth' : 'outerHeight'; + var cssSize = (d === 'x') ? 'width' : 'height'; + var offset = parseInt(c.css(cssOffset), 10) || 0; + + var AreaSize = scrollx.size; + var AreaVisible = scrollx.visible + offset; + + var scrollSize = scrollx.scroll.size[cssFullSize]() + (parseInt(scrollx.scroll.size.css(cssOffset), 10) || 0); + + if (o.autoScrollSize) { + scrollx.scrollbarSize = parseInt(scrollSize * AreaVisible / AreaSize, 10); + scrollx.scroll.bar.css(cssSize, scrollx.scrollbarSize + 'px'); + } + + scrollx.scrollbarSize = scrollx.scroll.bar[cssFullSize](); + scrollx.kx = ((scrollSize - scrollx.scrollbarSize) / (AreaSize - AreaVisible)) || 1; + scrollx.maxScrollOffset = AreaSize - AreaVisible; + }); + + c.scrollLeft(initScroll.scrollLeft).scrollTop(initScroll.scrollTop).trigger('scroll'); + }, + + /** + * Get scrollx/scrolly object + * + * @param {Mixed} scroll + * @returns {jQuery} scroll object + */ + _getScroll: function (scroll) { + var types = { + advanced: [ + '
', + '
', + '
', + '
', + '
', + '
', // required! used for scrollbar size calculation ! + '
', + '
', // used for handling scrollbar click + '
', + '
', + '
', + '
', // required + '
', + '
', + '
', + '
', + '
', + '
', + '
', + '
' + ].join(''), + simple: [ + '
', + '
', + '
', // required! used for scrollbar size calculation ! + '
', // used for handling scrollbar click + '
', // required + '
', + '
' + ].join('') + }; + if (types[scroll]) { + scroll = types[scroll]; + } + if (!scroll) { + scroll = types['simple']; + } + if (typeof (scroll) == 'string') { + scroll = $(scroll).appendTo(this.wrapper); + } else { + scroll = $(scroll); + } + $.extend(scroll, { + bar: scroll.find('.scroll-bar'), + size: scroll.find('.scroll-element_size'), + track: scroll.find('.scroll-element_track') + }); + return scroll; + }, + + _handleMouseDown: function(callback, event) { + + var namespace = this.namespace; + + $(document).on('blur' + namespace, function () { + $(document).add('body').off(namespace); + callback && callback(); + }); + $(document).on('dragstart' + namespace, function (event) { + event.preventDefault(); + return false; + }); + $(document).on('mouseup' + namespace, function () { + $(document).add('body').off(namespace); + callback && callback(); + }); + $('body').on('selectstart' + namespace, function (event) { + event.preventDefault(); + return false; + }); + + event && event.preventDefault(); + return false; + }, + + _updateScroll: function (d, scrollx) { + + var container = this.container, + containerWrapper = this.containerWrapper || container, + scrollClass = 'scroll-scroll' + d + '_visible', + scrolly = (d === 'x') ? this.scrolly : this.scrollx, + offset = parseInt(this.container.css((d === 'x') ? 'left' : 'top'), 10) || 0, + wrapper = this.wrapper; + + var AreaSize = scrollx.size; + var AreaVisible = scrollx.visible + offset; + + scrollx.isVisible = (AreaSize - AreaVisible) > 1; // bug in IE9/11 with 1px diff + if (scrollx.isVisible) { + scrollx.scroll.addClass(scrollClass); + scrolly.scroll.addClass(scrollClass); + containerWrapper.addClass(scrollClass); + } else { + scrollx.scroll.removeClass(scrollClass); + scrolly.scroll.removeClass(scrollClass); + containerWrapper.removeClass(scrollClass); + } + + if (d === 'y') { + if(container.is('textarea') || AreaSize < AreaVisible){ + containerWrapper.css({ + "height": (AreaVisible + browser.scroll.height) + 'px', + "max-height": "none" + }); + } else { + containerWrapper.css({ + //"height": "auto", // do not reset height value: issue with height:100%! + "max-height": (AreaVisible + browser.scroll.height) + 'px' + }); + } + } + + if (scrollx.size != container.prop('scrollWidth') + || scrolly.size != container.prop('scrollHeight') + || scrollx.visible != wrapper.width() + || scrolly.visible != wrapper.height() + || scrollx.offset != (parseInt(container.css('left'), 10) || 0) + || scrolly.offset != (parseInt(container.css('top'), 10) || 0) + ) { + $.extend(this.scrollx, { + "offset": parseInt(container.css('left'), 10) || 0, + "size": container.prop('scrollWidth'), + "visible": wrapper.width() + }); + $.extend(this.scrolly, { + "offset": parseInt(container.css('top'), 10) || 0, + "size": this.container.prop('scrollHeight'), + "visible": wrapper.height() + }); + this._updateScroll(d === 'x' ? 'y' : 'x', scrolly); + } + } + }; + + var CustomScrollbar = BaseScrollbar; + + /* + * Extend jQuery as plugin + * + * @param {Mixed} command to execute + * @param {Mixed} arguments as Array + * @return {jQuery} + */ + $.fn.scrollbar = function (command, args) { + if (typeof command !== 'string') { + args = command; + command = 'init'; + } + if (typeof args === 'undefined') { + args = []; + } + if (!$.isArray(args)) { + args = [args]; + } + this.not('body, .scroll-wrapper').each(function () { + var element = $(this), + instance = element.data(browser.data.name); + if (instance || command === 'init') { + if (!instance) { + instance = new CustomScrollbar(element); + } + if (instance[command]) { + instance[command].apply(instance, args); + } + } + }); + return this; + }; + + /** + * Connect default options to global object + */ + $.fn.scrollbar.options = defaults; + + + /** + * Check if scroll content/container size is changed + */ + + var updateScrollbars = (function () { + var timer = 0, + timerCounter = 0; + + return function (force) { + var i, container, options, scroll, wrapper, scrollx, scrolly; + for (i = 0; i < browser.scrolls.length; i++) { + scroll = browser.scrolls[i]; + container = scroll.container; + options = scroll.options; + wrapper = scroll.wrapper; + scrollx = scroll.scrollx; + scrolly = scroll.scrolly; + if (force || (options.autoUpdate && wrapper && wrapper.is(':visible') && + (container.prop('scrollWidth') != scrollx.size || container.prop('scrollHeight') != scrolly.size || wrapper.width() != scrollx.visible || wrapper.height() != scrolly.visible))) { + scroll.init(); + + if (options.debug) { + window.console && console.log({ + scrollHeight: container.prop('scrollHeight') + ':' + scroll.scrolly.size, + scrollWidth: container.prop('scrollWidth') + ':' + scroll.scrollx.size, + visibleHeight: wrapper.height() + ':' + scroll.scrolly.visible, + visibleWidth: wrapper.width() + ':' + scroll.scrollx.visible + }, true); + timerCounter++; + } + } + } + if (debug && timerCounter > 10) { + window.console && console.log('Scroll updates exceed 10'); + updateScrollbars = function () {}; + } else { + clearTimeout(timer); + timer = setTimeout(updateScrollbars, 300); + } + }; + })(); + + /* ADDITIONAL FUNCTIONS */ + /** + * Get native browser scrollbar size (height/width) + * + * @param {Boolean} actual size or CSS size, default - CSS size + * @returns {Object} with height, width + */ + function getBrowserScrollSize(actualSize) { + + if (browser.webkit && !actualSize) { + return { + "height": 0, + "width": 0 + }; + } + + if (!browser.data.outer) { + var css = { + "border": "none", + "box-sizing": "content-box", + "height": "200px", + "margin": "0", + "padding": "0", + "width": "200px" + }; + browser.data.inner = $("
").css($.extend({}, css)); + browser.data.outer = $("
").css($.extend({ + "left": "-1000px", + "overflow": "scroll", + "position": "absolute", + "top": "-1000px" + }, css)).append(browser.data.inner).appendTo("body"); + } + + browser.data.outer.scrollLeft(1000).scrollTop(1000); + + return { + "height": Math.ceil((browser.data.outer.offset().top - browser.data.inner.offset().top) || 0), + "width": Math.ceil((browser.data.outer.offset().left - browser.data.inner.offset().left) || 0) + }; + } + + /** + * Check if native browser scrollbars overlay content + * + * @returns {Boolean} + */ + function isScrollOverlaysContent() { + var scrollSize = getBrowserScrollSize(true); + return !(scrollSize.height || scrollSize.width); + } + + function isVerticalScroll(event) { + var e = event.originalEvent; + if (e.axis && e.axis === e.HORIZONTAL_AXIS) + return false; + if (e.wheelDeltaX) + return false; + return true; + } + + + /** + * Extend AngularJS as UI directive + * and expose a provider for override default config + * + */ + if (window.angular) { + (function (angular) { + angular.module('jQueryScrollbar', []) + .provider('jQueryScrollbar', function () { + var defaultOptions = defaults; + return { + setOptions: function (options) { + angular.extend(defaultOptions, options); + }, + $get: function () { + return { + options: angular.copy(defaultOptions) + }; + } + }; + }) + .directive('jqueryScrollbar', ['jQueryScrollbar', '$parse', function (jQueryScrollbar, $parse) { + return { + "restrict": "AC", + "link": function (scope, element, attrs) { + var model = $parse(attrs.jqueryScrollbar), + options = model(scope); + element.scrollbar(options || jQueryScrollbar.options) + .on('$destroy', function () { + element.scrollbar('destroy'); + }); + } + }; + }]); + })(window.angular); + } +})); diff --git a/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.min.js b/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.min.js new file mode 100755 index 0000000..14031fd --- /dev/null +++ b/assets/global/vendor/jquery-scrollbar/jquery.scrollbar.min.js @@ -0,0 +1,16 @@ +/** + * jQuery CSS Customizable Scrollbar + * + * Copyright 2015, Yuriy Khabarov + * Dual licensed under the MIT or GPL Version 2 licenses. + * + * If you found bug, please contact me via email <13real008@gmail.com> + * + * Compressed by http://jscompress.com/ + * + * @author Yuriy Khabarov aka Gromo + * @version 0.2.10 + * @url https://github.com/gromo/jquery.scrollbar/ + * + */ +!function(l,e){"function"==typeof define&&define.amd?define(["jquery"],e):e(l.jQuery)}(this,function(l){"use strict";function e(e){if(t.webkit&&!e)return{height:0,width:0};if(!t.data.outer){var o={border:"none","box-sizing":"content-box",height:"200px",margin:"0",padding:"0",width:"200px"};t.data.inner=l("
").css(l.extend({},o)),t.data.outer=l("
").css(l.extend({left:"-1000px",overflow:"scroll",position:"absolute",top:"-1000px"},o)).append(t.data.inner).appendTo("body")}return t.data.outer.scrollLeft(1e3).scrollTop(1e3),{height:Math.ceil(t.data.outer.offset().top-t.data.inner.offset().top||0),width:Math.ceil(t.data.outer.offset().left-t.data.inner.offset().left||0)}}function o(){var l=e(!0);return!(l.height||l.width)}function s(l){var e=l.originalEvent;return e.axis&&e.axis===e.HORIZONTAL_AXIS?!1:e.wheelDeltaX?!1:!0}var r=!1,t={data:{index:0,name:"scrollbar"},macosx:/mac/i.test(navigator.platform),mobile:/android|webos|iphone|ipad|ipod|blackberry/i.test(navigator.userAgent),overlay:null,scroll:null,scrolls:[],webkit:/webkit/i.test(navigator.userAgent)&&!/edge\/\d+/i.test(navigator.userAgent)};t.scrolls.add=function(l){this.remove(l).push(l)},t.scrolls.remove=function(e){for(;l.inArray(e,this)>=0;)this.splice(l.inArray(e,this),1);return this};var i={autoScrollSize:!0,autoUpdate:!0,debug:!1,disableBodyScroll:!1,duration:200,ignoreMobile:!1,ignoreOverlay:!1,scrollStep:30,showArrows:!1,stepScrolling:!0,scrollx:null,scrolly:null,onDestroy:null,onInit:null,onScroll:null,onUpdate:null},n=function(s){t.scroll||(t.overlay=o(),t.scroll=e(),a(),l(window).resize(function(){var l=!1;if(t.scroll&&(t.scroll.height||t.scroll.width)){var o=e();(o.height!==t.scroll.height||o.width!==t.scroll.width)&&(t.scroll=o,l=!0)}a(l)})),this.container=s,this.namespace=".scrollbar_"+t.data.index++,this.options=l.extend({},i,window.jQueryScrollbarOptions||{}),this.scrollTo=null,this.scrollx={},this.scrolly={},s.data(t.data.name,this),t.scrolls.add(this)};n.prototype={destroy:function(){if(this.wrapper){this.container.removeData(t.data.name),t.scrolls.remove(this);var e=this.container.scrollLeft(),o=this.container.scrollTop();this.container.insertBefore(this.wrapper).css({height:"",margin:"","max-height":""}).removeClass("scroll-content scroll-scrollx_visible scroll-scrolly_visible").off(this.namespace).scrollLeft(e).scrollTop(o),this.scrollx.scroll.removeClass("scroll-scrollx_visible").find("div").andSelf().off(this.namespace),this.scrolly.scroll.removeClass("scroll-scrolly_visible").find("div").andSelf().off(this.namespace),this.wrapper.remove(),l(document).add("body").off(this.namespace),l.isFunction(this.options.onDestroy)&&this.options.onDestroy.apply(this,[this.container])}},init:function(e){var o=this,r=this.container,i=this.containerWrapper||r,n=this.namespace,c=l.extend(this.options,e||{}),a={x:this.scrollx,y:this.scrolly},d=this.wrapper,h={scrollLeft:r.scrollLeft(),scrollTop:r.scrollTop()};if(t.mobile&&c.ignoreMobile||t.overlay&&c.ignoreOverlay||t.macosx&&!t.webkit)return!1;if(d)i.css({height:"auto","margin-bottom":-1*t.scroll.height+"px","margin-right":-1*t.scroll.width+"px","max-height":""});else{if(this.wrapper=d=l("
").addClass("scroll-wrapper").addClass(r.attr("class")).css("position","absolute"==r.css("position")?"absolute":"relative").insertBefore(r).append(r),r.is("textarea")&&(this.containerWrapper=i=l("
").insertBefore(r).append(r),d.addClass("scroll-textarea")),i.addClass("scroll-content").css({height:"auto","margin-bottom":-1*t.scroll.height+"px","margin-right":-1*t.scroll.width+"px","max-height":""}),r.on("scroll"+n,function(e){l.isFunction(c.onScroll)&&c.onScroll.call(o,{maxScroll:a.y.maxScrollOffset,scroll:r.scrollTop(),size:a.y.size,visible:a.y.visible},{maxScroll:a.x.maxScrollOffset,scroll:r.scrollLeft(),size:a.x.size,visible:a.x.visible}),a.x.isVisible&&a.x.scroll.bar.css("left",r.scrollLeft()*a.x.kx+"px"),a.y.isVisible&&a.y.scroll.bar.css("top",r.scrollTop()*a.y.kx+"px")}),d.on("scroll"+n,function(){d.scrollTop(0).scrollLeft(0)}),c.disableBodyScroll){var p=function(l){s(l)?a.y.isVisible&&a.y.mousewheel(l):a.x.isVisible&&a.x.mousewheel(l)};d.on("MozMousePixelScroll"+n,p),d.on("mousewheel"+n,p),t.mobile&&d.on("touchstart"+n,function(e){var o=e.originalEvent.touches&&e.originalEvent.touches[0]||e,s={pageX:o.pageX,pageY:o.pageY},t={left:r.scrollLeft(),top:r.scrollTop()};l(document).on("touchmove"+n,function(l){var e=l.originalEvent.targetTouches&&l.originalEvent.targetTouches[0]||l;r.scrollLeft(t.left+s.pageX-e.pageX),r.scrollTop(t.top+s.pageY-e.pageY),l.preventDefault()}),l(document).on("touchend"+n,function(){l(document).off(n)})})}l.isFunction(c.onInit)&&c.onInit.apply(this,[r])}l.each(a,function(e,t){var i=null,d=1,h="x"===e?"scrollLeft":"scrollTop",p=c.scrollStep,u=function(){var l=r[h]();r[h](l+p),1==d&&l+p>=f&&(l=r[h]()),-1==d&&f>=l+p&&(l=r[h]()),r[h]()==l&&i&&i()},f=0;t.scroll||(t.scroll=o._getScroll(c["scroll"+e]).addClass("scroll-"+e),c.showArrows&&t.scroll.addClass("scroll-element_arrows_visible"),t.mousewheel=function(l){if(!t.isVisible||"x"===e&&s(l))return!0;if("y"===e&&!s(l))return a.x.mousewheel(l),!0;var i=-1*l.originalEvent.wheelDelta||l.originalEvent.detail,n=t.size-t.visible-t.offset;return(i>0&&n>f||0>i&&f>0)&&(f+=i,0>f&&(f=0),f>n&&(f=n),o.scrollTo=o.scrollTo||{},o.scrollTo[h]=f,setTimeout(function(){o.scrollTo&&(r.stop().animate(o.scrollTo,240,"linear",function(){f=r[h]()}),o.scrollTo=null)},1)),l.preventDefault(),!1},t.scroll.on("MozMousePixelScroll"+n,t.mousewheel).on("mousewheel"+n,t.mousewheel).on("mouseenter"+n,function(){f=r[h]()}),t.scroll.find(".scroll-arrow, .scroll-element_track").on("mousedown"+n,function(s){if(1!=s.which)return!0;d=1;var n={eventOffset:s["x"===e?"pageX":"pageY"],maxScrollValue:t.size-t.visible-t.offset,scrollbarOffset:t.scroll.bar.offset()["x"===e?"left":"top"],scrollbarSize:t.scroll.bar["x"===e?"outerWidth":"outerHeight"]()},a=0,v=0;return l(this).hasClass("scroll-arrow")?(d=l(this).hasClass("scroll-arrow_more")?1:-1,p=c.scrollStep*d,f=d>0?n.maxScrollValue:0):(d=n.eventOffset>n.scrollbarOffset+n.scrollbarSize?1:n.eventOffset','
','
','
','
','
','
','
','
',"
","
",'
','
','
',"
",'
','
',"
","
","
"].join(""),simple:['
','
','
','
','
',"
","
"].join("")};return o[e]&&(e=o[e]),e||(e=o.simple),e="string"==typeof e?l(e).appendTo(this.wrapper):l(e),l.extend(e,{bar:e.find(".scroll-bar"),size:e.find(".scroll-element_size"),track:e.find(".scroll-element_track")}),e},_handleMouseDown:function(e,o){var s=this.namespace;return l(document).on("blur"+s,function(){l(document).add("body").off(s),e&&e()}),l(document).on("dragstart"+s,function(l){return l.preventDefault(),!1}),l(document).on("mouseup"+s,function(){l(document).add("body").off(s),e&&e()}),l("body").on("selectstart"+s,function(l){return l.preventDefault(),!1}),o&&o.preventDefault(),!1},_updateScroll:function(e,o){var s=this.container,r=this.containerWrapper||s,i="scroll-scroll"+e+"_visible",n="x"===e?this.scrolly:this.scrollx,c=parseInt(this.container.css("x"===e?"left":"top"),10)||0,a=this.wrapper,d=o.size,h=o.visible+c;o.isVisible=d-h>1,o.isVisible?(o.scroll.addClass(i),n.scroll.addClass(i),r.addClass(i)):(o.scroll.removeClass(i),n.scroll.removeClass(i),r.removeClass(i)),"y"===e&&(s.is("textarea")||h>d?r.css({height:h+t.scroll.height+"px","max-height":"none"}):r.css({"max-height":h+t.scroll.height+"px"})),(o.size!=s.prop("scrollWidth")||n.size!=s.prop("scrollHeight")||o.visible!=a.width()||n.visible!=a.height()||o.offset!=(parseInt(s.css("left"),10)||0)||n.offset!=(parseInt(s.css("top"),10)||0))&&(l.extend(this.scrollx,{offset:parseInt(s.css("left"),10)||0,size:s.prop("scrollWidth"),visible:a.width()}),l.extend(this.scrolly,{offset:parseInt(s.css("top"),10)||0,size:this.container.prop("scrollHeight"),visible:a.height()}),this._updateScroll("x"===e?"y":"x",n))}};var c=n;l.fn.scrollbar=function(e,o){return"string"!=typeof e&&(o=e,e="init"),"undefined"==typeof o&&(o=[]),l.isArray(o)||(o=[o]),this.not("body, .scroll-wrapper").each(function(){var s=l(this),r=s.data(t.data.name);(r||"init"===e)&&(r||(r=new c(s)),r[e]&&r[e].apply(r,o))}),this},l.fn.scrollbar.options=i;var a=function(){var l=0,e=0;return function(o){var s,i,n,c,d,h,p;for(s=0;s10?(window.console&&console.log("Scroll updates exceed 10"),a=function(){}):(clearTimeout(l),l=setTimeout(a,300))}}();window.angular&&!function(l){l.module("jQueryScrollbar",[]).provider("jQueryScrollbar",function(){var e=i;return{setOptions:function(o){l.extend(e,o)},$get:function(){return{options:l.copy(e)}}}}).directive("jqueryScrollbar",["jQueryScrollbar","$parse",function(l,e){return{restrict:"AC",link:function(o,s,r){var t=e(r.jqueryScrollbar),i=t(o);s.scrollbar(i||l.options).on("$destroy",function(){s.scrollbar("destroy")})}}}])}(window.angular)}); \ No newline at end of file diff --git a/assets/images/cryptologo/litecoin.png b/assets/images/cryptologo/litecoin.png new file mode 100644 index 0000000000000000000000000000000000000000..42fad2359ccc928f3a8a757c04f9d93a9eeeaf4d GIT binary patch literal 15138 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'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += ''; + walletDivContent += ''; + walletDivContent += 'B'; + walletDivContent += ''; + walletDivContent += '
'; + walletDivContent += ''; + walletDivContent += ''; + walletDivContent += ''; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
' + AllcoinsDataOutput.basilisk[index] + '
'; + walletDivContent += '6.584'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '3'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += ''; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += ''; + walletDivContent += '
'; + walletDivContent += '
'; + walletDivContent += ''; + + $('#wallet-widgets').html(walletDivContent); + $('.scrollbar-dynamic').scrollbar(); //Make sure widget-body has scrollbar for transactions history + $('[data-toggle="tooltip"]').tooltip(); //Make sure tooltips are working for wallet widgets and anywhere else in wallet. + //console.log(walletDivContent); + + //console.log('http://127.0.0.1:7778/api/bitcoinrpc/getaddressesbyaccount?coin=' + AllcoinsDataOutput.basilisk[index] + '&account=*'); + //$('select[data-currency="' + AllcoinsDataOutput.basilisk[index] + '"]').empty(); + $.getJSON( 'http://127.0.0.1:7778/api/bitcoinrpc/getaddressesbyaccount?coin=' + AllcoinsDataOutput.basilisk[index] + '&account=*', function( data ) { + var CoinAddrList = ''; + //console.log(data.result); + $.each(data.result, function(coin_index){ + //console.log(coin_index); + //console.log(data.result[index]); + //console.log(AllcoinsDataOutput.basilisk[index]); + CoinAddrList = ''; + + //console.log(CoinAddrList); + // Inject the whole content string into our existing HTML table + $('select[data-currency="' + AllcoinsDataOutput.basilisk[index] + '"]').append(CoinAddrList); + + }); + //console.log(data); + //console.log(data[0]);*/ + }); + }); + }, + error: function(xhr, textStatus, error) { + console.log('failed starting BitcoinDark.'); + console.log(xhr.statusText); + console.log(textStatus); + console.log(error); + //swal("Oops...", "Something went wrong!", "error"); + if (xhr.readyState == '0' ) { + toastr.error("Unable to connect to Iguana", "Account Notification") + } + } + }); } diff --git a/assets/scripts/login.js b/assets/scripts/login.js index cdb2530..63a8b1d 100644 --- a/assets/scripts/login.js +++ b/assets/scripts/login.js @@ -499,55 +499,58 @@ var Login = function() { }; var handleCoinsRunningCheck = function() { - - $.each([ 'BTC', 'BTCD' ], function( index, value ) { - var AddCoinBasiliskData = { - "poll": 100, - "active": 1, - "newcoin": value, - "startpend": 1, - "endpend": 1, - "services": 128, - "maxpeers": 16, - "RELAY": 0, - "VALIDATE": 0, - "portp2p": 14631 - } - //Start BitcoinDark in Basilisk mode - $.ajax({ - type: 'GET', - data: AddCoinBasiliskData, - url: 'http://127.0.0.1:7778/api/iguana/addcoin', - dataType: 'text', - success: function(data, textStatus, jqXHR) { - var CoinBasiliskDataOutput = JSON.parse(data); - //console.log('== Data OutPut =='); - //console.log(CoinBasiliskDataOutput); - - if (CoinBasiliskDataOutput.result === 'coin added') { - console.log('coin added'); - toastr.success(value + " started in Basilisk Mode", "Coin Notification"); - } else if (CoinBasiliskDataOutput.result === 'coin already there') { - console.log('coin already there'); - toastr.info("Looks like" + value + "already running.", "Coin Notification"); - } else if (CoinBasiliskDataOutput.result === null) { - console.log('coin already there'); - toastr.info("Looks like" + value + "already running.", "Coin Notification"); - } - }, - error: function(xhr, textStatus, error) { - console.log('failed starting BitcoinDark.'); - console.log(xhr.statusText); - console.log(textStatus); - console.log(error); - //swal("Oops...", "Something went wrong!", "error"); - if (xhr.readyState == '0' ) { - toastr.error("Unable to connect to Iguana", "Account Notification") - } + + if ( sessionStorage.getItem('IguanaActiveAccount') === null ) { + $.each([ 'BTC', 'BTCD' ], function( index, value ) { + var AddCoinBasiliskData = { + "poll": 100, + "active": 1, + "newcoin": value, + "startpend": 1, + "endpend": 1, + "services": 128, + "maxpeers": 16, + "RELAY": 0, + "VALIDATE": 0, + "portp2p": 14631 } + //Start BitcoinDark in Basilisk mode + $.ajax({ + type: 'GET', + data: AddCoinBasiliskData, + url: 'http://127.0.0.1:7778/api/iguana/addcoin', + dataType: 'text', + success: function(data, textStatus, jqXHR) { + var CoinBasiliskDataOutput = JSON.parse(data); + //console.log('== Data OutPut =='); + //console.log(CoinBasiliskDataOutput); + + if (CoinBasiliskDataOutput.result === 'coin added') { + console.log('coin added'); + toastr.success(value + " started in Basilisk Mode", "Coin Notification"); + } else if (CoinBasiliskDataOutput.result === 'coin already there') { + console.log('coin already there'); + //toastr.info("Looks like" + value + "already running.", "Coin Notification"); + } else if (CoinBasiliskDataOutput.result === null) { + console.log('coin already there'); + //toastr.info("Looks like" + value + "already running.", "Coin Notification"); + } + }, + error: function(xhr, textStatus, error) { + console.log('failed starting BitcoinDark.'); + console.log(xhr.statusText); + console.log(textStatus); + console.log(error); + //swal("Oops...", "Something went wrong!", "error"); + if (xhr.readyState == '0' ) { + toastr.error("Unable to connect to Iguana", "Account Notification") + } + } + }); }); - //return false; - }); + } + + } var handleLoginAnotherWallet = function() { @@ -588,7 +591,6 @@ var Login = function() { console.log(data.statusText); console.log(textStatus); console.log(jqXHR); - } }, error: function(xhr, textStatus, error) { @@ -598,7 +600,6 @@ var Login = function() { console.log(error); //swal("Oops...", "Something went wrong!", "error"); toastr.warning("Opps... Something went wrong!", "Account Notification") - } }); }); diff --git a/index.html b/index.html index b56c4d6..99b5ddf 100755 --- a/index.html +++ b/index.html @@ -21,6 +21,7 @@ + @@ -247,7 +248,7 @@