diff --git a/.npmignore b/.npmignore index 9e3b40848..fec953c4a 100644 --- a/.npmignore +++ b/.npmignore @@ -13,6 +13,10 @@ !dist/fineui.min.js.map !dist/fineui.ie.min.js !dist/fineui.ie.min.js.map +!dist/core.css +!dist/core.js +!dist/resource.css +!dist/resource.js !dist/utils.js !dist/utils.js.map !dist/utils.min.js diff --git a/dist/bundle.min.css b/dist/bundle.min.css deleted file mode 100644 index 875dd1e0b..000000000 --- a/dist/bundle.min.css +++ /dev/null @@ -1,2 +0,0 @@ -/*! time: 2020-11-26 11:40:31 */ -article,aside,details,figcaption,figure,footer,header,hgroup,nav,section,summary{display:block}audio,canvas,video{display:inline-block;*display:inline;*zoom:1}audio:not([controls]){display:none;height:0}[hidden]{display:none}html{font-size:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}button,html,input,select,textarea{font-family:sans-serif}a:focus{outline:thin dotted}a:active,a:hover{outline:0}h1{font-size:2em;margin:.67em 0}h2{font-size:1.5em;margin:.83em 0}h3{font-size:1.17em;margin:1em 0}h4{font-size:1em;margin:1.33em 0}h5{font-size:.83em;margin:1.67em 0}h6{font-size:.75em;margin:2.33em 0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}blockquote{margin:1em 40px}dfn{font-style:italic}mark{background:#ff0;color:#000}p,pre{margin:1em 0}code,kbd,pre,samp{font-family:monospace,serif;_font-family:courier new,monospace;font-size:1em}pre{white-space:pre;white-space:pre-wrap;word-wrap:break-word}q{quotes:none}q:after,q:before{content:"";content:none}small,sub,sup{font-size:75%}sub,sup{line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}dl,menu,ol,ul{margin:1em 0}dd{margin:0 0 0 40px}menu,ol,ul{padding:0 0 0 40px}nav ol,nav ul{list-style:none;list-style-image:none}img{border:0;-ms-interpolation-mode:bicubic}svg:not(:root){overflow:hidden}figure,form{margin:0}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0;white-space:normal;*margin-left:-7px}button,input,select,textarea{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle}button,input{line-height:normal}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer;*overflow:visible}button[disabled],input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0;*height:13px;*width:13px}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}textarea{overflow:auto;vertical-align:top}table{border-collapse:collapse;border-spacing:0}*,a,body,div,html,img,li,ol,p,span,ul{margin:0;padding:0}html{overflow:hidden}body,html{height:100%}body{position:absolute;width:100%;margin:0;padding:0;top:0;left:0;background-repeat:repeat;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;color:#3d4d66;font:normal 12px Helvetica Neue,Arial,PingFang SC,Hiragino Sans GB,Microsoft YaHei,微软雅黑,Heiti,黑体,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-decoration:none;-kthml-user-focus:normal;-moz-user-focus:normal;-moz-outline:0 none;outline:0 none}div::-webkit-scrollbar,textarea::-webkit-scrollbar{-webkit-appearance:none;width:10px;height:10px}div::-webkit-scrollbar-track,textarea::-webkit-scrollbar-track{border-radius:5px}div::-webkit-scrollbar-track,div::-webkit-scrollbar-track:hover,textarea::-webkit-scrollbar-track,textarea::-webkit-scrollbar-track:hover{background-color:rgba(35,46,64,.05);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0d232e40,endColorstr=#0d232e40)}div::-webkit-scrollbar-thumb,textarea::-webkit-scrollbar-thumb{border:2px solid transparent;background-clip:padding-box;border-radius:10px;background-color:rgba(35,46,64,.1);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#1a232e40,endColorstr=#1a232e40)}div::-webkit-scrollbar-thumb:hover,textarea::-webkit-scrollbar-thumb:hover{background-color:rgba(35,46,64,.3);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#4d232e40,endColorstr=#4d232e40)}div::-webkit-scrollbar-corner,textarea::-webkit-scrollbar-corner{background-color:transparent}a{outline:none;text-decoration:none}a:focus{outline:0}div:focus{outline:none}input::-webkit-contacts-auto-fill-button{visibility:hidden;display:none!important;pointer-events:none;position:absolute;right:0}input::-ms-clear{display:none}input,textarea{margin:0;padding:0;outline:none}ul{list-style:disc}li{list-style-type:none}i{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.anim-rotate{-webkit-animation:rotate 1s linear infinite both;animation:rotate 1s linear infinite both}@-webkit-keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}input,textarea{border:1px solid #e8eaed}.bi-theme-dark input,.bi-theme-dark textarea{border:1px solid #363e55}.base-disabled{cursor:not-allowed!important}.base-disabled,.base-disabled .bi-input,.base-disabled .bi-textarea{color:#9ea6b2!important}.base-disabled .b-font:before{color:#d0d4da!important}.bi-theme-dark .base-disabled,.bi-theme-dark .base-disabled .bi-input,.bi-theme-dark .base-disabled .bi-textarea{color:#878d9f!important}.bi-theme-dark .base-disabled .b-font:before{color:#606479!important}.bi-focus-shadow:focus,.bi-focus-shadow:hover{border-color:#3685f2}.bi-focus-shadow:focus-within{border-color:#3685f2}.bi-focus-shadow.disabled:hover{border-color:#e8eaed}.bi-theme-dark .bi-focus-shadow.disabled:hover{border-color:#363e55}.base-invalid{cursor:default!important}.clearfix{*zoom:1}.clearfix:after,.clearfix:before{content:" ";display:table;line-height:0}.clearfix:after{clear:both}.bi-background{background-color:#f7f8fa;color:#3d4d66}.bi-background .bi-input,.bi-background .bi-textarea{color:#3d4d66}.bi-theme-dark .bi-background{background-color:#191b2b;color:#d6e0dc}.bi-theme-dark .bi-background .bi-input,.bi-theme-dark .bi-background .bi-textarea{color:#d6e0dc}.bi-header-background{background-color:#f2f4f7;color:#647185}.bi-header-background .bi-input,.bi-header-background .bi-textarea{color:#647185}.bi-theme-dark .bi-header-background{background-color:#292f45;color:#afb7c6}.bi-theme-dark .bi-header-background .bi-input,.bi-theme-dark .bi-header-background .bi-textarea{color:#afb7c6}.bi-card{background-color:#fff}.bi-card,.bi-card .bi-input,.bi-card .bi-textarea{color:#3d4d66}.bi-theme-dark .bi-card{background-color:#20263b;color:#d6e0dc}.bi-theme-dark .bi-card .bi-input,.bi-theme-dark .bi-card .bi-textarea{color:#d6e0dc}.bi-disabled,.bi-disabled .bi-input,.bi-disabled .bi-textarea{color:#9ea6b2}.bi-theme-dark .bi-disabled,.bi-theme-dark .bi-disabled .bi-input,.bi-theme-dark .bi-disabled .bi-textarea{color:#878d9f}.bi-tips,.bi-tips .bi-input,.bi-tips .bi-textarea{color:#9ea6b2}.bi-border{border:1px solid #e8eaed}.bi-border.disabled{border-color:#e8eaed!important}.bi-border-top{border-top:1px solid #e8eaed}.bi-border-top.disabled{border-color:#e8eaed!important}.bi-border-right{border-right:1px solid #e8eaed}.bi-border-right.disabled{border-color:#e8eaed!important}.bi-border-bottom{border-bottom:1px solid #e8eaed}.bi-border-bottom.disabled{border-color:#e8eaed!important}.bi-border-left{border-left:1px solid #e8eaed}.bi-border-left.disabled{border-color:#e8eaed!important}.bi-theme-dark .bi-border{border:1px solid #363e55}.bi-theme-dark .bi-border.disabled{border-color:#363e55!important}.bi-theme-dark .bi-border-top{border-top:1px solid #363e55}.bi-theme-dark .bi-border-top.disabled{border-color:#363e55!important}.bi-theme-dark .bi-border-right{border-right:1px solid #363e55}.bi-theme-dark .bi-border-right.disabled{border-color:#363e55!important}.bi-theme-dark .bi-border-bottom{border-bottom:1px solid #363e55}.bi-theme-dark .bi-border-bottom.disabled{border-color:#363e55!important}.bi-theme-dark .bi-border-left{border-left:1px solid #363e55}.bi-theme-dark .bi-border-left.disabled{border-color:#363e55!important}.bi-split{border:1px solid #f2f4f7}.bi-split-top{border-top:1px solid #f2f4f7}.bi-split-right{border-right:1px solid #f2f4f7}.bi-split-bottom{border-bottom:1px solid #f2f4f7}.bi-split-left{border-left:1px solid #f2f4f7}.bi-theme-dark .bi-split{border:1px solid #292f45}.bi-theme-dark .bi-split-top{border-top:1px solid #292f45}.bi-theme-dark .bi-split-right{border-right:1px solid #292f45}.bi-theme-dark .bi-split-bottom{border-bottom:1px solid #292f45}.bi-theme-dark .bi-split-left{border-left:1px solid #292f45}.bi-font-helvetica-neue{font-family:Helvetica Neue,Arial,Verdana,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Heiti,serif}.bi-font-verdana{font-family:Verdana,Helvetica Neue,Arial,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Heiti,serif}.bi-font-arial{font-family:Arial,Helvetica Neue,Verdana,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Heiti,serif}.bi-font-PingFang{font-family:PingFang SC,Helvetica Neue,Verdana,Arial,Hiragino Sans GB,Microsoft YaHei,Heiti,serif}.bi-font-hiragino-sans{font-family:Hiragino Sans GB,Helvetica Neue,Verdana,Arial,PingFang SC,Microsoft YaHei,Heiti,serif}.bi-font-microsoft-yaHei{font-family:Microsoft YaHei,Helvetica Neue,Verdana,Arial,PingFang SC,Hiragino Sans GB,Heiti,serif}.bi-font-heiti{font-family:Heiti,Helvetica Neue,Verdana,Arial,PingFang SC,Hiragino Sans GB,Microsoft YaHei,serif}.bi-border-radius{border-radius:2px}.bi-font-bold{font-weight:700}.bi-keyword-red-mark,.bi-keyword-red-mark .bi-input,.bi-keyword-red-mark .bi-textarea{color:#faaa39}.bi-high-light,.bi-high-light .bi-input,.bi-high-light .bi-textarea{color:#3685f2}.bi-error,.bi-error .bi-input,.bi-error .bi-textarea{color:#e65251}.bi-high-light-background{background-color:#3685f2;color:#fff}.bi-high-light-background .bi-input,.bi-high-light-background .bi-textarea{color:#fff}.bi-error-background{background-color:#e65251;color:#fff}.bi-error-background .bi-input,.bi-error-background .bi-textarea{color:#fff}.bi-high-light-border{border:1px solid #3685f2}.bi-high-light-border.disabled{border-color:#e8eaed!important}.bi-high-light-border-top{border-top:1px solid #3685f2}.bi-high-light-border-top.disabled{border-color:#e8eaed!important}.bi-high-light-border-right{border-right:1px solid #3685f2}.bi-high-light-border-right.disabled{border-color:#e8eaed!important}.bi-high-light-border-bottom{border-bottom:1px solid #3685f2}.bi-high-light-border-bottom.disabled{border-color:#e8eaed!important}.bi-high-light-border-left{border-left:1px solid #3685f2}.bi-high-light-border-left.disabled{border-color:#e8eaed!important}.bi-water-mark{color:#9ea6b2;cursor:text}.bi-water-mark .bi-input,.bi-water-mark .bi-textarea{color:#9ea6b2}.bi-theme-dark .bi-water-mark,.bi-theme-dark .bi-water-mark .bi-input,.bi-theme-dark .bi-water-mark .bi-textarea{color:#6b7084}.bi-resizer{background:#232e40;opacity:.2;filter:alpha(opacity=20);z-index:1000000000!important}.bi-theme-dark .bi-resizer{background:#fff}.bi-mask{background-color:rgba(35,46,64,.2);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#33232e40,endColorstr=#33232e40)}.bi-mask,.bi-mask .bi-input,.bi-mask .bi-textarea{color:#fff}.bi-theme-dark .bi-mask{color:#20263b;background-color:hsla(0,0%,100%,.2);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#33ffffff,endColorstr=#33ffffff)}.bi-theme-dark .bi-mask .bi-input,.bi-theme-dark .bi-mask .bi-textarea{color:#20263b}.bi-z-index-mask{background-color:rgba(35,46,64,.5);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#80232e40,endColorstr=#80232e40)}.bi-theme-dark .bi-z-index-mask{background-color:rgba(96,100,121,.5);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#80606479,endColorstr=#80606479)}.bi-list-item.hover,.bi-list-item:hover{color:#232e40;background-color:rgba(54,133,242,.05);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0d3685f2,endColorstr=#0d3685f2)}.bi-list-item.hover .bi-input,.bi-list-item.hover .bi-textarea,.bi-list-item:hover .bi-input,.bi-list-item:hover .bi-textarea{color:#232e40}.bi-list-item.disabled,.bi-list-item.disabled:active,.bi-list-item.disabled:hover{background-color:transparent!important;color:#9ea6b2!important}.bi-list-item.disabled .bi-high-light,.bi-list-item.disabled .bi-input,.bi-list-item.disabled .bi-textarea,.bi-list-item.disabled:active .bi-high-light,.bi-list-item.disabled:active .bi-input,.bi-list-item.disabled:active .bi-textarea,.bi-list-item.disabled:hover .bi-high-light,.bi-list-item.disabled:hover .bi-input,.bi-list-item.disabled:hover .bi-textarea{color:#9ea6b2!important}.bi-theme-dark .bi-list-item.hover,.bi-theme-dark .bi-list-item:hover{color:#fff;background-color:rgba(54,133,242,.05);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0d3685f2,endColorstr=#0d3685f2)}.bi-theme-dark .bi-list-item.hover .bi-input,.bi-theme-dark .bi-list-item.hover .bi-textarea,.bi-theme-dark .bi-list-item:hover .bi-input,.bi-theme-dark .bi-list-item:hover .bi-textarea{color:#fff}.bi-theme-dark .bi-list-item.disabled,.bi-theme-dark .bi-list-item.disabled:active,.bi-theme-dark .bi-list-item.disabled:hover{background-color:transparent!important;color:#878d9f!important}.bi-theme-dark .bi-list-item.disabled .bi-high-light,.bi-theme-dark .bi-list-item.disabled .bi-input,.bi-theme-dark .bi-list-item.disabled .bi-textarea,.bi-theme-dark .bi-list-item.disabled:active .bi-high-light,.bi-theme-dark .bi-list-item.disabled:active .bi-input,.bi-theme-dark .bi-list-item.disabled:active .bi-textarea,.bi-theme-dark .bi-list-item.disabled:hover .bi-high-light,.bi-theme-dark .bi-list-item.disabled:hover .bi-input,.bi-theme-dark .bi-list-item.disabled:hover .bi-textarea{color:#878d9f!important}.bi-list-item-border.active,.bi-list-item-border:active{border:1px solid #3685f2}.bi-list-item-simple.hover,.bi-list-item-simple.hover .bi-input,.bi-list-item-simple.hover .bi-textarea,.bi-list-item-simple:hover,.bi-list-item-simple:hover .bi-input,.bi-list-item-simple:hover .bi-textarea{color:#3685f2}.bi-list-item-simple.disabled,.bi-list-item-simple.disabled .bi-high-light,.bi-list-item-simple.disabled .bi-input,.bi-list-item-simple.disabled .bi-textarea,.bi-list-item-simple.disabled:active,.bi-list-item-simple.disabled:active .bi-high-light,.bi-list-item-simple.disabled:active .bi-input,.bi-list-item-simple.disabled:active .bi-textarea,.bi-list-item-simple.disabled:hover,.bi-list-item-simple.disabled:hover .bi-high-light,.bi-list-item-simple.disabled:hover .bi-input,.bi-list-item-simple.disabled:hover .bi-textarea{color:#9ea6b2!important}.bi-list-item-effect:hover,.bi-list-item-effect:hover .bi-input,.bi-list-item-effect:hover .bi-textarea{color:#232e40}.bi-list-item-effect.active,.bi-list-item-effect.active .bi-input,.bi-list-item-effect.active .bi-textarea,.bi-list-item-effect:active,.bi-list-item-effect:active .bi-input,.bi-list-item-effect:active .bi-textarea{color:#3685f2}.bi-list-item-effect.disabled,.bi-list-item-effect.disabled .bi-high-light,.bi-list-item-effect.disabled .bi-input,.bi-list-item-effect.disabled .bi-textarea,.bi-list-item-effect.disabled:active,.bi-list-item-effect.disabled:active .bi-high-light,.bi-list-item-effect.disabled:active .bi-input,.bi-list-item-effect.disabled:active .bi-textarea,.bi-list-item-effect.disabled:hover,.bi-list-item-effect.disabled:hover .bi-high-light,.bi-list-item-effect.disabled:hover .bi-input,.bi-list-item-effect.disabled:hover .bi-textarea{color:#9ea6b2!important}.bi-theme-dark .bi-list-item-effect:hover,.bi-theme-dark .bi-list-item-effect:hover .bi-input,.bi-theme-dark .bi-list-item-effect:hover .bi-textarea{color:#fff}.bi-theme-dark .bi-list-item-effect.active,.bi-theme-dark .bi-list-item-effect.active .bi-input,.bi-theme-dark .bi-list-item-effect.active .bi-textarea,.bi-theme-dark .bi-list-item-effect:active,.bi-theme-dark .bi-list-item-effect:active .bi-input,.bi-theme-dark .bi-list-item-effect:active .bi-textarea{color:#3685f2}.bi-theme-dark .bi-list-item-effect.disabled,.bi-theme-dark .bi-list-item-effect.disabled:active,.bi-theme-dark .bi-list-item-effect.disabled:hover{background-color:transparent!important;color:#878d9f!important}.bi-theme-dark .bi-list-item-effect.disabled .bi-high-light,.bi-theme-dark .bi-list-item-effect.disabled .bi-input,.bi-theme-dark .bi-list-item-effect.disabled .bi-textarea,.bi-theme-dark .bi-list-item-effect.disabled:active .bi-high-light,.bi-theme-dark .bi-list-item-effect.disabled:active .bi-input,.bi-theme-dark .bi-list-item-effect.disabled:active .bi-textarea,.bi-theme-dark .bi-list-item-effect.disabled:hover .bi-high-light,.bi-theme-dark .bi-list-item-effect.disabled:hover .bi-input,.bi-theme-dark .bi-list-item-effect.disabled:hover .bi-textarea{color:#878d9f!important}.bi-list-item-active.hover,.bi-list-item-active:hover{color:#232e40;background-color:rgba(54,133,242,.06);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0f3685f2,endColorstr=#0f3685f2)}.bi-list-item-active.hover .bi-input,.bi-list-item-active.hover .bi-textarea,.bi-list-item-active:hover .bi-input,.bi-list-item-active:hover .bi-textarea{color:#232e40}.bi-list-item-active:active{color:#3685f2;background-color:rgba(54,133,242,.06);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0f3685f2,endColorstr=#0f3685f2)}.bi-list-item-active.active,.bi-list-item-active.active .bi-input,.bi-list-item-active.active .bi-textarea,.bi-list-item-active:active .bi-input,.bi-list-item-active:active .bi-textarea{color:#3685f2}.bi-list-item-active.disabled,.bi-list-item-active.disabled:active,.bi-list-item-active.disabled:hover{background-color:transparent!important;color:#9ea6b2!important}.bi-list-item-active.disabled .bi-high-light,.bi-list-item-active.disabled .bi-input,.bi-list-item-active.disabled .bi-textarea,.bi-list-item-active.disabled:active .bi-high-light,.bi-list-item-active.disabled:active .bi-input,.bi-list-item-active.disabled:active .bi-textarea,.bi-list-item-active.disabled:hover .bi-high-light,.bi-list-item-active.disabled:hover .bi-input,.bi-list-item-active.disabled:hover .bi-textarea{color:#9ea6b2!important}.bi-theme-dark .bi-list-item-active.hover,.bi-theme-dark .bi-list-item-active:hover{color:#fff;background-color:hsla(0,0%,100%,.05);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0dffffff,endColorstr=#0dffffff)}.bi-theme-dark .bi-list-item-active.hover .bi-input,.bi-theme-dark .bi-list-item-active.hover .bi-textarea,.bi-theme-dark .bi-list-item-active:hover .bi-input,.bi-theme-dark .bi-list-item-active:hover .bi-textarea{color:#fff}.bi-theme-dark .bi-list-item-active.active,.bi-theme-dark .bi-list-item-active:active{color:#3685f2;background-color:hsla(0,0%,100%,.05);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0dffffff,endColorstr=#0dffffff)}.bi-theme-dark .bi-list-item-active.active .bi-input,.bi-theme-dark .bi-list-item-active.active .bi-textarea,.bi-theme-dark .bi-list-item-active:active .bi-input,.bi-theme-dark .bi-list-item-active:active .bi-textarea{color:#3685f2}.bi-theme-dark .bi-list-item-active.disabled,.bi-theme-dark .bi-list-item-active.disabled:active,.bi-theme-dark .bi-list-item-active.disabled:hover{background-color:transparent!important;color:#878d9f!important}.bi-theme-dark .bi-list-item-active.disabled .bi-high-light,.bi-theme-dark .bi-list-item-active.disabled .bi-input,.bi-theme-dark .bi-list-item-active.disabled .bi-textarea,.bi-theme-dark .bi-list-item-active.disabled:active .bi-high-light,.bi-theme-dark .bi-list-item-active.disabled:active .bi-input,.bi-theme-dark .bi-list-item-active.disabled:active .bi-textarea,.bi-theme-dark .bi-list-item-active.disabled:hover .bi-high-light,.bi-theme-dark .bi-list-item-active.disabled:hover .bi-input,.bi-theme-dark .bi-list-item-active.disabled:hover .bi-textarea{color:#878d9f!important}.bi-list-item-active2.hover,.bi-list-item-active2:hover{color:#232e40;background-color:rgba(54,133,242,.06);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0f3685f2,endColorstr=#0f3685f2)}.bi-list-item-active2.hover .bi-input,.bi-list-item-active2.hover .bi-textarea,.bi-list-item-active2:hover .bi-input,.bi-list-item-active2:hover .bi-textarea{color:#232e40}.bi-list-item-active2.active,.bi-list-item-active2:active{color:#3685f2;background-color:rgba(54,133,242,.06);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0f3685f2,endColorstr=#0f3685f2)}.bi-list-item-active2.active .bi-input,.bi-list-item-active2.active .bi-textarea,.bi-list-item-active2:active .bi-input,.bi-list-item-active2:active .bi-textarea{color:#3685f2}.bi-list-item-active2.disabled,.bi-list-item-active2.disabled:active,.bi-list-item-active2.disabled:hover{background-color:transparent!important;color:#9ea6b2!important}.bi-list-item-active2.disabled .bi-high-light,.bi-list-item-active2.disabled .bi-input,.bi-list-item-active2.disabled .bi-textarea,.bi-list-item-active2.disabled:active .bi-high-light,.bi-list-item-active2.disabled:active .bi-input,.bi-list-item-active2.disabled:active .bi-textarea,.bi-list-item-active2.disabled:hover .bi-high-light,.bi-list-item-active2.disabled:hover .bi-input,.bi-list-item-active2.disabled:hover .bi-textarea{color:#9ea6b2!important}.bi-theme-dark .bi-list-item-active2.hover,.bi-theme-dark .bi-list-item-active2:hover{color:#fff;background-color:rgba(54,133,242,.06);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0f3685f2,endColorstr=#0f3685f2)}.bi-theme-dark .bi-list-item-active2.hover .bi-input,.bi-theme-dark .bi-list-item-active2.hover .bi-textarea,.bi-theme-dark .bi-list-item-active2:hover .bi-input,.bi-theme-dark .bi-list-item-active2:hover .bi-textarea{color:#fff}.bi-theme-dark .bi-list-item-active2.active,.bi-theme-dark .bi-list-item-active2:active{color:#3685f2;background-color:rgba(54,133,242,.06);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0f3685f2,endColorstr=#0f3685f2)}.bi-theme-dark .bi-list-item-active2.active .bi-input,.bi-theme-dark .bi-list-item-active2.active .bi-textarea,.bi-theme-dark .bi-list-item-active2:active .bi-input,.bi-theme-dark .bi-list-item-active2:active .bi-textarea{color:#3685f2}.bi-theme-dark .bi-list-item-active2.disabled,.bi-theme-dark .bi-list-item-active2.disabled:active,.bi-theme-dark .bi-list-item-active2.disabled:hover{background-color:transparent!important;color:#878d9f!important}.bi-theme-dark .bi-list-item-active2.disabled .bi-high-light,.bi-theme-dark .bi-list-item-active2.disabled .bi-input,.bi-theme-dark .bi-list-item-active2.disabled .bi-textarea,.bi-theme-dark .bi-list-item-active2.disabled:active .bi-high-light,.bi-theme-dark .bi-list-item-active2.disabled:active .bi-input,.bi-theme-dark .bi-list-item-active2.disabled:active .bi-textarea,.bi-theme-dark .bi-list-item-active2.disabled:hover .bi-high-light,.bi-theme-dark .bi-list-item-active2.disabled:hover .bi-input,.bi-theme-dark .bi-list-item-active2.disabled:hover .bi-textarea{color:#878d9f!important}.bi-list-item-select.hover,.bi-list-item-select:hover{background-color:rgba(54,133,242,.06);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0f3685f2,endColorstr=#0f3685f2)}.bi-list-item-select.active,.bi-list-item-select:active{color:#fff;background-color:#3685f2}.bi-list-item-select.active .bi-high-light,.bi-list-item-select.active .bi-input,.bi-list-item-select.active .bi-textarea,.bi-list-item-select:active .bi-high-light,.bi-list-item-select:active .bi-input,.bi-list-item-select:active .bi-textarea{color:#fff}.bi-list-item-select.button-success.active,.bi-list-item-select.button-success:active{color:#fff;background-color:#13cd66}.bi-list-item-select.button-success.active .bi-high-light,.bi-list-item-select.button-success.active .bi-input,.bi-list-item-select.button-success.active .bi-textarea,.bi-list-item-select.button-success:active .bi-high-light,.bi-list-item-select.button-success:active .bi-input,.bi-list-item-select.button-success:active .bi-textarea{color:#fff}.bi-list-item-select.button-success.active.bi-high-light-border,.bi-list-item-select.button-success:active.bi-high-light-border{border-color:#13cd66}.bi-list-item-select.button-warning,.bi-list-item-select.button-warning .bi-high-light,.bi-list-item-select.button-warning .bi-input,.bi-list-item-select.button-warning .bi-textarea{color:#e65251}.bi-list-item-select.button-warning.bi-high-light-border{border-color:#e65251}.bi-list-item-select.button-warning.hover,.bi-list-item-select.button-warning:hover{color:#e65251;background-color:#ffecec}.bi-list-item-select.button-warning.hover .bi-high-light,.bi-list-item-select.button-warning.hover .bi-input,.bi-list-item-select.button-warning.hover .bi-textarea,.bi-list-item-select.button-warning:hover .bi-high-light,.bi-list-item-select.button-warning:hover .bi-input,.bi-list-item-select.button-warning:hover .bi-textarea{color:#e65251}.bi-list-item-select.button-warning.hover.bi-high-light-border,.bi-list-item-select.button-warning:hover.bi-high-light-border{border-color:#e65251}.bi-list-item-select.button-warning.active,.bi-list-item-select.button-warning:active{color:#fff;background-color:#e65251}.bi-list-item-select.button-warning.active .bi-high-light,.bi-list-item-select.button-warning.active .bi-input,.bi-list-item-select.button-warning.active .bi-textarea,.bi-list-item-select.button-warning:active .bi-high-light,.bi-list-item-select.button-warning:active .bi-input,.bi-list-item-select.button-warning:active .bi-textarea{color:#fff}.bi-list-item-select.button-warning.active.bi-high-light-border,.bi-list-item-select.button-warning:active.bi-high-light-border{border-color:#e65251}.bi-list-item-select.disabled,.bi-list-item-select.disabled:active,.bi-list-item-select.disabled:hover{color:#9ea6b2!important;background-color:transparent!important}.bi-list-item-select.disabled .bi-high-light,.bi-list-item-select.disabled .bi-input,.bi-list-item-select.disabled .bi-textarea,.bi-list-item-select.disabled:active .bi-high-light,.bi-list-item-select.disabled:active .bi-input,.bi-list-item-select.disabled:active .bi-textarea,.bi-list-item-select.disabled:hover .bi-high-light,.bi-list-item-select.disabled:hover .bi-input,.bi-list-item-select.disabled:hover .bi-textarea{color:#9ea6b2!important}.bi-list-item-select.disabled.bi-high-light-border,.bi-list-item-select.disabled:active.bi-high-light-border,.bi-list-item-select.disabled:hover.bi-high-light-border{border-color:#e8eaed}.bi-list-item-select.disabled.active,.bi-list-item-select.disabled.hover,.bi-list-item-select.disabled:active.active,.bi-list-item-select.disabled:active.hover,.bi-list-item-select.disabled:hover.active,.bi-list-item-select.disabled:hover.hover{color:#fff!important;background-color:#d0d4da!important}.bi-list-item-select.disabled.active .bi-input,.bi-list-item-select.disabled.active .bi-textarea,.bi-list-item-select.disabled.hover .bi-input,.bi-list-item-select.disabled.hover .bi-textarea,.bi-list-item-select.disabled:active.active .bi-input,.bi-list-item-select.disabled:active.active .bi-textarea,.bi-list-item-select.disabled:active.hover .bi-input,.bi-list-item-select.disabled:active.hover .bi-textarea,.bi-list-item-select.disabled:hover.active .bi-input,.bi-list-item-select.disabled:hover.active .bi-textarea,.bi-list-item-select.disabled:hover.hover .bi-input,.bi-list-item-select.disabled:hover.hover .bi-textarea{color:#fff!important}.bi-list-item-select.disabled.active .bi-high-light,.bi-list-item-select.disabled.hover .bi-high-light,.bi-list-item-select.disabled:active.active .bi-high-light,.bi-list-item-select.disabled:active.hover .bi-high-light,.bi-list-item-select.disabled:hover.active .bi-high-light,.bi-list-item-select.disabled:hover.hover .bi-high-light{color:#9ea6b2!important}.bi-list-item-select.disabled.active.bi-high-light-border,.bi-list-item-select.disabled.hover.bi-high-light-border,.bi-list-item-select.disabled:active.active.bi-high-light-border,.bi-list-item-select.disabled:active.hover.bi-high-light-border,.bi-list-item-select.disabled:hover.active.bi-high-light-border,.bi-list-item-select.disabled:hover.hover.bi-high-light-border{border-color:#e8eaed}.bi-theme-dark .bi-list-item-select.hover,.bi-theme-dark .bi-list-item-select:hover{color:#fff;background-color:hsla(0,0%,100%,.05);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0dffffff,endColorstr=#0dffffff)}.bi-theme-dark .bi-list-item-select.hover .bi-input,.bi-theme-dark .bi-list-item-select.hover .bi-textarea,.bi-theme-dark .bi-list-item-select:hover .bi-input,.bi-theme-dark .bi-list-item-select:hover .bi-textarea{color:#fff}.bi-theme-dark .bi-list-item-select.active,.bi-theme-dark .bi-list-item-select:active{color:#fff;background-color:#3685f2}.bi-theme-dark .bi-list-item-select.active .bi-high-light,.bi-theme-dark .bi-list-item-select.active .bi-input,.bi-theme-dark .bi-list-item-select.active .bi-textarea,.bi-theme-dark .bi-list-item-select:active .bi-high-light,.bi-theme-dark .bi-list-item-select:active .bi-input,.bi-theme-dark .bi-list-item-select:active .bi-textarea{color:#fff}.bi-theme-dark .bi-list-item-select.disabled,.bi-theme-dark .bi-list-item-select.disabled:active,.bi-theme-dark .bi-list-item-select.disabled:hover{background-color:transparent!important;color:#878d9f!important}.bi-theme-dark .bi-list-item-select.disabled .bi-high-light,.bi-theme-dark .bi-list-item-select.disabled .bi-input,.bi-theme-dark .bi-list-item-select.disabled .bi-textarea,.bi-theme-dark .bi-list-item-select.disabled:active .bi-high-light,.bi-theme-dark .bi-list-item-select.disabled:active .bi-input,.bi-theme-dark .bi-list-item-select.disabled:active .bi-textarea,.bi-theme-dark .bi-list-item-select.disabled:hover .bi-high-light,.bi-theme-dark .bi-list-item-select.disabled:hover .bi-input,.bi-theme-dark .bi-list-item-select.disabled:hover .bi-textarea{color:#878d9f!important}.bi-theme-dark .bi-list-item-select.disabled.active,.bi-theme-dark .bi-list-item-select.disabled.hover{background-color:#606479!important}.bi-list-item-select2.hover,.bi-list-item-select2.hover .bi-input,.bi-list-item-select2.hover .bi-textarea,.bi-list-item-select2:hover,.bi-list-item-select2:hover .bi-input,.bi-list-item-select2:hover .bi-textarea{color:#232e40}.bi-list-item-select2.hover.bi-border,.bi-list-item-select2:hover.bi-border{border-color:#3685f2}.bi-list-item-select2:active,.bi-list-item-select2:active .bi-input,.bi-list-item-select2:active .bi-textarea{color:#3685f2}.bi-list-item-select2:active.bi-border{border-color:#3685f2}.bi-list-item-select2.active{color:#fff;background-color:#3685f2}.bi-list-item-select2.active .bi-input,.bi-list-item-select2.active .bi-textarea{color:#fff}.bi-list-item-select2.active.bi-border{border-color:#3685f2}.bi-list-item-select2.disabled,.bi-list-item-select2.disabled:active,.bi-list-item-select2.disabled:hover{background-color:transparent!important;color:#9ea6b2!important}.bi-list-item-select2.disabled .bi-high-light,.bi-list-item-select2.disabled .bi-input,.bi-list-item-select2.disabled .bi-textarea,.bi-list-item-select2.disabled:active .bi-high-light,.bi-list-item-select2.disabled:active .bi-input,.bi-list-item-select2.disabled:active .bi-textarea,.bi-list-item-select2.disabled:hover .bi-high-light,.bi-list-item-select2.disabled:hover .bi-input,.bi-list-item-select2.disabled:hover .bi-textarea{color:#9ea6b2!important}.bi-theme-dark .bi-list-item-select2.hover,.bi-theme-dark .bi-list-item-select2.hover .bi-input,.bi-theme-dark .bi-list-item-select2.hover .bi-textarea,.bi-theme-dark .bi-list-item-select2:hover,.bi-theme-dark .bi-list-item-select2:hover .bi-input,.bi-theme-dark .bi-list-item-select2:hover .bi-textarea{color:#fff}.bi-theme-dark .bi-list-item-select2.active{background-color:#20263b}.bi-theme-dark .bi-list-item-select2.disabled,.bi-theme-dark .bi-list-item-select2.disabled:active,.bi-theme-dark .bi-list-item-select2.disabled:hover{background-color:transparent!important;color:#878d9f!important}.bi-theme-dark .bi-list-item-select2.disabled .bi-high-light,.bi-theme-dark .bi-list-item-select2.disabled .bi-input,.bi-theme-dark .bi-list-item-select2.disabled .bi-textarea,.bi-theme-dark .bi-list-item-select2.disabled:active .bi-high-light,.bi-theme-dark .bi-list-item-select2.disabled:active .bi-input,.bi-theme-dark .bi-list-item-select2.disabled:active .bi-textarea,.bi-theme-dark .bi-list-item-select2.disabled:hover .bi-high-light,.bi-theme-dark .bi-list-item-select2.disabled:hover .bi-input,.bi-theme-dark .bi-list-item-select2.disabled:hover .bi-textarea{color:#878d9f!important}.bi-theme-dark .bi-list-item-select2.disabled.active{background-color:#606479!important}.bi-list-item-select3.hover,.bi-list-item-select3:hover{background-color:#f7f8fa}.bi-list-item-select3.active,.bi-list-item-select3:active{color:#3685f2;background-color:#f7f8fa}.bi-list-item-select3.active .bi-input,.bi-list-item-select3.active .bi-textarea,.bi-list-item-select3:active .bi-input,.bi-list-item-select3:active .bi-textarea{color:#3685f2}.bi-list-item-select3.disabled.active,.bi-list-item-select3.disabled.hover,.bi-list-item-select3.disabled:active,.bi-list-item-select3.disabled:hover{background-color:#fff!important}.bi-theme-dark .bi-list-item-select3.hover,.bi-theme-dark .bi-list-item-select3:hover{background-color:#191b2b}.bi-theme-dark .bi-list-item-select3.active,.bi-theme-dark .bi-list-item-select3:active{color:#3685f2;background-color:#191b2b}.bi-theme-dark .bi-list-item-select3.active .bi-input,.bi-theme-dark .bi-list-item-select3.active .bi-textarea,.bi-theme-dark .bi-list-item-select3:active .bi-input,.bi-theme-dark .bi-list-item-select3:active .bi-textarea{color:#3685f2}.bi-theme-dark .bi-list-item-select3.disabled.active,.bi-theme-dark .bi-list-item-select3.disabled.hover,.bi-theme-dark .bi-list-item-select3.disabled:active,.bi-theme-dark .bi-list-item-select3.disabled:hover{background-color:#20263b!important}.bi-list-item-none.hover,.bi-list-item-none:hover{color:inherit;background-color:transparent}.bi-list-item-none.hover .bi-input,.bi-list-item-none.hover .bi-textarea,.bi-list-item-none:hover .bi-input,.bi-list-item-none:hover .bi-textarea{color:inherit}.bi-list-item-none.active,.bi-list-item-none:active{color:inherit;background-color:transparent}.bi-list-item-none.active .bi-high-light,.bi-list-item-none.active .bi-input,.bi-list-item-none.active .bi-textarea,.bi-list-item-none:active .bi-high-light,.bi-list-item-none:active .bi-input,.bi-list-item-none:active .bi-textarea{color:inherit}.bi-list-item-none.disabled,.bi-list-item-none.disabled:active,.bi-list-item-none.disabled:hover{color:#9ea6b2!important;background-color:transparent!important}.bi-list-item-none.disabled .bi-high-light,.bi-list-item-none.disabled .bi-input,.bi-list-item-none.disabled .bi-textarea,.bi-list-item-none.disabled:active .bi-high-light,.bi-list-item-none.disabled:active .bi-input,.bi-list-item-none.disabled:active .bi-textarea,.bi-list-item-none.disabled:hover .bi-high-light,.bi-list-item-none.disabled:hover .bi-input,.bi-list-item-none.disabled:hover .bi-textarea{color:#9ea6b2!important}.bi-theme-dark .bi-list-item-none.hover,.bi-theme-dark .bi-list-item-none:hover{color:inherit;background-color:transparent}.bi-theme-dark .bi-list-item-none.hover .bi-input,.bi-theme-dark .bi-list-item-none.hover .bi-textarea,.bi-theme-dark .bi-list-item-none:hover .bi-input,.bi-theme-dark .bi-list-item-none:hover .bi-textarea{color:inherit}.bi-theme-dark .bi-list-item-none.active,.bi-theme-dark .bi-list-item-none:active{color:inherit;background-color:transparent}.bi-theme-dark .bi-list-item-none.active .bi-high-light,.bi-theme-dark .bi-list-item-none.active .bi-input,.bi-theme-dark .bi-list-item-none.active .bi-textarea,.bi-theme-dark .bi-list-item-none:active .bi-high-light,.bi-theme-dark .bi-list-item-none:active .bi-input,.bi-theme-dark .bi-list-item-none:active .bi-textarea{color:inherit}.bi-theme-dark .bi-list-item-none.disabled,.bi-theme-dark .bi-list-item-none.disabled:active,.bi-theme-dark .bi-list-item-none.disabled:hover{background-color:transparent!important;color:#878d9f!important}.bi-theme-dark .bi-list-item-none.disabled .bi-high-light,.bi-theme-dark .bi-list-item-none.disabled .bi-input,.bi-theme-dark .bi-list-item-none.disabled .bi-textarea,.bi-theme-dark .bi-list-item-none.disabled:active .bi-high-light,.bi-theme-dark .bi-list-item-none.disabled:active .bi-input,.bi-theme-dark .bi-list-item-none.disabled:active .bi-textarea,.bi-theme-dark .bi-list-item-none.disabled:hover .bi-high-light,.bi-theme-dark .bi-list-item-none.disabled:hover .bi-input,.bi-theme-dark .bi-list-item-none.disabled:hover .bi-textarea{color:#878d9f!important}.bi-user-select-enable{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;-o-user-select:text;user-select:text}.bi-user-select-disable{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.cursor-move{cursor:move}.y-overflow-auto{overflow-y:auto;overflow-x:hidden}.x-overflow-auto{overflow-y:hidden;overflow-x:auto}.y-overflow-scroll{overflow-y:scroll;overflow-x:hidden}.x-overflow-scroll{overflow-y:hidden;overflow-x:scroll}.overflow-auto{overflow-x:auto;overflow-y:auto}.overflow-scroll{overflow-x:scroll;overflow-y:scroll}.overflow-hidden{overflow-x:hidden;overflow-y:hidden}.td-overflow{white-space:normal;word-break:break-all}.overflow-dot{text-overflow:ellipsis;overflow-x:hidden;overflow-y:hidden;white-space:nowrap}.display-block{display:block}.display-inline{display:inline-block;*display:inline;*zoom:1}.display-table{display:table}.vertical-super{vertical-align:super}.vertical-top{vertical-align:top}.horizon-center{text-align:center}.horizon-left{text-align:left}.border-sizing{-ms-box-sizing:border-box;box-sizing:border-box}.content-sizing{-ms-box-sizing:content-box;box-sizing:content-box}.bi-flex-horizontal-layout{display:flex;-moz-flex-direction:row;-o-flex-direction:row;flex-direction:row;-moz-justify-content:flex-start;-ms-justify-content:flex-start;-o-justify-content:flex-start;justify-content:flex-start;-moz-align-items:flex-start;-ms-align-items:flex-start;-o-align-items:flex-start;align-items:flex-start;-o-flex-wrap:nowrap;flex-wrap:nowrap}.bi-flex-horizontal-layout.v-middle{-moz-align-items:center;-ms-align-items:center;-o-align-items:center;align-items:center}.bi-flex-horizontal-layout.v-bottom{-moz-align-items:flex-end;-ms-align-items:flex-end;-o-align-items:flex-end;align-items:flex-end}.bi-flex-horizontal-layout.v-stretch{-moz-align-items:stretch;-ms-align-items:stretch;-o-align-items:stretch;align-items:stretch}.bi-flex-horizontal-layout.h-center{-moz-justify-content:center;-ms-justify-content:center;-o-justify-content:center;justify-content:center}.bi-flex-horizontal-layout.h-right{-moz-flex-direction:row-reverse;-o-flex-direction:row-reverse;flex-direction:row-reverse}.bi-flex-horizontal-layout.h-stretch{-moz-flex-direction:column;-o-flex-direction:column;flex-direction:column;-moz-align-items:stretch;-ms-align-items:stretch;-o-align-items:stretch;align-items:stretch}.bi-flex-horizontal-layout.h-stretch.v-middle{-moz-justify-content:center;-ms-justify-content:center;-o-justify-content:center;justify-content:center}.bi-flex-horizontal-layout.h-stretch.v-bottom{-moz-justify-content:flex-end;-ms-justify-content:flex-end;-o-justify-content:flex-end;justify-content:flex-end}.bi-flex-vertical-layout{display:flex;-moz-flex-direction:column;-o-flex-direction:column;flex-direction:column;-moz-justify-content:flex-start;-ms-justify-content:flex-start;-o-justify-content:flex-start;justify-content:flex-start;-moz-align-items:flex-start;-ms-align-items:flex-start;-o-align-items:flex-start;align-items:flex-start;-o-flex-wrap:nowrap;flex-wrap:nowrap}.bi-flex-vertical-layout.h-center{-moz-align-items:center;-ms-align-items:center;-o-align-items:center;align-items:center}.bi-flex-vertical-layout.h-right{-moz-align-items:flex-end;-ms-align-items:flex-end;-o-align-items:flex-end;align-items:flex-end}.bi-flex-vertical-layout.h-stretch{-moz-align-items:stretch;-ms-align-items:stretch;-o-align-items:stretch;align-items:stretch}.bi-flex-vertical-layout.v-middle{-moz-justify-content:center;-ms-justify-content:center;-o-justify-content:center;justify-content:center}.bi-flex-vertical-layout.v-bottom{-moz-flex-direction:column-reverse;-o-flex-direction:column-reverse;flex-direction:column-reverse}.bi-flex-vertical-layout.v-stretch{-moz-flex-direction:row;-o-flex-direction:row;flex-direction:row;-moz-align-items:stretch;-ms-align-items:stretch;-o-align-items:stretch;align-items:stretch}.bi-flex-vertical-layout.v-stretch.h-center{-moz-justify-content:center;-ms-justify-content:center;-o-justify-content:center;justify-content:center}.bi-flex-vertical-layout.v-stretch.h-right{-moz-justify-content:flex-end;-ms-justify-content:flex-end;-o-justify-content:flex-end;justify-content:flex-end}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper{display:flex;-moz-flex-direction:row;-o-flex-direction:row;flex-direction:row;-moz-justify-content:flex-start;-ms-justify-content:flex-start;-o-justify-content:flex-start;justify-content:flex-start;-moz-align-items:flex-start;-ms-align-items:flex-start;-o-align-items:flex-start;align-items:flex-start;-o-flex-wrap:nowrap;flex-wrap:nowrap;min-height:100%}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper.v-middle{-moz-align-items:center;-ms-align-items:center;-o-align-items:center;align-items:center}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper.v-bottom{-moz-align-items:flex-end;-ms-align-items:flex-end;-o-align-items:flex-end;align-items:flex-end}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper.v-stretch{-moz-align-items:stretch;-ms-align-items:stretch;-o-align-items:stretch;align-items:stretch}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper.h-center{-moz-justify-content:center;-ms-justify-content:center;-o-justify-content:center;justify-content:center}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper.h-right{-moz-flex-direction:row-reverse;-o-flex-direction:row-reverse;flex-direction:row-reverse}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper.h-stretch{-moz-flex-direction:column;-o-flex-direction:column;flex-direction:column;-moz-align-items:stretch;-ms-align-items:stretch;-o-align-items:stretch;align-items:stretch}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper.h-stretch.v-middle{-moz-justify-content:center;-ms-justify-content:center;-o-justify-content:center;justify-content:center}.bi-flex-scrollable-horizontal-layout .flex-scrollable-horizontal-layout-wrapper.h-stretch.v-bottom{-moz-justify-content:flex-end;-ms-justify-content:flex-end;-o-justify-content:flex-end;justify-content:flex-end}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper{display:flex;-moz-flex-direction:column;-o-flex-direction:column;flex-direction:column;-moz-justify-content:flex-start;-ms-justify-content:flex-start;-o-justify-content:flex-start;justify-content:flex-start;-moz-align-items:flex-start;-ms-align-items:flex-start;-o-align-items:flex-start;align-items:flex-start;-o-flex-wrap:nowrap;flex-wrap:nowrap;min-width:100%}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper.h-center{-moz-align-items:center;-ms-align-items:center;-o-align-items:center;align-items:center}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper.h-right{-moz-align-items:flex-end;-ms-align-items:flex-end;-o-align-items:flex-end;align-items:flex-end}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper.h-stretch{-moz-align-items:stretch;-ms-align-items:stretch;-o-align-items:stretch;align-items:stretch}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper.v-middle{-moz-justify-content:center;-ms-justify-content:center;-o-justify-content:center;justify-content:center}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper.v-bottom{-moz-flex-direction:column-reverse;-o-flex-direction:column-reverse;flex-direction:column-reverse}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper.v-stretch{-moz-flex-direction:row;-o-flex-direction:row;flex-direction:row;-moz-align-items:stretch;-ms-align-items:stretch;-o-align-items:stretch;align-items:stretch}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper.v-stretch.h-center{-moz-justify-content:center;-ms-justify-content:center;-o-justify-content:center;justify-content:center}.bi-flex-scrollable-vertical-layout .flex-scrollable-vertical-layout-wrapper.v-stretch.h-right{-moz-justify-content:flex-end;-ms-justify-content:flex-end;-o-justify-content:flex-end;justify-content:flex-end}.bi-inline-center-adapt-layout:after{display:inline-block;width:0;min-height:100%;vertical-align:middle;content:" "}.bi-inline-center-adapt-layout>.inline-center-adapt-item{display:inline-block}.bi-inline-center-adapt-layout>.bi-combo.bi-combo-popup,.bi-inline-center-adapt-layout>.inline-center-adapt-item.x-icon{display:inline-block!important}.bi-inline-horizontal-adapt-layout:after{display:inline-block;width:0;min-height:100%;vertical-align:middle;content:" "}.bi-inline-horizontal-adapt-layout>.inline-horizontal-adapt-item{display:inline-block}.bi-inline-horizontal-adapt-layout>.bi-combo.bi-combo-popup,.bi-inline-horizontal-adapt-layout>.inline-horizontal-adapt-item.x-icon{display:inline-block!important}.bi-inline-vertical-adapt-layout:after{display:inline-block;width:0;min-height:100%;vertical-align:middle;content:" "}.bi-inline-vertical-adapt-layout>.inline-vertical-adapt-item{display:inline-block}.bi-inline-vertical-adapt-layout>.bi-combo.bi-combo-popup,.bi-inline-vertical-adapt-layout>.inline-vertical-adapt-item.x-icon{display:inline-block!important}.bi-theme-dark{color:#d6e0dc}.bi-theme-dark .bi-input{color:#fff}.bi-year-calendar{padding-top:5px;padding-bottom:5px}.bi-color-chooser-popup .disable-mask{opacity:.5;filter:alpha(opacity=50);background-color:#fff}.bi-color-chooser-trigger{border-radius:2px}.bi-color-picker-button .color-picker-button-mask{border:1px solid #232e40}.bi-theme-dark .bi-color-picker-button .color-picker-button-mask{border:1px solid #fff}.bi-farbtastic .wheel{background:url(images/1x/background/wheel.png) no-repeat 50%}.bi-farbtastic .overlay{background:url(images/1x/background/mask.png) no-repeat 50%}.bi-farbtastic .marker{background:url(images/1x/background/marker.png) no-repeat 50%}.bi-display-tree .ztree li span.button.switch.center_open{background:url(images/2x/icon/tree_vertical_line_3.png) no-repeat 50%}.bi-display-tree .ztree li span.button.switch.roots_open{background:url(images/2x/icon/tree_vertical_line_2.png) no-repeat 50%}.bi-display-tree .ztree li span.button.switch.bottom_open{background:url(images/2x/icon/tree_vertical_line_4.png) no-repeat 50%}.bi-display-tree .ztree.hack li span.button.switch.center_open{background:url(images/1x/icon/tree_vertical_line_3.png) no-repeat 50%}.bi-display-tree .ztree.hack li span.button.switch.roots_open{background:url(images/1x/icon/tree_vertical_line_2.png) no-repeat 50%}.bi-display-tree .ztree.hack li span.button.switch.bottom_open{background:url(images/1x/icon/tree_vertical_line_4.png) no-repeat 50%}.ztree.hack li ul.line{background:url(images/1x/icon/tree_vertical_line_1.png) repeat-y 1px 0}.bi-theme-dark .ztree.hack li ul.line{background:url(images/1x/icon/dark/tree_vertical_line_1.png) repeat-y 1px 0}.ztree li span.button.chk.checkbox_false_full,.ztree li span.button.chk.checkbox_false_full_focus{background:url(images/2x/icon/check_box_normal.png) no-repeat 50%}.ztree li span.button.chk.checkbox_false_part,.ztree li span.button.chk.checkbox_false_part_focus{background:url(images/2x/icon/half_selected.png) no-repeat 50%}.ztree li span.button.chk.checkbox_true_full,.ztree li span.button.chk.checkbox_true_full_focus{background:url(images/2x/icon/check_box_active.png) no-repeat 50%}.ztree li span.button.chk.checkbox_true_part,.ztree li span.button.chk.checkbox_true_part_focus{background:url(images/2x/icon/half_selected.png) no-repeat 50%}.ztree.hack li span.button.chk.checkbox_false_full,.ztree.hack li span.button.chk.checkbox_false_full_focus{background:url(images/1x/icon/check_box_normal.png) no-repeat 50%}.ztree.hack li span.button.chk.checkbox_false_part,.ztree.hack li span.button.chk.checkbox_false_part_focus{background:url(images/1x/icon/half_selected.png) no-repeat 50%}.ztree.hack li span.button.chk.checkbox_true_full,.ztree.hack li span.button.chk.checkbox_true_full_focus{background:url(images/1x/icon/check_box_active.png) no-repeat 50%}.ztree.hack li span.button.chk.checkbox_true_part,.ztree.hack li span.button.chk.checkbox_true_part_focus{background:url(images/1x/icon/half_selected.png) no-repeat 50%}.ztree li span.button.root_open{background:url(images/2x/icon/tree_expand_1.png) no-repeat 50%}.ztree.hack li span.button.root_open{background:url(images/1x/icon/tree_expand_1.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.root_open{background:url(images/2x/icon/dark/tree_expand_1.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.root_open{background:url(images/1x/icon/dark/tree_expand_1.png) no-repeat 50%}.ztree li span.button.root_close{background:url(images/2x/icon/tree_collapse_1.png) no-repeat 50%}.ztree.hack li span.button.root_close{background:url(images/1x/icon/tree_collapse_1.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.root_close{background:url(images/2x/icon/dark/tree_collapse_1.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.root_close{background:url(images/1x/icon/dark/tree_collapse_1.png) no-repeat 50%}.ztree li span.button.roots_open{background:url(images/2x/icon/tree_expand_2.png) no-repeat 50%}.ztree.hack li span.button.roots_open{background:url(images/1x/icon/tree_expand_2.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.roots_open{background:url(images/2x/icon/dark/tree_expand_2.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.roots_open{background:url(images/1x/icon/dark/tree_expand_2.png) no-repeat 50%}.ztree li span.button.roots_close{background:url(images/2x/icon/tree_collapse_2.png) no-repeat 50%}.ztree.hack li span.button.roots_close{background:url(images/1x/icon/tree_collapse_2.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.roots_close{background:url(images/2x/icon/dark/tree_collapse_2.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.roots_close{background:url(images/1x/icon/dark/tree_collapse_2.png) no-repeat 50%}.ztree li span.button.center_open{background:url(images/2x/icon/tree_expand_3.png) no-repeat 50%}.ztree.hack li span.button.center_open{background:url(images/1x/icon/tree_expand_3.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.center_open{background:url(images/2x/icon/dark/tree_expand_3.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.center_open{background:url(images/1x/icon/dark/tree_expand_3.png) no-repeat 50%}.ztree li span.button.center_close{background:url(images/2x/icon/tree_collapse_3.png) no-repeat 50%}.ztree.hack li span.button.center_close{background:url(images/1x/icon/tree_collapse_3.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.center_close{background:url(images/2x/icon/dark/tree_collapse_3.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.center_close{background:url(images/1x/icon/dark/tree_collapse_3.png) no-repeat 50%}.ztree li span.button.bottom_open{background:url(images/2x/icon/tree_expand_4.png) no-repeat 50%}.ztree.hack li span.button.bottom_open{background:url(images/1x/icon/tree_expand_4.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.bottom_open{background:url(images/2x/icon/dark/tree_expand_4.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.bottom_open{background:url(images/1x/icon/dark/tree_expand_4.png) no-repeat 50%}.ztree li span.button.bottom_close{background:url(images/2x/icon/tree_collapse_4.png) no-repeat 50%}.ztree.hack li span.button.bottom_close{background:url(images/1x/icon/tree_collapse_4.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.bottom_close{background:url(images/2x/icon/dark/tree_collapse_4.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.bottom_close{background:url(images/1x/icon/dark/tree_collapse_4.png) no-repeat 50%}.ztree li span.button.roots_docu{background:url(images/2x/icon/tree_vertical_line_2.png) no-repeat 50%}.ztree.hack li span.button.roots_docu{background:url(images/1x/icon/tree_vertical_line_2.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.roots_docu{background:url(images/2x/icon/dark/tree_vertical_line_2.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.roots_docu{background:url(images/1x/icon/dark/tree_vertical_line_2.png) no-repeat 50%}.ztree li span.button.center_docu{background:url(images/2x/icon/tree_vertical_line_3.png) no-repeat 50%}.ztree.hack li span.button.center_docu{background:url(images/1x/icon/tree_vertical_line_3.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.center_docu{background:url(images/2x/icon/dark/tree_vertical_line_3.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.center_docu{background:url(images/1x/icon/dark/tree_vertical_line_3.png) no-repeat 50%}.ztree li span.button.bottom_docu{background:url(images/2x/icon/tree_vertical_line_4.png) no-repeat 50%}.ztree.hack li span.button.bottom_docu{background:url(images/1x/icon/tree_vertical_line_4.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.bottom_docu{background:url(images/2x/icon/dark/tree_vertical_line_4.png) no-repeat 50%}.bi-theme-dark .ztree.hack li span.button.bottom_docu{background:url(images/1x/icon/dark/tree_vertical_line_4.png) no-repeat 50%}.ztree li span.button.ico_loading{background:url(images/2x/icon/loading.gif) no-repeat 50%}.ztree.hack li span.button.ico_loading{background:url(images/1x/icon/loading.gif) no-repeat 50%}.base-line-conn-background{background:url(images/1x/icon/tree_vertical_line_1.png) repeat-y 0 0}.bi-theme-dark .base-line-conn-background{background:url(images/1x/icon/dark/tree_vertical_line_1.png) repeat-y 0 0}.first-line-conn-background{background:url(images/1x/icon/tree_vertical_line_2.png) no-repeat 50%}.bi-theme-dark .first-line-conn-background{background:url(images/1x/icon/dark/tree_vertical_line_2.png) no-repeat 50%}.mid-line-conn-background{background:url(images/1x/icon/tree_vertical_line_3.png) no-repeat 50%}.bi-theme-dark .mid-line-conn-background{background:url(images/1x/icon/dark/tree_vertical_line_3.png) no-repeat 50%}.last-line-conn-background{background:url(images/1x/icon/tree_vertical_line_4.png) no-repeat 50%}.bi-theme-dark .last-line-conn-background{background:url(images/1x/icon/dark/tree_vertical_line_4.png) no-repeat 50%}.loading-background{background:url(images/2x/icon/loading.gif) no-repeat 50%}.auto-color-background{background:url(images/2x/background/auto_color_normal.png) no-repeat 50%}.auto-color-normal-background{background:url(images/2x/icon/auto_normal.png) no-repeat 50%}.auto-color-normal-disabled-background{background:url(images/2x/icon/auto_disable.png) no-repeat 50%}.trans-color-background{background:url(images/2x/background/trans_normal.png) no-repeat 50%}.trans-color-disabled-background{background:url(images/2x/background/trans_disable.png) no-repeat 50%}.auto-color-background.hack{background:url(images/1x/background/auto_color_normal.png) no-repeat 50%}.auto-color-normal-background.hack{background:url(images/1x/icon/auto_normal.png) no-repeat 50%}.auto-color-normal-disabled-background.hack{background:url(images/1x/icon/auto_disable.png) no-repeat 50%}.trans-color-background.hack{background:url(images/1x/background/trans_normal.png) no-repeat 50%}.trans-color-disabled-background.hack{background:url(images/1x/background/trans_disable.png) no-repeat 50%}.wave-loading{background:url(images/2x/icon/wave_loading.gif) no-repeat 50%}.wave-loading.hack{background:url(images/1x/icon/wave_loading.gif) no-repeat 50%}.bi-color-picker-editor .color-picker-editor-display{border-radius:2px}.bi-color-picker-editor.disabled .auto-color-normal-background{background:url(images/2x/icon/auto_disable.png) no-repeat 50%;background-size:contain}.bi-color-picker-editor.disabled .auto-color-normal-background.hack{background:url(images/1x/icon/auto_disable.png) no-repeat 50%}.bi-color-picker-editor.disabled .trans-color-background{background:url(images/2x/background/trans_disable.png) no-repeat 50%;background-size:contain}.bi-color-picker-editor.disabled .trans-color-background.hack{background:url(images/1x/background/trans_disable.png) no-repeat 50%}.bi-farbtastic *{cursor:crosshair}.bi-farbtastic .marker{margin:-8px 0 0 -8px}.bi-bubble-combo .button-combo-triangle-wrapper{position:fixed!important;position:-ms-device-fixed!important;line-height:0;z-index:10000000;background-color:hsla(0,0%,100%,0);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#00ffffff,endColorstr=#00ffffff)}.bi-bubble-combo .bubble-combo-triangle-left{z-index:1;position:absolute;width:6px;height:16px;text-align:left}.bi-bubble-combo .bubble-combo-triangle-left:before{position:absolute;width:6px;height:6px;margin-left:-3px;margin-top:4px;content:"";transform:rotate(-45deg)}.bi-bubble-combo .bubble-combo-triangle-right{z-index:1;position:absolute;width:6px;height:16px;text-align:left}.bi-bubble-combo .bubble-combo-triangle-right:before{position:absolute;width:6px;height:6px;margin-left:2px;margin-top:3px;content:"";transform:rotate(135deg)}.bi-bubble-combo .bubble-combo-triangle-top{z-index:1;position:absolute;width:16px;height:6px;text-align:left}.bi-bubble-combo .bubble-combo-triangle-top:before{position:absolute;width:6px;height:6px;margin-left:4px;margin-top:-3px;content:"";transform:rotate(45deg)}.bi-bubble-combo .bubble-combo-triangle-bottom{z-index:1;position:absolute;width:16px;height:6px;text-align:left}.bi-bubble-combo .bubble-combo-triangle-bottom:before{position:absolute;width:6px;height:6px;margin-left:4px;margin-top:2px;content:"";transform:rotate(-135deg)}.bi-bubble-combo .bubble-combo-triangle-bottom:before,.bi-bubble-combo .bubble-combo-triangle-left:before,.bi-bubble-combo .bubble-combo-triangle-right:before,.bi-bubble-combo .bubble-combo-triangle-top:before{background-color:#fff;border-bottom:1px solid #f2f4f7;border-right:1px solid #f2f4f7}.bi-theme-dark .bi-bubble-combo .bubble-combo-triangle-bottom:before,.bi-theme-dark .bi-bubble-combo .bubble-combo-triangle-left:before,.bi-theme-dark .bi-bubble-combo .bubble-combo-triangle-right:before,.bi-theme-dark .bi-bubble-combo .bubble-combo-triangle-top:before{background-color:#20263b;border-bottom:1px solid #292f45;border-right:1px solid #292f45}.bi-combo>.bi-trigger .bi-trigger-icon-button .x-icon{transform:rotate(0deg);transition:transform .3s ease}.bi-combo.bi-combo-popup{display:block!important;visibility:visible!important}.bi-combo.bi-combo-popup>.bi-trigger .bi-trigger-icon-button .x-icon{transform:rotate(180deg);transition:transform .3s ease}.bi-combo.bi-combo-hover>.bi-border,.bi-combo.bi-combo-popup>.bi-border,.bi-combo:hover>.bi-border{border-color:#3685f2}.bi-combo.disabled.bi-combo-hover>.bi-border,.bi-combo.disabled:hover>.bi-border{border-color:#e8eaed}.bi-theme-dark .bi-combo.disabled.bi-combo-hover>.bi-border,.bi-theme-dark .bi-combo.disabled:hover>.bi-border{border-color:#363e55}.bi-search-text-value-combo .trigger-icon-button{font-size:16px}.bi-search-text-value-combo .search-text-value-trigger{border-radius:2px}.bi-search-text-value-combo.combo-error .bi-search-text-value-trigger .bi-text-button{color:#e65251}.bi-search-text-value-combo .bi-combo.bi-combo-popup+.bi-trigger-icon-button .x-icon{transform:rotate(180deg);transition:transform .3s ease}.bi-search-text-value-combo .bi-combo+.bi-trigger-icon-button .x-icon{transform:rotate(0deg);transition:transform .3s ease}.bi-icon-text-value-combo.combo-error .bi-text-trigger .select-text-label,.bi-text-value-combo.combo-error .bi-select-text-trigger .select-text-label{color:#e65251}.bi-text-value-check-combo.bi-combo-popup>.bi-border,.bi-text-value-check-combo:hover>.bi-border,.bi-text-value-down-list-combo.bi-combo-popup>.bi-border,.bi-text-value-down-list-combo:hover>.bi-border{border-color:#3685f2}.bi-bubble-bar-popup-view .bar-popup-container{max-height:456px}.bi-search-editor{border-radius:2px}.bi-search-editor .circle-close-font,.bi-search-editor .search-font{font-size:18px}.bi-small-search-editor .bi-editor,.bi-small-search-editor .bi-editor .bi-input,.bi-small-search-editor .bi-editor .bi-label{font-size:12px}.bi-small-search-editor .close-font,.bi-small-search-editor .search-font{font-size:16px}.bi-message-title{font-size:14px;cursor:pointer}.bi-message-text{font-size:16px;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;-o-user-select:text;user-select:text}.bi-message-close,.bi-message-content{font-size:16px}.bi-message-animate{transition:opacity .3s,transform .3s,left .3s,right .3s,top .4s,bottom .3s}.bi-message-enter{opacity:1}.bi-message-leave{opacity:0;transform:translateY(-100%)}.bi-multi-list-view .bi-button-mask{opacity:.1;filter:alpha(opacity=10)}.bi-panel{border-radius:2px}.bi-panel .panel-title .panel-title-text{cursor:text;font-size:14px}.bi-sortable-holder{border:1px dashed #e8eaed}.bi-all-count-pager .all-pager-next,.bi-all-count-pager .all-pager-prev{font-size:16px}.bi-all-count-pager .row-count{color:#3685f2}.bi-direction-pager .direction-pager-next,.bi-direction-pager .direction-pager-prev{font-size:16px}.bi-pager .page-item{border-radius:2px}.bi-pane{min-height:25px}.bi-pane.loading-status{min-height:55px}.bi-pane .loading-container{background-color:rgba(247,248,250,0);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#00f7f8fa,endColorstr=#00f7f8fa)}.bi-loading-widget{font-size:0}.bi-loading-widget .animate-rect{background-color:rgba(54,133,242,.9);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#e63685f2,endColorstr=#e63685f2);border-radius:1.5px;-webkit-animation:loading-widget .8s linear infinite;animation:loading-widget .8s linear infinite}.bi-loading-widget .rect2{-webkit-animation-delay:-.2s;animation-delay:-.2s}.bi-loading-widget .rect3{-webkit-animation-delay:-.4s;animation-delay:-.4s}@-webkit-keyframes loading-widget{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@keyframes loading-widget{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}.bi-segment-button{color:#3685f2}.bi-segment>.center-element{overflow:hidden;overflow-x:hidden;overflow-y:hidden;background:#fff;border-right:1px solid #3685f2;border-top:1px solid #3685f2;border-bottom:1px solid #3685f2}.bi-segment>.first-element{border-left:1px solid #3685f2;border-radius:2px 0 0 2px}.bi-segment>.last-element{border-radius:0 2px 2px 0}.bi-segment.disabled>.center-element,.bi-segment.disabled>.first-element{border-color:#e8eaed}.bi-theme-dark .bi-segment>.center-element{overflow:hidden;overflow-x:hidden;overflow-y:hidden;background:#20263b;border-right:1px solid #363e55;border-top:1px solid #363e55;border-bottom:1px solid #363e55}.bi-theme-dark .bi-segment>.first-element{border-left:1px solid #363e55}.bi-half-button{border-radius:2px}#body .bi-button,body .bi-button{border-radius:2px;border:1px solid #3685f2;background-color:#3685f2;-ms-box-sizing:border-box;box-sizing:border-box;text-align:center;vertical-align:middle;cursor:pointer}#body .bi-button.hack,body .bi-button.hack{border-radius:0}#body .bi-button.block,body .bi-button.block{font-size:inherit;border-width:0;border-radius:0}#body .bi-button.clear,body .bi-button.clear{font-size:inherit;border-width:0;background-color:transparent}#body .bi-button.clear:hover,body .bi-button.clear:hover{opacity:.9;filter:alpha(opacity=90)}#body .bi-button.clear:active,body .bi-button.clear:active{opacity:.8;filter:alpha(opacity=80)}#body .bi-button.clear:after,body .bi-button.clear:after{display:none}#body .bi-button.ghost,body .bi-button.ghost{font-size:inherit;background-color:transparent}#body .bi-button.button-common,#body .bi-button.button-common .b-font:before,body .bi-button.button-common,body .bi-button.button-common .b-font:before{color:#fff}#body .bi-button.button-common.clear,#body .bi-button.button-common.clear .b-font:before,#body .bi-button.button-common.ghost,#body .bi-button.button-common.ghost .b-font:before,body .bi-button.button-common.clear,body .bi-button.button-common.clear .b-font:before,body .bi-button.button-common.ghost,body .bi-button.button-common.ghost .b-font:before{color:#3685f2}#body .bi-button.button-common.ghost:hover,body .bi-button.button-common.ghost:hover{color:#fff;background-color:#3685f2}#body .bi-button.button-common.ghost:active,body .bi-button.button-common.ghost:active{background-color:#3685f2}#body .bi-button.button-ignore,body .bi-button.button-ignore{background-color:transparent;border-color:#3685f2}#body .bi-button.button-ignore,#body .bi-button.button-ignore .b-font:before,body .bi-button.button-ignore,body .bi-button.button-ignore .b-font:before{color:#3685f2}#body .bi-button.button-ignore.clear,body .bi-button.button-ignore.clear{background-color:transparent;border-width:0}#body .bi-button.button-success,body .bi-button.button-success{background-color:#13cd66;border-color:#13cd66}#body .bi-button.button-success,#body .bi-button.button-success .b-font:before,body .bi-button.button-success,body .bi-button.button-success .b-font:before{color:#fff}#body .bi-button.button-success.clear,body .bi-button.button-success.clear{background-color:transparent;border-width:0}#body .bi-button.button-success.clear,#body .bi-button.button-success.clear .b-font:before,body .bi-button.button-success.clear,body .bi-button.button-success.clear .b-font:before{color:#13cd66}#body .bi-button.button-warning,body .bi-button.button-warning{background-color:#faaa39;border-color:#fbb03b}#body .bi-button.button-warning,#body .bi-button.button-warning .b-font:before,body .bi-button.button-warning,body .bi-button.button-warning .b-font:before{color:#fff}#body .bi-button.button-warning.clear,body .bi-button.button-warning.clear{background-color:transparent;border-width:0}#body .bi-button.button-warning.clear,#body .bi-button.button-warning.clear .b-font:before,body .bi-button.button-warning.clear,body .bi-button.button-warning.clear .b-font:before{color:#faaa39}#body .bi-button.button-error,body .bi-button.button-error{background-color:#e65251;border-color:#e65251}#body .bi-button.button-error,#body .bi-button.button-error .b-font:before,body .bi-button.button-error,body .bi-button.button-error .b-font:before{color:#fff}#body .bi-button.button-error.clear,body .bi-button.button-error.clear{background-color:transparent;border-width:0}#body .bi-button.button-error.clear,#body .bi-button.button-error.clear .b-font:before,body .bi-button.button-error.clear,body .bi-button.button-error.clear .b-font:before{color:#e65251}#body .bi-button.button-common.disabled,#body .bi-button.button-common.disabled.base-disabled,#body .bi-button.button-error.disabled,#body .bi-button.button-error.disabled.base-disabled,#body .bi-button.button-success.disabled,#body .bi-button.button-success.disabled.base-disabled,#body .bi-button.button-warning.disabled,#body .bi-button.button-warning.disabled.base-disabled,body .bi-button.button-common.disabled,body .bi-button.button-common.disabled.base-disabled,body .bi-button.button-error.disabled,body .bi-button.button-error.disabled.base-disabled,body .bi-button.button-success.disabled,body .bi-button.button-success.disabled.base-disabled,body .bi-button.button-warning.disabled,body .bi-button.button-warning.disabled.base-disabled{background-color:rgba(158,166,178,.2)!important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#339ea6b2,endColorstr=#339ea6b2);border-color:#e8eaed!important}#body .bi-button.button-common.disabled,#body .bi-button.button-common.disabled .b-font:before,#body .bi-button.button-common.disabled.base-disabled,#body .bi-button.button-common.disabled.base-disabled .b-font:before,#body .bi-button.button-error.disabled,#body .bi-button.button-error.disabled .b-font:before,#body .bi-button.button-error.disabled.base-disabled,#body .bi-button.button-error.disabled.base-disabled .b-font:before,#body .bi-button.button-success.disabled,#body .bi-button.button-success.disabled .b-font:before,#body .bi-button.button-success.disabled.base-disabled,#body .bi-button.button-success.disabled.base-disabled .b-font:before,#body .bi-button.button-warning.disabled,#body .bi-button.button-warning.disabled .b-font:before,#body .bi-button.button-warning.disabled.base-disabled,#body .bi-button.button-warning.disabled.base-disabled .b-font:before,body .bi-button.button-common.disabled,body .bi-button.button-common.disabled .b-font:before,body .bi-button.button-common.disabled.base-disabled,body .bi-button.button-common.disabled.base-disabled .b-font:before,body .bi-button.button-error.disabled,body .bi-button.button-error.disabled .b-font:before,body .bi-button.button-error.disabled.base-disabled,body .bi-button.button-error.disabled.base-disabled .b-font:before,body .bi-button.button-success.disabled,body .bi-button.button-success.disabled .b-font:before,body .bi-button.button-success.disabled.base-disabled,body .bi-button.button-success.disabled.base-disabled .b-font:before,body .bi-button.button-warning.disabled,body .bi-button.button-warning.disabled .b-font:before,body .bi-button.button-warning.disabled.base-disabled,body .bi-button.button-warning.disabled.base-disabled .b-font:before{color:#9ea6b2!important}#body .bi-button.button-common.disabled:after,#body .bi-button.button-error.disabled:after,#body .bi-button.button-success.disabled:after,#body .bi-button.button-warning.disabled:after,body .bi-button.button-common.disabled:after,body .bi-button.button-error.disabled:after,body .bi-button.button-success.disabled:after,body .bi-button.button-warning.disabled:after{display:none}#body .bi-button.button-ignore.disabled,body .bi-button.button-ignore.disabled{background:#fff!important;border-color:#e8eaed!important}#body .bi-button.button-ignore.disabled,#body .bi-button.button-ignore.disabled .b-font:before,body .bi-button.button-ignore.disabled,body .bi-button.button-ignore.disabled .b-font:before{color:#9ea6b2!important}#body .bi-button.button-ignore.disabled:after,body .bi-button.button-ignore.disabled:after{display:none}#body .bi-button.button-common.disabled.clear,#body .bi-button.button-error.disabled.clear,#body .bi-button.button-ignore.disabled.clear,#body .bi-button.button-success.disabled.clear,#body .bi-button.button-warning.disabled.clear,body .bi-button.button-common.disabled.clear,body .bi-button.button-error.disabled.clear,body .bi-button.button-ignore.disabled.clear,body .bi-button.button-success.disabled.clear,body .bi-button.button-warning.disabled.clear{background:transparent!important;border-width:0!important}#body .bi-button.button-common.disabled.clear,#body .bi-button.button-common.disabled.clear .b-font:before,#body .bi-button.button-error.disabled.clear,#body .bi-button.button-error.disabled.clear .b-font:before,#body .bi-button.button-ignore.disabled.clear,#body .bi-button.button-ignore.disabled.clear .b-font:before,#body .bi-button.button-success.disabled.clear,#body .bi-button.button-success.disabled.clear .b-font:before,#body .bi-button.button-warning.disabled.clear,#body .bi-button.button-warning.disabled.clear .b-font:before,body .bi-button.button-common.disabled.clear,body .bi-button.button-common.disabled.clear .b-font:before,body .bi-button.button-error.disabled.clear,body .bi-button.button-error.disabled.clear .b-font:before,body .bi-button.button-ignore.disabled.clear,body .bi-button.button-ignore.disabled.clear .b-font:before,body .bi-button.button-success.disabled.clear,body .bi-button.button-success.disabled.clear .b-font:before,body .bi-button.button-warning.disabled.clear,body .bi-button.button-warning.disabled.clear .b-font:before{color:#9ea6b2!important}#body .bi-button.button-common.disabled.clear:active,#body .bi-button.button-common.disabled.clear:hover,#body .bi-button.button-error.disabled.clear:active,#body .bi-button.button-error.disabled.clear:hover,#body .bi-button.button-ignore.disabled.clear:active,#body .bi-button.button-ignore.disabled.clear:hover,#body .bi-button.button-success.disabled.clear:active,#body .bi-button.button-success.disabled.clear:hover,#body .bi-button.button-warning.disabled.clear:active,#body .bi-button.button-warning.disabled.clear:hover,body .bi-button.button-common.disabled.clear:active,body .bi-button.button-common.disabled.clear:hover,body .bi-button.button-error.disabled.clear:active,body .bi-button.button-error.disabled.clear:hover,body .bi-button.button-ignore.disabled.clear:active,body .bi-button.button-ignore.disabled.clear:hover,body .bi-button.button-success.disabled.clear:active,body .bi-button.button-success.disabled.clear:hover,body .bi-button.button-warning.disabled.clear:active,body .bi-button.button-warning.disabled.clear:hover{opacity:1;filter:alpha(opacity=100)}#body .bi-button.button-common.disabled.ghost,#body .bi-button.button-error.disabled.ghost,#body .bi-button.button-ignore.disabled.ghost,#body .bi-button.button-success.disabled.ghost,#body .bi-button.button-warning.disabled.ghost,body .bi-button.button-common.disabled.ghost,body .bi-button.button-error.disabled.ghost,body .bi-button.button-ignore.disabled.ghost,body .bi-button.button-success.disabled.ghost,body .bi-button.button-warning.disabled.ghost{background:transparent!important;border-color:#3685f2!important;opacity:.5;filter:alpha(opacity=50)}#body .bi-button.button-common.disabled.ghost,#body .bi-button.button-common.disabled.ghost .b-font:before,#body .bi-button.button-error.disabled.ghost,#body .bi-button.button-error.disabled.ghost .b-font:before,#body .bi-button.button-ignore.disabled.ghost,#body .bi-button.button-ignore.disabled.ghost .b-font:before,#body .bi-button.button-success.disabled.ghost,#body .bi-button.button-success.disabled.ghost .b-font:before,#body .bi-button.button-warning.disabled.ghost,#body .bi-button.button-warning.disabled.ghost .b-font:before,body .bi-button.button-common.disabled.ghost,body .bi-button.button-common.disabled.ghost .b-font:before,body .bi-button.button-error.disabled.ghost,body .bi-button.button-error.disabled.ghost .b-font:before,body .bi-button.button-ignore.disabled.ghost,body .bi-button.button-ignore.disabled.ghost .b-font:before,body .bi-button.button-success.disabled.ghost,body .bi-button.button-success.disabled.ghost .b-font:before,body .bi-button.button-warning.disabled.ghost,body .bi-button.button-warning.disabled.ghost .b-font:before{color:#3685f2!important}.bi-basic-button.button-common:after,.bi-basic-button.button-error:after,.bi-basic-button.button-success:after,.bi-basic-button.button-warning:after{content:"";background-color:#232e40;border-radius:10px;display:block;width:100%;height:100%;position:absolute;transform:scale(1);opacity:0;filter:alpha(opacity=0);transition:transform .5s ease,opacity 1s ease;left:0;top:0;pointer-events:none}.bi-basic-button.button-common.hack:after,.bi-basic-button.button-error.hack:after,.bi-basic-button.button-success.hack:after,.bi-basic-button.button-warning.hack:after{content:none}.bi-basic-button.button-common:active:after,.bi-basic-button.button-error:active:after,.bi-basic-button.button-success:active:after,.bi-basic-button.button-warning:active:after{transform:scaleX(0);opacity:.1;filter:alpha(opacity=10);transition:transform 0s}.bi-basic-button.button-common:hover .bi-button-mask,.bi-basic-button.button-error:hover .bi-button-mask,.bi-basic-button.button-success:hover .bi-button-mask,.bi-basic-button.button-warning:hover .bi-button-mask{opacity:.1;filter:alpha(opacity=10);background-color:#fff;transition:opacity .3s ease}.bi-basic-button.button-ignore:after{content:"";background-color:#3685f2;border-radius:10px;display:block;width:100%;height:100%;position:absolute;transform:scale(1);opacity:0;filter:alpha(opacity=0);transition:transform .5s ease,opacity 1s ease;left:0;top:0;pointer-events:none}.bi-basic-button.button-ignore.hack:after{content:none}.bi-basic-button.button-ignore:active:after{transform:scaleX(0);opacity:.1;filter:alpha(opacity=10);transition:transform 0s}.bi-basic-button.button-ignore:hover{background-color:rgba(54,133,242,.05);transition:opacity .3s ease}.bi-basic-button .popup-content{font-size:14px}.bi-theme-dark #body .bi-button.button-common.ghost,.bi-theme-dark #body .bi-button.button-common.ghost .b-font:before,.bi-theme-dark body .bi-button.button-common.ghost,.bi-theme-dark body .bi-button.button-common.ghost .b-font:before{color:#fff;border-color:#fff}.bi-theme-dark #body .bi-button.button-common.ghost:hover,.bi-theme-dark body .bi-button.button-common.ghost:hover{color:#3d4d66;background-color:#fff}.bi-theme-dark #body .bi-button.button-common.ghost:active,.bi-theme-dark body .bi-button.button-common.ghost:active{background-color:hsla(0,0%,100%,.9);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#e6ffffff,endColorstr=#e6ffffff)}.bi-theme-dark #body .bi-button.button-ignore:hover,.bi-theme-dark body .bi-button.button-ignore:hover{background-color:rgba(54,133,242,.05)}.bi-theme-dark #body .bi-button.button-ignore:active,.bi-theme-dark body .bi-button.button-ignore:active{background-color:rgba(54,133,242,.1)}.bi-theme-dark #body .bi-button.button-common.disabled.ghost,.bi-theme-dark body .bi-button.button-common.disabled.ghost{background:transparent!important;border-color:#fff!important;opacity:.5;filter:alpha(opacity=50)}.bi-theme-dark #body .bi-button.button-common.disabled.ghost,.bi-theme-dark #body .bi-button.button-common.disabled.ghost .b-font:before,.bi-theme-dark body .bi-button.button-common.disabled.ghost,.bi-theme-dark body .bi-button.button-common.disabled.ghost .b-font:before{color:#fff!important}.bi-theme-dark #body .bi-button.button-error.disabled,.bi-theme-dark #body .bi-button.button-error.disabled.base-disabled,.bi-theme-dark #body .bi-button.button-ignore.disabled,.bi-theme-dark #body .bi-button.button-ignore.disabled.base-disabled,.bi-theme-dark #body .bi-button.button-success.disabled,.bi-theme-dark #body .bi-button.button-success.disabled.base-disabled,.bi-theme-dark #body .bi-button.button-warning.disabled,.bi-theme-dark #body .bi-button.button-warning.disabled.base-disabled,.bi-theme-dark body .bi-button.button-error.disabled,.bi-theme-dark body .bi-button.button-error.disabled.base-disabled,.bi-theme-dark body .bi-button.button-ignore.disabled,.bi-theme-dark body .bi-button.button-ignore.disabled.base-disabled,.bi-theme-dark body .bi-button.button-success.disabled,.bi-theme-dark body .bi-button.button-success.disabled.base-disabled,.bi-theme-dark body .bi-button.button-warning.disabled,.bi-theme-dark body .bi-button.button-warning.disabled.base-disabled{background-color:rgba(135,141,159,.2)!important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#33878d9f,endColorstr=#33878d9f)}.bi-single-select-icon-text-item.active .b-font:before,.bi-single-select-icon-text-item:active .b-font:before{color:#3685f2}.bi-switch{border-radius:40px 40px 40px 40px;background-color:#d0d4da}.bi-switch.active,.bi-switch:active{background-color:#3685f2}.bi-switch .circle-button{border-radius:9px 9px 9px 9px}.bi-switch.disabled,.bi-switch.disabled:active{background-color:#f2f4f7}.bi-theme-dark .bi-switch{background-color:#606479}.bi-theme-dark .bi-switch.active,.bi-theme-dark .bi-switch:active{background-color:#3685f2}.bi-theme-dark .bi-switch.disabled,.bi-theme-dark .bi-switch.disabled:active{background-color:#292f45}.bi-multifile-editor .multifile-editor{text-align:right;cursor:pointer;font-size:100px;z-index:2;margin-left:-5px}.bi-multifile-editor input[type=file],.bi-multifile-editor input[type=file]::-webkit-file-upload-button{cursor:pointer}.bi-textarea-editor{overflow:hidden;overflow-x:hidden;overflow-y:hidden}.bi-textarea-editor .textarea-editor-content{white-space:pre-wrap;font-size:12px;line-height:21px;border:none}.bi-textarea-editor .textarea-watermark{max-height:100%}.bi-html article,.bi-html aside,.bi-html details,.bi-html figcaption,.bi-html figure,.bi-html footer,.bi-html header,.bi-html hgroup,.bi-html nav,.bi-html section,.bi-html summary{display:block}.bi-html audio,.bi-html canvas,.bi-html video{display:inline-block;*display:inline;*zoom:1}.bi-html audio:not([controls]){display:none;height:0}.bi-html [hidden]{display:none}.bi-html html{font-size:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}.bi-html button,.bi-html html,.bi-html input,.bi-html select,.bi-html textarea{font-family:sans-serif}.bi-html body{margin:0}.bi-html a:focus{outline:thin dotted}.bi-html a:active,.bi-html a:hover{outline:0}.bi-html h1{font-size:2em;margin:.67em 0}.bi-html h2{font-size:1.5em;margin:.83em 0}.bi-html h3{font-size:1.17em;margin:1em 0}.bi-html h4{font-size:1em;margin:1.33em 0}.bi-html h5{font-size:.83em;margin:1.67em 0}.bi-html h6{font-size:.75em;margin:2.33em 0}.bi-html abbr[title]{border-bottom:1px dotted}.bi-html b,.bi-html strong{font-weight:700}.bi-html blockquote{margin:1em 40px}.bi-html dfn{font-style:italic}.bi-html mark{background:#ff0;color:#000}.bi-html p,.bi-html pre{margin:1em 0}.bi-html code,.bi-html kbd,.bi-html pre,.bi-html samp{font-family:monospace,serif;_font-family:courier new,monospace;font-size:1em}.bi-html pre{white-space:pre;white-space:pre-wrap;word-wrap:break-word}.bi-html q{quotes:none}.bi-html q:after,.bi-html q:before{content:"";content:none}.bi-html small{font-size:75%}.bi-html sub,.bi-html sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}.bi-html sup{top:-.5em}.bi-html sub{bottom:-.25em}.bi-html dl,.bi-html menu,.bi-html ol,.bi-html ul{margin:1em 0}.bi-html dd{margin:0 0 0 40px}.bi-html menu,.bi-html ol,.bi-html ul{padding:0 0 0 40px}.bi-html nav ol,.bi-html nav ul{list-style:none;list-style-image:none}.bi-html ul{list-style:disc}.bi-html li{list-style-type:disc}.bi-html img{border:0;-ms-interpolation-mode:bicubic}.bi-html svg:not(:root){overflow:hidden}.bi-html figure,.bi-html form{margin:0}.bi-html fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}.bi-html legend{border:0;padding:0;white-space:normal;*margin-left:-7px}.bi-html button,.bi-html input,.bi-html select,.bi-html textarea{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle}.bi-html button,.bi-html input{line-height:normal}.bi-html button,.bi-html html input[type=button],.bi-html input[type=reset],.bi-html input[type=submit]{-webkit-appearance:button;cursor:pointer;*overflow:visible}.bi-html button[disabled],.bi-html input[disabled]{cursor:default}.bi-html input[type=checkbox],.bi-html input[type=radio]{box-sizing:border-box;padding:0;*height:13px;*width:13px}.bi-html input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}.bi-html input[type=search]::-webkit-search-cancel-button,.bi-html input[type=search]::-webkit-search-decoration{-webkit-appearance:none}.bi-html button::-moz-focus-inner,.bi-html input::-moz-focus-inner{border:0;padding:0}.bi-html textarea{overflow:auto;vertical-align:top}.bi-html table{border-collapse:collapse;border-spacing:0}.x-icon.b-font{margin:auto;width:100%}.bi-checkbox .checkbox-content{border-radius:2px;border:1px solid #9ea6b2}.bi-checkbox .checkbox-content:after{position:absolute;display:table;top:50%;left:20%;border:2px solid transparent;border-top:0;border-left:0;width:4px;height:8px;transform:rotate(45deg) scale(1) translate(-50%,-50%);content:""}.bi-checkbox.active .checkbox-content,.bi-checkbox .checkbox-content.hover,.bi-checkbox .checkbox-content:hover,.bi-checkbox:active .checkbox-content{border-color:#3685f2}.bi-checkbox.active .checkbox-content:after,.bi-checkbox:active .checkbox-content:after{border-color:#fff;opacity:1}.bi-checkbox.disabled .checkbox-content{background-color:#f2f4f7;border-color:#e8eaed}.bi-checkbox.disabled .checkbox-content:after{opacity:0}.bi-checkbox.disabled.active .checkbox-content{background-color:#d0d4da}.bi-checkbox.disabled.active .checkbox-content:after{opacity:1}.bi-theme-dark .bi-checkbox .checkbox-content{border-color:#878d9f}.bi-theme-dark .bi-checkbox.active .checkbox-content,.bi-theme-dark .bi-checkbox .checkbox-content.hover,.bi-theme-dark .bi-checkbox .checkbox-content:hover,.bi-theme-dark .bi-checkbox:active .checkbox-content{border-color:#3685f2}.bi-theme-dark .bi-checkbox.disabled .checkbox-content{background-color:#292f45}.bi-theme-dark .bi-checkbox.disabled.active .checkbox-content{background-color:#606479;border-color:#363e55}.bi-file{opacity:0;filter:alpha(opacity=0);z-index:2}.bi-input,.bi-textarea{border:none;outline:none;background-color:transparent;padding:0;margin:0;width:100%;height:100%}.bi-input.bi-input-focus,.bi-textarea.bi-input-focus{border:none}.bi-input.bi-input-error,.bi-textarea.bi-input-error{border:none;color:#e65251!important}.bi-radio .radio-content{border-radius:8px;border:1px solid #9ea6b2}.bi-radio .radio-content:after{content:""}.bi-radio.active .radio-content,.bi-radio .radio-content.hover,.bi-radio .radio-content:hover,.bi-radio:active .radio-content{border-color:#3685f2}.bi-radio.active .radio-content:after,.bi-radio:active .radio-content:after{width:6px;height:6px;display:table;position:absolute;top:50%;left:50%;border-radius:3px;background-color:#fff;transform:translate(-50%,-50%)}.bi-radio.disabled .radio-content{background-color:#f2f4f7;border-color:#e8eaed}.bi-radio.disabled .radio-content:after{background-color:transparent}.bi-radio.disabled.active .radio-content{background-color:#d0d4da}.bi-radio.disabled.active .radio-content:after{background-color:#fff}.bi-theme-dark .bi-radio .radio-content{border-color:#878d9f}.bi-theme-dark .bi-radio.active .radio-content,.bi-theme-dark .bi-radio .radio-content.hover,.bi-theme-dark .bi-radio .radio-content:hover,.bi-theme-dark .bi-radio:active .radio-content{border-color:#3685f2}.bi-theme-dark .bi-radio.disabled .radio-content{background-color:#292f45}.bi-theme-dark .bi-radio.disabled .radio-content.hover,.bi-theme-dark .bi-radio.disabled .radio-content:hover{border-color:#878d9f}.bi-theme-dark .bi-radio.disabled.active .radio-content{background-color:#606479;border-color:#363e55}.bi-label,.bi-text{overflow:hidden;overflow-x:hidden;overflow-y:hidden;word-break:break-all}.bi-text{-ms-box-sizing:border-box;box-sizing:border-box}.bi-bubble .bubble-text{border-radius:2px}.bi-bubble .bubble-error{background:#ffecec;color:#e65251}.bi-theme-dark .bi-bubble .bubble-error{background:#3a2940}.bi-bubble .bubble-common{background:#eaf2fd;color:#3685f2}.bi-bubble .bubble-success{background:#e1f4e7;color:#13cd66}.bi-bubble .bubble-warning{background:#feeed7;color:#faaa39}.bi-tip{position:fixed!important;position:-ms-device-fixed!important}.bi-toast{color:#fff;max-width:400px;min-width:150px;border-radius:2px}.bi-toast.toast-success{background:#13cd66}.bi-toast.toast-warning{background:#faaa39}.bi-toast.toast-error{background:#e65251}.bi-toast.toast-common,.bi-toast.toast-normal{background:#3685f2}.bi-toast .toast-icon{font-size:16px}.bi-tooltip{max-width:250px;border-radius:2px;font-size:12px;color:#fff}.bi-tooltip.tooltip-success{background:#647185;border:1px solid #647185}.bi-tooltip.tooltip-warning{background:#e65251;border:1px solid #e65251}.bi-branch-tree .bi-branch-tree-view{min-width:300px}.bi-display-tree .ztree *{color:#999}.bi-display-tree .ztree li a,.bi-display-tree .ztree li span{cursor:default!important}.bi-display-tree .ztree li a:hover{text-decoration:none}.bi-display-tree .ztree li a.curSelectedNode{padding-top:1px;border:none;background-color:inherit;opacity:1;filter:alpha(opacity=100)}.bi-tree-expander-popup.line:before{position:absolute;content:"";border-left:1px dashed #d0d4da;height:100%;left:11px}.bi-list-display-tree .ztree li a,.bi-list-display-tree .ztree li span{cursor:default!important}.bi-list-display-tree .ztree li a:hover{text-decoration:none}.bi-list-display-tree .ztree li a.curSelectedNode{padding-top:1px;border:none;background-color:inherit;opacity:1;filter:alpha(opacity=100)}.ztree *{padding:0;margin:0}.ztree{margin:0;padding:5px}.ztree li{padding:0;margin:0;list-style:none;line-height:14px;text-align:left;white-space:pre;outline:0}.ztree li ul{margin:0;padding:0 0 0 18px}.ztree li a{padding:1px 3px 0 0;margin:0;cursor:pointer;height:24px;background-color:transparent;text-decoration:none;vertical-align:top;display:inline-block}.ztree li a:active,.ztree li a:hover{background-color:rgba(54,133,242,.06);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0f3685f2,endColorstr=#0f3685f2)}.ztree li a:active{color:#3685f2}.ztree li a.curSelectedNode_Edit{padding-top:0;background-color:#ffe6b0;color:#000;height:16px;border:1px solid #ffb951;opacity:.8}.ztree li a.tmpTargetNode_inner{padding-top:0;background-color:#316ac5;color:#fff;height:16px;border:1px solid #316ac5;opacity:.8;filter:alpha(opacity=80)}.ztree li a input.rename{height:14px;width:80px;padding:0;margin:0;font-size:12px;border:1px solid #7ec4cc;*border:0}.ztree li span{line-height:24px;margin-right:2px}.ztree li span.bi-keyword-red-mark{margin-right:0}.ztree li span.button{line-height:0;margin:0;width:16px;height:16px;display:inline-block;vertical-align:middle;border:0;cursor:pointer;outline:none;background-color:transparent;background-repeat:no-repeat;background-attachment:scroll}.ztree li span.button.chk{width:16px;height:16px;margin:0 3px 0 0;cursor:auto}.ztree li span.button.chk.checkbox_false_disable{background-position:0 -56px}.ztree li span.button.chk.checkbox_true_disable{background-position:-14px -56px}.ztree li span.button.chk.radio_false_full{background-position:-28px 0}.ztree li span.button.chk.radio_false_full_focus{background-position:-28px -14px}.ztree li span.button.chk.radio_false_part{background-position:-28px -28px}.ztree li span.button.chk.radio_false_part_focus{background-position:-28px -42px}.ztree li span.button.chk.radio_false_disable{background-position:-28px -56px}.ztree li span.button.chk.radio_true_full{background-position:-42px 0}.ztree li span.button.chk.radio_true_full_focus{background-position:-42px -14px}.ztree li span.button.chk.radio_true_part{background-position:-42px -28px}.ztree li span.button.chk.radio_true_part_focus{background-position:-42px -42px}.ztree li span.button.chk.checkbox_true_full+a,.ztree li span.button.chk.checkbox_true_full_focus+a,.ztree li span.button.chk.checkbox_true_part+a,.ztree li span.button.chk.checkbox_true_part_focus+a{color:#3685f2}.ztree li span.button.chk.radio_true_disable{background-position:-42px -56px}.ztree li span.button.switch{width:24px;height:24px}.ztree li span.button.noline_open{background-position:-92px -72px}.ztree li span.button.noline_close{background-position:-74px -72px}.ztree li span.button.noline_docu,.ztree li span.button.root_docu{background:none}.ztree li span.button.ico_open{margin-right:2px;background-position:-110px -16px;vertical-align:top;*vertical-align:middle}.ztree li span.button.ico_close{margin-right:2px;background-position:-110px 0;vertical-align:top;*vertical-align:middle}.ztree li span.button.ico_docu{background-position:-110px -32px}.ztree li span.button.edit,.ztree li span.button.ico_docu{margin-right:2px;vertical-align:top;*vertical-align:middle}.ztree li span.button.edit{background-position:-110px -48px}.ztree li span.button.remove{margin-right:2px;background-position:-110px -64px;vertical-align:top;*vertical-align:middle}.ztree li span.button.ico_loading{width:0;margin-right:2px;vertical-align:top;*vertical-align:middle}ul.tmpTargetzTree{background-color:#ffe6b0;opacity:.8;filter:alpha(opacity=80)}span.tmpzTreeMove_arrow{width:16px;height:16px;display:inline-block;padding:0;margin:2px 0 0 1px;border:0;position:absolute;background-color:transparent;background-repeat:no-repeat;background-attachment:scroll;background-position:-110px -80px}ul.ztree.zTreeDragUL{margin:0;padding:0;width:auto;height:auto;overflow:hidden;border:1px dotted #00b83f;opacity:.8;filter:alpha(opacity=80)}.zTreeMask,ul.ztree.zTreeDragUL{position:absolute;background-color:#cfcfcf}.zTreeMask{z-index:10000;opacity:0;filter:alpha(opacity=0)}.bi-trigger .bi-trigger-icon-button{font-size:16px}.bi-select-text-trigger,.bi-small-select-text-trigger{border-radius:2px}.bi-popover{border:1px solid transparent}.bi-popup-view{position:fixed!important;position:-ms-device-fixed!important;overflow-y:visible!important;overflow-x:visible!important;overflow:visible!important;cursor:default}.bi-popup-view .list-view-outer{border-radius:2px}.bi-popup-view .padding-outer{padding-top:5px;padding-bottom:5px}.bi-popup-view .list-view-shadow{box-shadow:0 1px 5px 0 rgba(35,46,64,.2)}.bi-popup-view .list-view-toolbar{line-height:24px}.bi-popup-view .list-view-toolbar>.center-element{border-left:1px solid #e8eaed}.bi-popup-view .list-view-toolbar>.first-element{border-left:none}.bi-theme-dark .bi-popup-view .list-view-toolbar>.center-element{border-left:1px solid #363e55}.bi-theme-dark .bi-popup-view .list-view-toolbar>.first-element{border-left:none}.bi-theme-dark .list-view-shadow{box-shadow:0 1px 5px 0 rgba(25,27,43,.8)}.bi-date-trigger{border-radius:2px}.bi-down-list-popup .bi-down-list-item .list-item-text,.bi-down-list-popup .list-group-item-text{max-width:203px}.bi-dynamic-date-combo .date-font{font-size:16px}.bi-interactive-arrangement .interactive-arrangement-dragtag-line{z-index:1000000000;background-color:#faaa39}.bi-interactive-arrangement .interactive-arrangement-dragtag-icon{z-index:1000000000}.bi-interval-slider,.bi-interval-slider-label{min-height:50px}.bi-month-trigger{border-radius:2px}.bi-multilayer-select-tree-combo .trigger-icon-button{font-size:16px}.bi-multilayer-select-tree-combo .bi-combo.bi-combo-popup+.bi-trigger-icon-button .x-icon{transform:rotate(180deg);transition:transform .3s ease}.bi-multilayer-select-tree-combo .bi-combo+.bi-trigger-icon-button .x-icon{transform:rotate(0deg);transition:transform .3s ease}.bi-multilayer-select-level-tree .tree-view{min-width:100%}.bi-multilayer-single-tree-combo .trigger-icon-button{font-size:16px}.bi-multilayer-single-tree-combo .bi-combo.bi-combo-popup+.bi-trigger-icon-button .x-icon{transform:rotate(180deg);transition:transform .3s ease}.bi-multilayer-single-tree-combo .bi-combo+.bi-trigger-icon-button .x-icon{transform:rotate(0deg);transition:transform .3s ease}.bi-multilayer-single-level-tree .tree-view{min-width:100%}.bi-multi-select-check-pane .multi-select-check-selected{text-decoration:underline}.bi-multi-select-combo .multi-select-trigger-icon-button{font-size:16px}.bi-multi-select-combo .bi-combo.bi-combo-popup+.bi-trigger-icon-button .x-icon{transform:rotate(180deg);transition:transform .3s ease}.bi-multi-select-combo .bi-combo+.bi-trigger-icon-button .x-icon{transform:rotate(0deg);transition:transform .3s ease}.bi-multi-select-insert-combo .multi-select-trigger-icon-button{font-size:16px}.bi-multi-select-insert-combo .bi-combo.bi-combo-popup+.bi-trigger-icon-button .x-icon{transform:rotate(180deg);transition:transform .3s ease}.bi-multi-select-insert-combo .bi-combo+.bi-trigger-icon-button .x-icon{transform:rotate(0deg);transition:transform .3s ease}.bi-multi-select-search-pane .multi-select-toolbar{color:#faaa39}.bi-multi-select-check-selected-button{z-index:1;min-width:16px;border-radius:8px}.bi-multi-select-insert-list .bi-search-editor,.bi-multi-select-list .bi-search-editor{-moz-border-radius-bottomleft:0;-webkit-border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.bi-multi-tree-check-pane .multi-tree-check-selected{color:#3685f2}.bi-multi-tree-combo .multi-select-trigger-icon-button{font-size:16px}.bi-multi-tree-combo .bi-combo.bi-combo-popup+.bi-trigger-icon-button .x-icon{transform:rotate(180deg);transition:transform .3s ease}.bi-multi-tree-combo .bi-combo+.bi-trigger-icon-button .x-icon{transform:rotate(0deg);transition:transform .3s ease}.bi-multi-tree-popup .popup-view-tree{min-height:170px}.bi-multi-tree-check-selected-button .trigger-check-selected{color:#3685f2;z-index:1}.bi-number-editor{border-radius:2px}.bi-number-editor .pull-down-font,.bi-number-editor .pull-up-font{font-size:12px}.bi-number-interval.hack{border-radius:0}.bi-number-interval .number-interval-small-editor{-moz-border-radius-topleft:2px;-webkit-border-top-left-radius:2px;-moz-border-radius-bottomleft:2px;-webkit-border-bottom-left-radius:2px;border-top-left-radius:2px;border-bottom-left-radius:2px}.bi-number-interval .number-interval-big-editor{-moz-border-radius-topright:2px;-webkit-border-top-right-radius:2px;-moz-border-radius-bottomright:2px;-webkit-border-bottom-right-radius:2px;border-top-right-radius:2px;border-bottom-right-radius:2px}.bi-number-interval .number-interval-big-combo{-moz-border-radius-topleft:2px;-webkit-border-top-left-radius:2px;-moz-border-radius-bottomleft:2px;-webkit-border-bottom-left-radius:2px;border-top-left-radius:2px;border-bottom-left-radius:2px}.bi-number-interval .number-interval-big-combo .bi-icon-combo-trigger .icon-combo-trigger-icon{font-size:14px}.bi-number-interval .number-interval-small-combo{-moz-border-radius-topright:2px;-webkit-border-top-right-radius:2px;-moz-border-radius-bottomright:2px;-webkit-border-bottom-right-radius:2px;border-top-right-radius:2px;border-bottom-right-radius:2px}.bi-number-interval .number-interval-small-combo .bi-icon-combo-trigger .icon-combo-trigger-icon{font-size:14px}.bi-number-interval.number-error .bi-input{color:#e65251!important}.bi-quarter-trigger{border-radius:2px}.bi-search-multi-text-value-combo .multi-select-trigger-icon-button{font-size:16px}.bi-search-multi-text-value-combo.combo-error .bi-multi-select-searcher .tip-text-style{color:#e65251}.bi-single-select-search-pane .single-select-toolbar{color:#faaa39}.bi-single-select-combo .single-select-trigger-icon-button{font-size:16px}.bi-single-select-combo .bi-combo.bi-combo-popup+.bi-trigger-icon-button .x-icon{transform:rotate(180deg);transition:transform .3s ease}.bi-single-select-combo .bi-combo+.bi-trigger-icon-button .x-icon{transform:rotate(0deg);transition:transform .3s ease}.bi-single-slider-label{min-height:50px}.bi-single-slider-normal{min-height:30px}.bi-single-slider{min-height:50px}.bi-single-slider-button .slider-button{cursor:ew-resize;border-width:2px;border-style:solid;border-radius:8px;background-color:#fff;height:12px;width:12px;top:6px;left:-8px}.bi-single-slider-button .slider-button.hover,.bi-single-slider-button .slider-button:hover{border-radius:10px;background-color:#f7f8fa;width:16px;height:16px;top:4px;left:-10px}.bi-single-slider-button .slider-button.disabled{border-color:#e8eaed}.bi-single-slider-button .slider-button.disabled.hover,.bi-single-slider-button .slider-button.disabled:hover{background-color:#f7f8fa;width:12px;height:12px;top:6px;left:-8px}.bi-theme-dark .bi-single-slider-button .slider-button{background-color:#20263b}.bi-theme-dark .bi-single-slider-button .slider-button.disabled.hover,.bi-theme-dark .bi-single-slider-button .slider-button.disabled:hover,.bi-theme-dark .bi-single-slider-button .slider-button.hover,.bi-theme-dark .bi-single-slider-button .slider-button:hover{background-color:#191b2b}.bi-slider-track .gray-track{background-color:rgba(61,77,102,.1);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#1a3d4d66,endColorstr=#1a3d4d66);border-radius:3px}.bi-slider-track .blue-track{border-radius:3px}.bi-slider-track .disabled-blue-track{background-color:#d0d4da;border-radius:3px}.bi-theme-dark .bi-slider-track .gray-track{background-color:rgba(214,224,220,.1);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#1ad6e0dc,endColorstr=#1ad6e0dc);border-radius:3px}.bi-theme-dark .bi-slider-track .disabled-blue-track{background-color:#606479;border-radius:3px}.bi-time-trigger .show-text{background-color:hsla(0,0%,100%,0);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#00ffffff,endColorstr=#00ffffff)}.bi-date-interval.time-error .bi-input,.bi-date-interval.time-error .sign-editor-text{color:#e65251}.bi-time-interval .bi-date-time-trigger{border-radius:2px}.bi-time-interval.time-error .bi-date-time-trigger .bi-input,.bi-time-interval.time-error .bi-date-time-trigger .sign-editor-text{color:#e65251}.bi-year-popup .year-popup-navigation{line-height:30px}.bi-year-popup .year-popup-navigation>.center-element{border-left:1px solid #e8eaed}.bi-year-popup .year-popup-navigation>.first-element{border-left:none}.bi-theme-dark .bi-year-popup .year-popup-navigation>.center-element{border-left:1px solid #363e55}.bi-theme-dark .bi-year-popup .year-popup-navigation>.first-element{border-left:none}.bi-year-trigger{border-radius:2px}.bi-year-month-interval.time-error .bi-input,.bi-year-month-interval.time-error .sign-editor-text{color:#e65251}.bi-theme-dark div::-webkit-scrollbar,.bi-theme-dark textarea::-webkit-scrollbar{-webkit-appearance:none}.bi-theme-dark div::-webkit-scrollbar-track,.bi-theme-dark div::-webkit-scrollbar-track:hover,.bi-theme-dark textarea::-webkit-scrollbar-track,.bi-theme-dark textarea::-webkit-scrollbar-track:hover{background-color:hsla(0,0%,100%,.05);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#0dffffff,endColorstr=#0dffffff)}.bi-theme-dark div::-webkit-scrollbar-thumb,.bi-theme-dark textarea::-webkit-scrollbar-thumb{background-color:hsla(0,0%,100%,.1);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#1affffff,endColorstr=#1affffff)}.bi-theme-dark div::-webkit-scrollbar-thumb:hover,.bi-theme-dark textarea::-webkit-scrollbar-thumb:hover{background-color:hsla(0,0%,100%,.3);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#4dffffff,endColorstr=#4dffffff)}.bi-farbtastic .wheel{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/background/wheel.png) no-repeat 50%}.bi-farbtastic .overlay{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/background/mask.png) no-repeat 50%}.bi-farbtastic .marker{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/background/marker.png) no-repeat 50%}.bi-display-tree .ztree li span.button.switch.center_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_3.png) no-repeat 50%;background-size:contain}.bi-display-tree .ztree li span.button.switch.roots_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_2.png) no-repeat 50%;background-size:contain}.bi-display-tree .ztree li span.button.switch.bottom_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_4.png) no-repeat 50%;background-size:contain}.bi-display-tree .ztree.hack li span.button.switch.center_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_3.png) no-repeat 50%}.bi-display-tree .ztree.hack li span.button.switch.roots_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_2.png) no-repeat 50%}.bi-display-tree .ztree.hack li span.button.switch.bottom_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_4.png) no-repeat 50%}.ztree li ul.line{position:relative}.ztree li ul.line:before{position:absolute;content:"";border-left:1px dashed #d0d4da;height:calc(100% - 3px);left:11px;margin-top:1px}.ztree.hack li ul.line{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_1.png) repeat-y 1px 0}.bi-theme-dark .ztree li ul.line:before{border-left:1px dashed #606479}.bi-theme-dark .ztree.hack li ul.line{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_1.png) repeat-y 1px 0}.ztree li span.button.chk.checkbox_false_full,.ztree li span.button.chk.checkbox_false_full_focus{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/check_box_normal.png) no-repeat 50%;background-size:contain}.ztree li span.button.chk.checkbox_false_part,.ztree li span.button.chk.checkbox_false_part_focus{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/half_selected.png) no-repeat 50%;background-size:contain}.ztree li span.button.chk.checkbox_true_full,.ztree li span.button.chk.checkbox_true_full_focus{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/check_box_active.png) no-repeat 50%;background-size:contain}.ztree li span.button.chk.checkbox_true_part,.ztree li span.button.chk.checkbox_true_part_focus{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/half_selected.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.chk.checkbox_false_full,.ztree.hack li span.button.chk.checkbox_false_full_focus{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/check_box_normal.png) no-repeat 50%}.ztree.hack li span.button.chk.checkbox_false_part,.ztree.hack li span.button.chk.checkbox_false_part_focus{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/half_selected.png) no-repeat 50%}.ztree.hack li span.button.chk.checkbox_true_full,.ztree.hack li span.button.chk.checkbox_true_full_focus{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/check_box_active.png) no-repeat 50%}.ztree.hack li span.button.chk.checkbox_true_part,.ztree.hack li span.button.chk.checkbox_true_part_focus{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/half_selected.png) no-repeat 50%}.ztree li span.button.root_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_expand_1.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.root_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_expand_1.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.root_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_expand_1.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.root_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_expand_1.png) no-repeat 50%}.ztree li span.button.root_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_collapse_1.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.root_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_collapse_1.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.root_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_collapse_1.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.root_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_collapse_1.png) no-repeat 50%}.ztree li span.button.roots_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_expand_2.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.roots_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_expand_2.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.roots_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_expand_2.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.roots_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_expand_2.png) no-repeat 50%}.ztree li span.button.roots_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_collapse_2.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.roots_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_collapse_2.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.roots_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_collapse_2.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.roots_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_collapse_2.png) no-repeat 50%}.ztree li span.button.center_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_expand_3.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.center_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_expand_3.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.center_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_expand_3.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.center_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_expand_3.png) no-repeat 50%}.ztree li span.button.center_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_collapse_3.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.center_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_collapse_3.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.center_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_collapse_3.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.center_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_collapse_3.png) no-repeat 50%}.ztree li span.button.bottom_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_expand_4.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.bottom_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_expand_4.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.bottom_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_expand_4.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.bottom_open{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_expand_4.png) no-repeat 50%}.ztree li span.button.bottom_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_collapse_4.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.bottom_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_collapse_4.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.bottom_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_collapse_4.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.bottom_close{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_collapse_4.png) no-repeat 50%}.ztree li span.button.roots_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_2.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.roots_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_2.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.roots_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_vertical_line_2.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.roots_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_2.png) no-repeat 50%}.ztree li span.button.center_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_3.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.center_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_3.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.center_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_vertical_line_3.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.center_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_3.png) no-repeat 50%}.ztree li span.button.bottom_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_4.png) no-repeat 50%;background-size:contain}.ztree.hack li span.button.bottom_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_4.png) no-repeat 50%}.bi-theme-dark .ztree li span.button.bottom_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_vertical_line_4.png) no-repeat 50%;background-size:contain}.bi-theme-dark .ztree.hack li span.button.bottom_docu{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_4.png) no-repeat 50%}.ztree li span.button.ico_loading{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/loading.gif) no-repeat 50%;background-size:contain}.ztree.hack li span.button.ico_loading{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/loading.gif) no-repeat 50%}.base-line-conn-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_1.png) repeat-y 0 0}.bi-theme-dark .base-line-conn-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_1.png) repeat-y 0 0}.first-line-conn-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_2.png) no-repeat 50%}.bi-theme-dark .first-line-conn-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_2.png) no-repeat 50%}.mid-line-conn-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_3.png) no-repeat 50%}.bi-theme-dark .mid-line-conn-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_3.png) no-repeat 50%}.last-line-conn-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_4.png) no-repeat 50%}.bi-theme-dark .last-line-conn-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_4.png) no-repeat 50%}.loading-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/loading.gif) no-repeat 50%;background-size:contain}.auto-color-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/background/auto_color_normal.png) no-repeat 50%;background-size:contain}.auto-color-normal-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/auto_normal.png) no-repeat 50%;background-size:contain}.auto-color-normal-disabled-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/auto_disable.png) no-repeat 50%;background-size:contain}.trans-color-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/background/trans_normal.png) no-repeat 50%;background-size:contain}.trans-color-disabled-background{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/background/trans_disable.png) no-repeat 50%;background-size:contain}.auto-color-background.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/background/auto_color_normal.png) no-repeat 50%}.auto-color-normal-background.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/auto_normal.png) no-repeat 50%}.auto-color-normal-disabled-background.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/auto_disable.png) no-repeat 50%}.trans-color-background.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/background/trans_normal.png) no-repeat 50%}.trans-color-disabled-background.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/background/trans_disable.png) no-repeat 50%}.wave-loading{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/wave_loading.gif) no-repeat 50%;background-size:contain}.wave-loading.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/wave_loading.gif) no-repeat 50%}@font-face{font-family:fineui;src:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/font/iconfont.eot);src:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/font/iconfont.eot#iefix) format("embedded-opentype"),url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/font/iconfont.woff) format("woff"),url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/font/iconfont.ttf) format("truetype"),url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/font/iconfont.svg#svgFontName) format("svg")}.b-font{font-family:fineui;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.close-font .b-font:before,.close-font.disabled .b-font:before,.close-h-font .b-font:before,.close-h-font.disabled .b-font:before,.close-h-font.hover .b-font:before,.close-h-font:hover .b-font:before,.close-ha-font .b-font:before,.close-ha-font.hover .b-font:before,.close-ha-font:hover .b-font:before{content:"\e6d0";color:inherit}.close-ha-font.active .b-font:before,.close-ha-font:active .b-font:before{content:"\e6d0";color:#3f8ce8}.close-ha-font.disabled .b-font:before{content:"\e6d0";color:inherit}.circle-close-font .b-font:before,.circle-close-font.disabled .b-font:before{content:"\e6d5";color:inherit}.search-close-h-font .b-font:before{content:"\e6d0";color:inherit}.search-close-h-font.hover .b-font:before,.search-close-h-font:hover .b-font:before{content:"\e6d0";color:#e65251}.search-close-h-font.disabled .b-font:before{content:"\e6d0";color:inherit}.pre-page-h-font .b-font:before,.pre-page-h-font.disabled .b-font:before,.pre-page-h-font.hover .b-font:before,.pre-page-h-font:hover .b-font:before{content:"\e70d";color:inherit}.next-page-h-font .b-font:before,.next-page-h-font.disabled .b-font:before,.next-page-h-font.hover .b-font:before,.next-page-h-font:hover .b-font:before{content:"\e70c";color:inherit}.search-font .b-font:before,.search-font.disabled .b-font:before{content:"\e6dc";color:inherit}.date-font .b-font:before,.date-font.disabled .b-font:before{content:"\e733";color:inherit}.time-font .b-font:before,.time-font.disabled .b-font:before{content:"\e6b1";color:inherit}.date-change-h-font .b-font:before,.date-change-h-font.disabled .b-font:before,.date-change-h-font.hover .b-font:before,.date-change-h-font:hover .b-font:before{content:"\e72f";color:inherit}.dot-font .b-font:before,.dot-font.disabled .b-font:before,.dot-h-font .b-font:before{content:"\e762";color:#232e40}.dot-h-font.hover .b-font:before,.dot-h-font:hover .b-font:before{content:"\e762";color:inherit}.dot-h-font.disabled .b-font:before{content:"\e762";color:#232e40}.dot-ha-font .b-font:before{content:"\e762";color:#fff}.dot-ha-font.hover .b-font:before,.dot-ha-font:hover .b-font:before{content:"\e762";color:#999}.dot-ha-font.active .b-font:before,.dot-ha-font:active .b-font:before{content:"\e762";color:#232e40}.dot-ha-font.disabled .b-font:before{content:"\e762";color:#fff}.dot-e-font .b-font:before,.dot-e-font.hover .b-font:before,.dot-e-font:active .b-font:before,.dot-e-font:hover .b-font:before{content:"\e762";color:transparent}.dot-e-font.active .b-font:before{content:"\e762";color:#3685f2}.dot-e-font.disabled .b-font:before{content:"\e762";color:transparent}.pull-right-font .b-font:before,.pull-right-font.disabled .b-font:before,.pull-right-h-font .b-font:before,.pull-right-h-font.disabled .b-font:before,.pull-right-h-font.hover .b-font:before,.pull-right-h-font:hover .b-font:before,.pull-right-ha-font .b-font:before,.pull-right-ha-font.hover .b-font:before,.pull-right-ha-font:hover .b-font:before{content:"\e70c";color:inherit}.pull-right-ha-font.active .b-font:before,.pull-right-ha-font:active .b-font:before{content:"\e70c";color:#3f8ce8}.pull-right-e-font .b-font:before,.pull-right-e-font.hover .b-font:before,.pull-right-e-font:hover .b-font:before,.pull-right-ha-font.disabled .b-font:before{content:"\e70c";color:inherit}.pull-right-e-font.active .b-font:before,.pull-right-e-font:active .b-font:before{content:"\e70c";color:#3f8ce8}.pull-right-e-font.disabled .b-font:before{content:"\e70c";color:inherit}.copy-font .b-font:before,.copy-font.disabled .b-font:before{content:"\e6bd";color:inherit}.copy-h-font .b-font:before{content:"\e6bd";color:#232e40}.copy-h-font.hover .b-font:before,.copy-h-font:hover .b-font:before{content:"\e6bd";color:inherit}.copy-h-font.disabled .b-font:before{content:"\e6bd";color:#232e40}.copy-ha-font .b-font:before,.copy-ha-font.hover .b-font:before,.copy-ha-font:hover .b-font:before{content:"\e6bd";color:inherit}.copy-ha-font.active .b-font:before,.copy-ha-font:active .b-font:before{content:"\e6bd";color:#3f8ce8}.copy-e-font .b-font:before,.copy-e-font.hover .b-font:before,.copy-e-font:hover .b-font:before,.copy-ha-font.disabled .b-font:before{content:"\e6bd";color:inherit}.copy-e-font.active .b-font:before,.copy-e-font:active .b-font:before{content:"\e6bd";color:#3f8ce8}.copy-e-font.disabled .b-font:before{content:"\e6bd";color:inherit}.check-mark-font .b-font:before,.check-mark-font.disabled .b-font:before,.check-mark-h-font .b-font:before,.check-mark-h-font.disabled .b-font:before,.check-mark-h-font.hover .b-font:before,.check-mark-h-font:hover .b-font:before,.check-mark-ha-font .b-font:before,.check-mark-ha-font.hover .b-font:before,.check-mark-ha-font:hover .b-font:before{content:"\e6cf";color:inherit}.check-mark-ha-font.active .b-font:before,.check-mark-ha-font:active .b-font:before{content:"\e6cf";color:#3f8ce8}.check-mark-e-font .b-font:before,.check-mark-e-font.hover .b-font:before,.check-mark-e-font:hover .b-font:before,.check-mark-ha-font.disabled .b-font:before{content:"\e6cf";color:inherit}.check-mark-e-font.active .b-font:before,.check-mark-e-font:active .b-font:before{content:"\e6cf";color:#3f8ce8}.check-mark-e-font.disabled .b-font:before{content:"\e6cf";color:inherit}.row-pre-page-h-font .b-font:before,.row-pre-page-h-font.disabled .b-font:before,.row-pre-page-h-font.hover .b-font:before,.row-pre-page-h-font:hover .b-font:before{content:"\e70d";color:inherit}.row-next-page-h-font .b-font:before,.row-next-page-h-font.disabled .b-font:before,.row-next-page-h-font.hover .b-font:before,.row-next-page-h-font:hover .b-font:before{content:"\e70c";color:inherit}.column-pre-page-h-font .b-font:before,.column-pre-page-h-font.disabled .b-font:before,.column-pre-page-h-font.hover .b-font:before,.column-pre-page-h-font:hover .b-font:before{content:"\e70a";color:inherit}.column-next-page-h-font .b-font:before,.column-next-page-h-font.disabled .b-font:before,.column-next-page-h-font.hover .b-font:before,.column-next-page-h-font:hover .b-font:before{content:"\e70b";color:inherit}.expander-right-font .b-font:before,.expander-right-font.disabled .b-font:before{content:"\e6d8";color:inherit}.expander-down-font .b-font:before,.expander-down-font.disabled .b-font:before{content:"\e6d7";color:inherit}.solid-triangle-top-font .b-font:before,.solid-triangle-top-font.disabled .b-font:before,.solid-triangle-top-font.hover .b-font:before,.solid-triangle-top-font:hover .b-font:before{content:"\e6d6";color:inherit}.solid-triangle-bottom-font .b-font:before,.solid-triangle-bottom-font.disabled .b-font:before,.solid-triangle-bottom-font.hover .b-font:before,.solid-triangle-bottom-font:hover .b-font:before{content:"\e6d7";color:inherit}.trigger-triangle-font .b-font:before,.trigger-triangle-font.disabled .b-font:before{content:"\e64e";color:inherit}.pull-up-font .b-font:before,.pull-up-font.disabled .b-font:before{content:"\e70a";color:inherit}.pull-down-font .b-font:before,.pull-down-font.disabled .b-font:before{content:"\e70b";color:inherit}.pull-down-h-font .b-font:before{content:"\e70b";color:#647185}.pull-down-h-font.hover .b-font:before,.pull-down-h-font:hover .b-font:before{content:"\e70b";color:inherit}.pull-down-h-font.disabled .b-font:before,.pull-down-ha-font .b-font:before{content:"\e70b";color:#647185}.pull-down-ha-font.hover .b-font:before,.pull-down-ha-font:hover .b-font:before{content:"\e70b";color:inherit}.pull-down-ha-font.active .b-font:before,.pull-down-ha-font:active .b-font:before{content:"\e70b";color:#3f8ce8}.pull-down-ha-font.disabled .b-font:before{content:"\e70b";color:#647185}.check-font .b-font:before,.check-font.disabled .b-font:before{content:"\e6cf";color:#3685f2}.item-check-font .b-font:before{content:"\e6cf";color:#fff}.item-check-font.hover .b-font:before,.item-check-font:hover .b-font:before{content:"\e6cf";color:#999}.item-check-font.active .b-font:before,.item-check-font:active .b-font:before{content:"\e6cf";color:#3f8ce8}.item-check-font.disabled .b-font:before{content:"\e6cf";color:#fff}.primary-key-font .b-font:before,.primary-key-font.disabled .b-font:before,.primary-key-font.hover .b-font:before,.primary-key-font:hover .b-font:before{content:"\e740";color:inherit}.drag-tag-font .b-font:before,.drag-tag-font.disabled .b-font:before{content:"\e6d0";color:#faaa39}.less-font .b-font:before,.less-font.disabled .b-font:before{content:"\e75e";color:inherit}.less-equal-font .b-font:before,.less-equal-font.disabled .b-font:before{content:"\e761";color:inherit}.text-bold-font .b-font:before,.text-bold-font.disabled .b-font:before{content:"\e697";color:inherit}.text-italic-font .b-font:before,.text-italic-font.disabled .b-font:before{content:"\e69d";color:inherit}.text-underline-font .b-font:before,.text-underline-font.disabled .b-font:before{content:"\e69c";color:inherit}.text-color-font .b-font:before,.text-color-font.disabled .b-font:before{content:"\e698";color:inherit}.text-background-font .b-font:before,.text-background-font.disabled .b-font:before{content:"\e699";color:inherit}.text-color-underline-font .b-font:before,.text-color-underline-font.disabled .b-font:before{content:"\e69a";color:inherit}.text-align-left-font .b-font:before,.text-align-left-font.disabled .b-font:before{content:"\e6ca";color:inherit}.text-align-center-font .b-font:before,.text-align-center-font.disabled .b-font:before{content:"\e6bf";color:inherit}.text-align-right-font .b-font:before,.text-align-right-font.disabled .b-font:before{content:"\e6c8";color:inherit}.toast-error-font .b-font:before,.toast-error-font.disabled .b-font:before{content:"\e757";color:inherit}.toast-success-font .b-font:before,.toast-success-font.disabled .b-font:before{content:"\e756";color:inherit}.toast-warning-font .b-font:before,.toast-warning-font.disabled .b-font:before{content:"\e755";color:inherit}.toast-message-font .b-font:before,.toast-message-font.disabled .b-font:before{content:"\e74b";color:inherit}.text-add-tip-font .b-font:before,.text-add-tip-font.disabled .b-font:before{content:"\e6dd";color:#13cd66}.add-up-font .b-font:before,.add-up-font.disabled .b-font:before{content:"\e70a";color:inherit}.minus-down-font .b-font:before,.minus-down-font.disabled .b-font:before{content:"\e70b";color:inherit}.tree-collapse-icon-type1 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_collapse_1.png) no-repeat 50%;background-size:contain}.tree-collapse-icon-type1 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_collapse_1.png) no-repeat 50%}.tree-collapse-icon-type2 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_collapse_2.png) no-repeat 50%;background-size:contain}.tree-collapse-icon-type2 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_collapse_2.png) no-repeat 50%}.tree-collapse-icon-type3 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_collapse_3.png) no-repeat 50%;background-size:contain}.tree-collapse-icon-type3 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_collapse_3.png) no-repeat 50%}.tree-collapse-icon-type4 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_collapse_4.png) no-repeat 50%;background-size:contain}.tree-collapse-icon-type4 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_collapse_4.png) no-repeat 50%}.tree-expand-icon-type1 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_expand_1.png) no-repeat 50%;background-size:contain}.tree-expand-icon-type1 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_expand_1.png) no-repeat 50%}.tree-expand-icon-type2 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_expand_2.png) no-repeat 50%;background-size:contain}.tree-expand-icon-type2 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_expand_2.png) no-repeat 50%}.tree-expand-icon-type3 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_expand_3.png) no-repeat 50%;background-size:contain}.tree-expand-icon-type3 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_expand_3.png) no-repeat 50%}.tree-expand-icon-type4 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_expand_4.png) no-repeat 50%;background-size:contain}.tree-expand-icon-type4 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_expand_4.png) no-repeat 50%}.tree-vertical-line-type2 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_2.png) no-repeat 50%;background-size:contain}.tree-vertical-line-type2 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_2.png) no-repeat 50%}.tree-vertical-line-type3 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_3.png) no-repeat 50%;background-size:contain}.tree-vertical-line-type3 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_3.png) no-repeat 50%}.tree-vertical-line-type4 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/tree_vertical_line_4.png) no-repeat 50%;background-size:contain}.tree-vertical-line-type4 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/tree_vertical_line_4.png) no-repeat 50%}.check-box-icon .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/check_box_normal.png) no-repeat 50%;background-size:contain}.check-box-icon .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/check_box_normal.png) no-repeat 50%}.check-box-icon.hover .x-icon,.check-box-icon:hover .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/check_box_normal.png) no-repeat 50%;background-size:contain}.check-box-icon.hover .x-icon.hack,.check-box-icon:hover .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/check_box_normal.png) no-repeat 50%}.check-box-icon:active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/check_box_normal.png) no-repeat 50%;background-size:contain}.check-box-icon:active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/check_box_normal.png) no-repeat 50%}.check-box-icon.active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/check_box_active.png) no-repeat 50%;background-size:contain}.check-box-icon.active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/check_box_active.png) no-repeat 50%}.check-box-icon.disabled .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/check_box_disable.png) no-repeat 50%;background-size:contain}.check-box-icon.disabled .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/check_box_disable.png) no-repeat 50%}.check-box-icon.disabled.active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/check_box_disable2.png) no-repeat 50%;background-size:contain}.check-box-icon.disabled.active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/check_box_disable2.png) no-repeat 50%}.radio-icon .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/radio_normal.png) no-repeat 50%;background-size:contain}.radio-icon .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/radio_normal.png) no-repeat 50%}.radio-icon.hover .x-icon,.radio-icon:hover .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/radio_normal.png) no-repeat 50%;background-size:contain}.radio-icon.hover .x-icon.hack,.radio-icon:hover .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/radio_normal.png) no-repeat 50%}.radio-icon:active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/radio_normal.png) no-repeat 50%;background-size:contain}.radio-icon:active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/radio_normal.png) no-repeat 50%}.radio-icon.active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/radio_active.png) no-repeat 50%;background-size:contain}.radio-icon.active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/radio_active.png) no-repeat 50%}.radio-icon.disabled .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/radio_disable.png) no-repeat 50%;background-size:contain}.radio-icon.disabled .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/radio_disable.png) no-repeat 50%}.radio-icon.disabled.active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/radio_disable2.png) no-repeat 50%;background-size:contain}.radio-icon.disabled.active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/radio_disable2.png) no-repeat 50%}.check-half-select-icon .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/half_selected.png) no-repeat 50%;background-size:contain}.check-half-select-icon .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/half_selected.png) no-repeat 50%}.check-half-select-icon.disabled .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/half_selected_disable.png) no-repeat 50%;background-size:contain}.check-half-select-icon.disabled .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/half_selected_disable.png) no-repeat 50%}.slider-icon .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/slider_normal_small.png) no-repeat 50%;background-size:contain}.slider-icon .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/slider_normal_small.png) no-repeat 50%}.slider-icon.hover .x-icon,.slider-icon:hover .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/slider_active_small.png) no-repeat 50%;background-size:contain}.slider-icon.hover .x-icon.hack,.slider-icon:hover .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/slider_active_small.png) no-repeat 50%}.slider-icon.disabled .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/slider_normal_small.png) no-repeat 50%;background-size:contain}.slider-icon.disabled .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/slider_normal_small.png) no-repeat 50%}.auto-color-icon .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/auto_normal.png) no-repeat 50%;background-size:contain}.auto-color-icon .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/auto_normal.png) no-repeat 50%}.auto-color-icon.active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/auto_select.png) no-repeat 50%;background-size:contain}.auto-color-icon.active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/auto_select.png) no-repeat 50%}.auto-color-icon.disabled .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/auto_disable.png) no-repeat 50%;background-size:contain}.auto-color-icon.disabled .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/auto_disable.png) no-repeat 50%}.trans-color-icon .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/trans_normal.png) no-repeat 50%;background-size:contain}.trans-color-icon .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/trans_normal.png) no-repeat 50%}.trans-color-icon.active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/trans_select.png) no-repeat 50%;background-size:contain}.trans-color-icon.active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/trans_select.png) no-repeat 50%}.trans-color-icon.disabled .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/trans_disable.png) no-repeat 50%;background-size:contain}.trans-color-icon.disabled .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/trans_disable.png) no-repeat 50%}.bi-theme-dark .tree-collapse-icon-type1 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_collapse_1.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-collapse-icon-type1 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_collapse_1.png) no-repeat 50%}.bi-theme-dark .tree-collapse-icon-type2 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_collapse_2.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-collapse-icon-type2 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_collapse_2.png) no-repeat 50%}.bi-theme-dark .tree-collapse-icon-type3 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_collapse_3.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-collapse-icon-type3 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_collapse_3.png) no-repeat 50%}.bi-theme-dark .tree-collapse-icon-type4 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_collapse_4.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-collapse-icon-type4 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_collapse_4.png) no-repeat 50%}.bi-theme-dark .tree-expand-icon-type1 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_expand_1.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-expand-icon-type1 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_expand_1.png) no-repeat 50%}.bi-theme-dark .tree-expand-icon-type2 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_expand_2.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-expand-icon-type2 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_expand_2.png) no-repeat 50%}.bi-theme-dark .tree-expand-icon-type3 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_expand_3.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-expand-icon-type3 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_expand_3.png) no-repeat 50%}.bi-theme-dark .tree-expand-icon-type4 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_expand_4.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-expand-icon-type4 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_expand_4.png) no-repeat 50%}.bi-theme-dark .tree-vertical-line-type2 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_vertical_line_2.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-vertical-line-type2 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_2.png) no-repeat 50%}.bi-theme-dark .tree-vertical-line-type3 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_vertical_line_3.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-vertical-line-type3 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_3.png) no-repeat 50%}.bi-theme-dark .tree-vertical-line-type4 .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/tree_vertical_line_4.png) no-repeat 50%;background-size:contain}.bi-theme-dark .tree-vertical-line-type4 .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/tree_vertical_line_4.png) no-repeat 50%}.bi-theme-dark .trans-color-icon .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/trans_normal.png) no-repeat 50%;background-size:contain}.bi-theme-dark .trans-color-icon .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/trans_normal.png) no-repeat 50%}.bi-theme-dark .trans-color-icon.active .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/trans_select.png) no-repeat 50%;background-size:contain}.bi-theme-dark .trans-color-icon.active .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/trans_select.png) no-repeat 50%}.bi-theme-dark .trans-color-icon.disabled .x-icon{display:block;background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/2x/icon/dark/trans_disable.png) no-repeat 50%;background-size:contain}.bi-theme-dark .trans-color-icon.disabled .x-icon.hack{background:url(https://fine-design-storage.oss-cn-shanghai.aliyuncs.com/fineui/2.0/images/1x/icon/dark/trans_disable.png) no-repeat 50%}.icon-size-12 .b-font{font-size:12px}.icon-size-16 .b-font{font-size:16px}.icon-size-24 .b-font{font-size:24px}.icon-size-40 .b-font{font-size:40px}.icon-size-50 .b-font{font-size:50px}.icon-size-70 .b-font{font-size:70px} \ No newline at end of file diff --git a/dist/bundle.min.js b/dist/bundle.min.js deleted file mode 100644 index b2358af4e..000000000 --- a/dist/bundle.min.js +++ /dev/null @@ -1,2 +0,0 @@ -/*! time: 2020-11-26 11:40:31 */ -!function(n){var i={};function r(e){if(i[e])return i[e].exports;var t=i[e]={i:e,l:!1,exports:{}};return n[e].call(t.exports,t,t.exports,r),t.l=!0,t.exports}r.m=n,r.c=i,r.d=function(e,t,n){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(t,e){if(1&e&&(t=r(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(r.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var i in t)r.d(n,i,function(e){return t[e]}.bind(null,i));return n},r.n=function(e){var t=e&&e.__esModule?function(){return e["default"]}:function(){return e};return r.d(t,"a",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p="",r(r.s=1018)}([function(e,t,n){var g=n(1),m=n(7),I=n(15),B=n(11),_=n(18),E="prototype",b=function(e,t,n){var i,r,a,o,s=e&b.F,l=e&b.G,u=e&b.S,c=e&b.P,h=e&b.B,p=l?g:u?g[t]||(g[t]={}):(g[t]||{})[E],d=l?m:m[t]||(m[t]={}),f=d[E]||(d[E]={});for(i in l&&(n=t),n)a=((r=!s&&p&&p[i]!==undefined)?p:n)[i],o=h&&r?_(a,g):c&&"function"==typeof a?_(Function.call,a):a,p&&B(p,i,a,e&b.U),d[i]!=a&&I(d,i,o),c&&f[i]!=a&&(f[i]=a)};g.core=m,b.F=1,b.G=2,b.S=4,b.P=8,b.B=16,b.W=32,b.U=64,b.R=128,e.exports=b},function(e,t){var n=e.exports="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")();"number"==typeof __g&&(__g=n)},function(e,t){e.exports=function(e){try{return!!e()}catch(t){return!0}}},function(e,t,n){var i=n(4);e.exports=function(e){if(!i(e))throw TypeError(e+" is not an object!");return e}},function(e,t){e.exports=function(e){return"object"==typeof e?null!==e:"function"==typeof e}},function(e,t,n){var i=n(53)("wks"),r=n(30),a=n(1).Symbol,o="function"==typeof a;(e.exports=function(e){return i[e]||(i[e]=o&&a[e]||(o?a:r)("Symbol."+e))}).store=i},function(e,t,n){var i=n(20),r=Math.min;e.exports=function(e){return 0"+r+""};e.exports=function(t,e){var n={};n[t]=e(a),i(i.P+i.F*r(function(){var e=""[t]('"');return e!==e.toLowerCase()||3document.F=Object<\/script>"),e.close(),c=e.F;n--;)delete c[u][o[n]];return c()};e.exports=Object.create||function(e,t){var n;return null!==e?(l[u]=r(e),n=new l,l[u]=null,n[s]=e):n=c(),t===undefined?n:a(n,t)}},function(e,t,n){var i=n(270),r=n(73).concat("length","prototype");t.f=Object.getOwnPropertyNames||function(e){return i(e,r)}},function(e,t,n){var i=n(14),r=n(10),a=n(72)("IE_PROTO"),o=Object.prototype;e.exports=Object.getPrototypeOf||function(e){return e=r(e),i(e,a)?e[a]:"function"==typeof e.constructor&&e instanceof e.constructor?e.constructor.prototype:e instanceof Object?o:null}},function(e,t,n){var i=n(5)("unscopables"),r=Array.prototype;r[i]==undefined&&n(15)(r,i,{}),e.exports=function(e){r[i][e]=!0}},function(e,t,n){var i=n(4);e.exports=function(e,t){if(!i(e)||e._t!==t)throw TypeError("Incompatible receiver, "+t+" required!");return e}},function(e,t,n){var i=n(9).f,r=n(14),a=n(5)("toStringTag");e.exports=function(e,t,n){e&&!r(e=n?e:e.prototype,a)&&i(e,a,{configurable:!0,value:t})}},function(e,t,n){var o=n(0),i=n(25),s=n(2),l=n(76),r="["+l+"]",a=RegExp("^"+r+r+"*"),u=RegExp(r+r+"*$"),c=function(e,t,n){var i={},r=s(function(){return!!l[e]()||"​…"!="​…"[e]()}),a=i[e]=r?t(h):l[e];n&&(i[n]=a),o(o.P+o.F*r,"String",i)},h=c.trim=function(e,t){return e=String(i(e)),1&t&&(e=e.replace(a,"")),2&t&&(e=e.replace(u,"")),e};e.exports=c},function(e,t){e.exports={}},function(e,t,n){"use strict";var i=n(1),r=n(9),a=n(8),o=n(5)("species");e.exports=function(e){var t=i[e];a&&t&&!t[o]&&r.f(t,o,{configurable:!0,get:function(){return this}})}},function(e,t){e.exports=function(e,t,n,i){if(!(e instanceof t)||i!==undefined&&i in e)throw TypeError(n+": incorrect invocation!");return e}},function(e,t,n){var r=n(11);e.exports=function(e,t,n){for(var i in t)r(e,i,t[i],n);return e}},,function(e,t,n){var i=n(24);e.exports=Object("z").propertyIsEnumerable(0)?Object:function(e){return"String"==i(e)?e.split(""):Object(e)}},function(e,t){t.f={}.propertyIsEnumerable},function(e,t,n){var r=n(24),a=n(5)("toStringTag"),o="Arguments"==r(function(){return arguments}());e.exports=function(e){var t,n,i;return e===undefined?"Undefined":null===e?"Null":"string"==typeof(n=function(e,t){try{return e[t]}catch(n){}}(t=Object(e),a))?n:o?r(t):"Object"==(i=r(t))&&"function"==typeof t.callee?"Arguments":i}},function(e,t,n){var r=n(3),a=n(19),o=n(5)("species");e.exports=function(e,t){var n,i=r(e).constructor;return i===undefined||(n=r(i)[o])==undefined?t:a(n)}},,,function(e,r,a){"use strict";(function(e){var t=void 0!==e&&e||"undefined"!=typeof self&&self||window,n=Function.prototype.apply;function i(e,t){this._id=e,this._clearFn=t}r.setTimeout=function(){return new i(n.call(setTimeout,t,arguments),clearTimeout)},r.setInterval=function(){return new i(n.call(setInterval,t,arguments),clearInterval)},r.clearTimeout=r.clearInterval=function(e){e&&e.close()},i.prototype.unref=i.prototype.ref=function(){},i.prototype.close=function(){this._clearFn.call(t,this._id)},r.enroll=function(e,t){clearTimeout(e._idleTimeoutId),e._idleTimeout=t},r.unenroll=function(e){clearTimeout(e._idleTimeoutId),e._idleTimeout=-1},r._unrefActive=r.active=function(e){clearTimeout(e._idleTimeoutId);var t=e._idleTimeout;0<=t&&(e._idleTimeoutId=setTimeout(function(){e._onTimeout&&e._onTimeout()},t))},a(106),r.setImmediate="undefined"!=typeof self&&self.setImmediate||void 0!==e&&e.setImmediate||void 0,r.clearImmediate="undefined"!=typeof self&&self.clearImmediate||void 0!==e&&e.clearImmediate||void 0}).call(this,a(13))},function(e,t,n){var i=n(7),r=n(1),a="__core-js_shared__",o=r[a]||(r[a]={});(e.exports=function(e,t){return o[e]||(o[e]=t!==undefined?t:{})})("versions",[]).push({version:i.version,mode:n(31)?"pure":"global",copyright:"© 2019 Denis Pushkarev (zloirock.ru)"})},function(e,t,n){var l=n(16),u=n(6),c=n(33);e.exports=function(s){return function(e,t,n){var i,r=l(e),a=u(r.length),o=c(n,a);if(s&&t!=t){for(;o")}),B=function(){var e=/(?:)/,t=e.exec;e.exec=function(){return t.apply(this,arguments)};var n="ab".split(e);return 2===n.length&&"a"===n[0]&&"b"===n[1]}();e.exports=function(n,e,t){var a,i,r,o,s=f(n),l=!p(function(){var e={};return e[s]=function(){return 7},7!=""[n](e)}),u=l?!p(function(){var e=!1,t=/a/;return t.exec=function(){return e=!0,null},"split"===n&&(t.constructor={},t.constructor[m]=function(){return t}),t[s](""),!e}):undefined;l&&u&&("replace"!==n||I)&&("split"!==n||B)||(a=/./[s],r=(i=t(d,s,""[n],function(e,t,n,i,r){return t.exec===g?l&&!r?{done:!0,value:a.call(t,n,i)}:{done:!0,value:e.call(n,t,i)}:{done:!1}}))[0],o=i[1],c(String.prototype,n,r),h(RegExp.prototype,s,2==e?function(e,t){return o.call(e,this,t)}:function(e){return o.call(e,this)}))}},function(e,t,n){var p=n(18),d=n(283),f=n(86),g=n(3),m=n(6),I=n(88),B={},_={};(t=e.exports=function(e,t,n,i,r){var a,o,s,l,u=r?function(){return e}:I(e),c=p(n,i,t?2:1),h=0;if("function"!=typeof u)throw TypeError(e+" is not iterable!");if(f(u)){for(a=m(e.length);h>>=1)&&(t+=t))1&i&&(n+=t);return n}},function(e,t){e.exports=Math.sign||function(e){return 0==(e=+e)||e!=e?e:e<0?-1:1}},function(e,t){var n=Math.expm1;e.exports=!n||22025.465794806718=e.length?(this._t=undefined,r(1)):r(0,"keys"==t?n:"values"==t?e[n]:[n,e[n]])},"values"),a.Arguments=a.Array,i("keys"),i("values"),i("entries")},function(e,t,n){"use strict";var i,r,o=n(58),s=RegExp.prototype.exec,l=String.prototype.replace,a=s,u="lastIndex",c=(i=/a/,r=/b*/g,s.call(i,"a"),s.call(r,"a"),0!==i[u]||0!==r[u]),h=/()??/.exec("")[1]!==undefined;(c||h)&&(a=function(e){var t,n,i,r,a=this;return h&&(n=new RegExp("^"+a.source+"$(?!\\s)",o.call(a))),c&&(t=a[u]),i=s.call(a,e),c&&i&&(a[u]=a.global?i.index+i[0].length:t),h&&i&&1>1,c=23===t?x(2,-24)-x(2,-77):0,h=0,p=e<0||0===e&&1/e<0?1:0;for((e=S(e))!=e||e===N?(r=e!=e?1:0,i=l):(i=w(A(e)/L),e*(a=x(2,-i))<1&&(i--,a*=2),2<=(e+=1<=i+u?c/a:c*x(2,1-u))*a&&(i++,a/=2),l<=i+u?(r=0,i=l):1<=i+u?(r=(e*a-1)*x(2,t),i+=u):(r=e*x(2,u-1)*x(2,t),i=0));8<=t;o[h++]=255&r,r/=256,t-=8);for(i=i<>1,s=r-7,l=n-1,u=e[l--],c=127&u;for(u>>=7;0>=-s,s+=t;0>8&255]}function G(e){return[255&e,e>>8&255,e>>16&255,e>>24&255]}function j(e){return H(e,52,8)}function Z(e){return H(e,23,4)}function X(e,t,n){g(e[E],t,{get:function(){return this[n]}})}function J(e,t,n,i){var r=d(+n);if(r+t>e[P])throw C(b);var a=e[M]._b,o=r+e[R],s=a.slice(o,o+t);return i?s:s.reverse()}function K(e,t,n,i,r,a){var o=d(+n);if(o+t>e[P])throw C(b);for(var s=e[M]._b,l=o+e[R],u=i(+r),c=0;cq;)(z=Q[q++])in y||s(y,z,V[z]);a||(U.constructor=y)}var $=new v(new y(2)),ee=v[E].setInt8;$.setInt8(0,2147483648),$.setInt8(1,2147483649),!$.getInt8(0)&&$.getInt8(1)||l(v[E],{setInt8:function(e,t){ee.call(this,e,t<<24>>24)},setUint8:function(e,t){ee.call(this,e,t<<24>>24)}},!0)}else y=function(e){c(this,y,B);var t=d(e);this._b=m.call(new Array(t),0),this[P]=t},v=function(e,t,n){c(this,v,_),c(e,y,_);var i=e[P],r=h(t);if(r<0||i>24},getUint8:function(e){return J(this,1,e)[0]},getInt16:function(e){var t=J(this,2,e,arguments[1]);return(t[1]<<8|t[0])<<16>>16},getUint16:function(e){var t=J(this,2,e,arguments[1]);return t[1]<<8|t[0]},getInt32:function(e){return F(J(this,4,e,arguments[1]))},getUint32:function(e){return F(J(this,4,e,arguments[1]))>>>0},getFloat32:function(e){return O(J(this,4,e,arguments[1]),23,4)},getFloat64:function(e){return O(J(this,8,e,arguments[1]),52,8)},setInt8:function(e,t){K(this,1,e,W,t)},setUint8:function(e,t){K(this,1,e,W,t)},setInt16:function(e,t){K(this,2,e,Y,t,arguments[2])},setUint16:function(e,t){K(this,2,e,Y,t,arguments[2])},setInt32:function(e,t){K(this,4,e,G,t,arguments[2])},setUint32:function(e,t){K(this,4,e,G,t,arguments[2])},setFloat32:function(e,t){K(this,4,e,Z,t,arguments[2])},setFloat64:function(e,t){K(this,8,e,j,t,arguments[2])}});I(y,B),I(v,_),s(v[E],o.VIEW,!0),t[B]=y,t[_]=v},function(e,t){var n=e.exports="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")();"number"==typeof __g&&(__g=n)},function(e,t){e.exports=function(e){return"object"==typeof e?null!==e:"function"==typeof e}},function(e,t,n){e.exports=!n(300)(function(){return 7!=Object.defineProperty({},"a",{get:function(){return 7}}).a})},,,,function(e,t,n){(function(e){_global=undefined,_global="undefined"!=typeof window?window:void 0!==e?e:"undefined"!=typeof self?self:this,null==_global.BI&&(_global.BI={prepares:[]}),null==_global.BI.prepares&&(_global.BI.prepares=[])}).call(this,n(13))},function(e,t,n){n(103)(n(104))},function(e,t){e.exports=function(e){function t(e){"undefined"!=typeof console&&(console.error||console.log)("[Script Loader]",e)}try{"undefined"!=typeof execScript&&"undefined"!=typeof attachEvent&&"undefined"==typeof addEventListener?execScript(e):"undefined"!=typeof eval?eval.call(null,e):t("EvalError: No eval function available")}catch(n){t(n)}}},function(e,t){e.exports="/**\r\n * @license\r\n * Lodash (Custom Build) \r\n * Build: `lodash core plus=\"debounce,throttle,get,set,findIndex,findLastIndex,findKey,findLastKey,isArrayLike,invert,invertBy,uniq,uniqBy,omit,omitBy,zip,unzip,rest,range,random,reject,intersection,drop,countBy,union,zipObject,initial,cloneDeep,clamp,isPlainObject,take,takeRight,without,difference,defaultsDeep,trim,merge,groupBy,uniqBy,before,after\"`\r\n * Copyright JS Foundation and other contributors \r\n * Released under MIT license \r\n * Based on Underscore.js 1.8.3 \r\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\r\n */\r\n;(function() {\r\n\r\n /** Used as a safe reference for `undefined` in pre-ES5 environments. */\r\n var undefined;\r\n\r\n /** Used as the semantic version number. */\r\n var VERSION = '4.17.5';\r\n\r\n /** Used as the size to enable large array optimizations. */\r\n var LARGE_ARRAY_SIZE = 200;\r\n\r\n /** Error message constants. */\r\n var FUNC_ERROR_TEXT = 'Expected a function';\r\n\r\n /** Used to stand-in for `undefined` hash values. */\r\n var HASH_UNDEFINED = '__lodash_hash_undefined__';\r\n\r\n /** Used as the maximum memoize cache size. */\r\n var MAX_MEMOIZE_SIZE = 500;\r\n\r\n /** Used as the internal argument placeholder. */\r\n var PLACEHOLDER = '__lodash_placeholder__';\r\n\r\n /** Used to compose bitmasks for cloning. */\r\n var CLONE_DEEP_FLAG = 1,\r\n CLONE_FLAT_FLAG = 2,\r\n CLONE_SYMBOLS_FLAG = 4;\r\n\r\n /** Used to compose bitmasks for value comparisons. */\r\n var COMPARE_PARTIAL_FLAG = 1,\r\n COMPARE_UNORDERED_FLAG = 2;\r\n\r\n /** Used to compose bitmasks for function metadata. */\r\n var WRAP_BIND_FLAG = 1,\r\n WRAP_BIND_KEY_FLAG = 2,\r\n WRAP_CURRY_BOUND_FLAG = 4,\r\n WRAP_CURRY_FLAG = 8,\r\n WRAP_CURRY_RIGHT_FLAG = 16,\r\n WRAP_PARTIAL_FLAG = 32,\r\n WRAP_PARTIAL_RIGHT_FLAG = 64,\r\n WRAP_ARY_FLAG = 128,\r\n WRAP_REARG_FLAG = 256,\r\n WRAP_FLIP_FLAG = 512;\r\n\r\n /** Used to detect hot functions by number of calls within a span of milliseconds. */\r\n var HOT_COUNT = 800,\r\n HOT_SPAN = 16;\r\n\r\n /** Used to indicate the type of lazy iteratees. */\r\n var LAZY_FILTER_FLAG = 1,\r\n LAZY_MAP_FLAG = 2,\r\n LAZY_WHILE_FLAG = 3;\r\n\r\n /** Used as references for various `Number` constants. */\r\n var INFINITY = 1 / 0,\r\n MAX_SAFE_INTEGER = 9007199254740991,\r\n MAX_INTEGER = 1.7976931348623157e+308,\r\n NAN = 0 / 0;\r\n\r\n /** Used as references for the maximum length and index of an array. */\r\n var MAX_ARRAY_LENGTH = 4294967295;\r\n\r\n /** Used to associate wrap methods with their bit flags. */\r\n var wrapFlags = [\r\n ['ary', WRAP_ARY_FLAG],\r\n ['bind', WRAP_BIND_FLAG],\r\n ['bindKey', WRAP_BIND_KEY_FLAG],\r\n ['curry', WRAP_CURRY_FLAG],\r\n ['curryRight', WRAP_CURRY_RIGHT_FLAG],\r\n ['flip', WRAP_FLIP_FLAG],\r\n ['partial', WRAP_PARTIAL_FLAG],\r\n ['partialRight', WRAP_PARTIAL_RIGHT_FLAG],\r\n ['rearg', WRAP_REARG_FLAG]\r\n ];\r\n\r\n /** `Object#toString` result references. */\r\n var argsTag = '[object Arguments]',\r\n arrayTag = '[object Array]',\r\n asyncTag = '[object AsyncFunction]',\r\n boolTag = '[object Boolean]',\r\n dateTag = '[object Date]',\r\n errorTag = '[object Error]',\r\n funcTag = '[object Function]',\r\n genTag = '[object GeneratorFunction]',\r\n mapTag = '[object Map]',\r\n numberTag = '[object Number]',\r\n nullTag = '[object Null]',\r\n objectTag = '[object Object]',\r\n promiseTag = '[object Promise]',\r\n proxyTag = '[object Proxy]',\r\n regexpTag = '[object RegExp]',\r\n setTag = '[object Set]',\r\n stringTag = '[object String]',\r\n symbolTag = '[object Symbol]',\r\n undefinedTag = '[object Undefined]',\r\n weakMapTag = '[object WeakMap]';\r\n\r\n var arrayBufferTag = '[object ArrayBuffer]',\r\n dataViewTag = '[object DataView]',\r\n float32Tag = '[object Float32Array]',\r\n float64Tag = '[object Float64Array]',\r\n int8Tag = '[object Int8Array]',\r\n int16Tag = '[object Int16Array]',\r\n int32Tag = '[object Int32Array]',\r\n uint8Tag = '[object Uint8Array]',\r\n uint8ClampedTag = '[object Uint8ClampedArray]',\r\n uint16Tag = '[object Uint16Array]',\r\n uint32Tag = '[object Uint32Array]';\r\n\r\n /** Used to match HTML entities and HTML characters. */\r\n var reUnescapedHtml = /[&<>\"']/g,\r\n reHasUnescapedHtml = RegExp(reUnescapedHtml.source);\r\n\r\n /** Used to match property names within property paths. */\r\n var reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\r\n reIsPlainProp = /^\\w*$/,\r\n rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\r\n\r\n /**\r\n * Used to match `RegExp`\r\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\r\n */\r\n var reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\r\n\r\n /** Used to match leading and trailing whitespace. */\r\n var reTrim = /^\\s+|\\s+$/g;\r\n\r\n /** Used to match wrap detail comments. */\r\n var reWrapComment = /\\{(?:\\n\\/\\* \\[wrapped with .+\\] \\*\\/)?\\n?/,\r\n reWrapDetails = /\\{\\n\\/\\* \\[wrapped with (.+)\\] \\*/,\r\n reSplitDetails = /,? & /;\r\n\r\n /** Used to match backslashes in property paths. */\r\n var reEscapeChar = /\\\\(\\\\)?/g;\r\n\r\n /** Used to match `RegExp` flags from their coerced string values. */\r\n var reFlags = /\\w*$/;\r\n\r\n /** Used to detect bad signed hexadecimal string values. */\r\n var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\r\n\r\n /** Used to detect binary string values. */\r\n var reIsBinary = /^0b[01]+$/i;\r\n\r\n /** Used to detect host constructors (Safari). */\r\n var reIsHostCtor = /^\\[object .+?Constructor\\]$/;\r\n\r\n /** Used to detect octal string values. */\r\n var reIsOctal = /^0o[0-7]+$/i;\r\n\r\n /** Used to detect unsigned integer values. */\r\n var reIsUint = /^(?:0|[1-9]\\d*)$/;\r\n\r\n /** Used to compose unicode character classes. */\r\n var rsAstralRange = '\\\\ud800-\\\\udfff',\r\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\r\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\r\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\r\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\r\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\r\n\r\n /** Used to compose unicode capture groups. */\r\n var rsAstral = '[' + rsAstralRange + ']',\r\n rsCombo = '[' + rsComboRange + ']',\r\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\r\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\r\n rsNonAstral = '[^' + rsAstralRange + ']',\r\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\r\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\r\n rsZWJ = '\\\\u200d';\r\n\r\n /** Used to compose unicode regexes. */\r\n var reOptMod = rsModifier + '?',\r\n rsOptVar = '[' + rsVarRange + ']?',\r\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\r\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\r\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\r\n\r\n /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\r\n var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\r\n\r\n /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\r\n var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\r\n\r\n /** Used to identify `toStringTag` values of typed arrays. */\r\n var typedArrayTags = {};\r\n typedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\r\n typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\r\n typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\r\n typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\r\n typedArrayTags[uint32Tag] = true;\r\n typedArrayTags[argsTag] = typedArrayTags[arrayTag] =\r\n typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\r\n typedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\r\n typedArrayTags[errorTag] = typedArrayTags[funcTag] =\r\n typedArrayTags[mapTag] = typedArrayTags[numberTag] =\r\n typedArrayTags[objectTag] = typedArrayTags[regexpTag] =\r\n typedArrayTags[setTag] = typedArrayTags[stringTag] =\r\n typedArrayTags[weakMapTag] = false;\r\n\r\n /** Used to identify `toStringTag` values supported by `_.clone`. */\r\n var cloneableTags = {};\r\n cloneableTags[argsTag] = cloneableTags[arrayTag] =\r\n cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\r\n cloneableTags[boolTag] = cloneableTags[dateTag] =\r\n cloneableTags[float32Tag] = cloneableTags[float64Tag] =\r\n cloneableTags[int8Tag] = cloneableTags[int16Tag] =\r\n cloneableTags[int32Tag] = cloneableTags[mapTag] =\r\n cloneableTags[numberTag] = cloneableTags[objectTag] =\r\n cloneableTags[regexpTag] = cloneableTags[setTag] =\r\n cloneableTags[stringTag] = cloneableTags[symbolTag] =\r\n cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\r\n cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\r\n cloneableTags[errorTag] = cloneableTags[funcTag] =\r\n cloneableTags[weakMapTag] = false;\r\n\r\n /** Used to map characters to HTML entities. */\r\n var htmlEscapes = {\r\n '&': '&',\r\n '<': '<',\r\n '>': '>',\r\n '\"': '"',\r\n \"'\": '''\r\n };\r\n\r\n /** Built-in method references without a dependency on `root`. */\r\n var freeParseFloat = parseFloat,\r\n freeParseInt = parseInt;\r\n\r\n /** Detect free variable `global` from Node.js. */\r\n var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\r\n\r\n /** Detect free variable `self`. */\r\n var freeSelf = typeof self == 'object' && self && self.Object === Object && self;\r\n\r\n /** Used as a reference to the global object. */\r\n var root = freeGlobal || freeSelf || Function('return this')();\r\n\r\n /** Detect free variable `exports`. */\r\n var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\r\n\r\n /** Detect free variable `module`. */\r\n var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\r\n\r\n /** Detect the popular CommonJS extension `module.exports`. */\r\n var moduleExports = freeModule && freeModule.exports === freeExports;\r\n\r\n /** Detect free variable `process` from Node.js. */\r\n var freeProcess = moduleExports && freeGlobal.process;\r\n\r\n /** Used to access faster Node.js helpers. */\r\n var nodeUtil = (function() {\r\n try {\r\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\r\n } catch (e) {}\r\n }());\r\n\r\n /* Node.js helper references. */\r\n var nodeIsDate = nodeUtil && nodeUtil.isDate,\r\n nodeIsMap = nodeUtil && nodeUtil.isMap,\r\n nodeIsRegExp = nodeUtil && nodeUtil.isRegExp,\r\n nodeIsSet = nodeUtil && nodeUtil.isSet,\r\n nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\r\n\r\n /*--------------------------------------------------------------------------*/\r\n\r\n /**\r\n * A faster alternative to `Function#apply`, this function invokes `func`\r\n * with the `this` binding of `thisArg` and the arguments of `args`.\r\n *\r\n * @private\r\n * @param {Function} func The function to invoke.\r\n * @param {*} thisArg The `this` binding of `func`.\r\n * @param {Array} args The arguments to invoke `func` with.\r\n * @returns {*} Returns the result of `func`.\r\n */\r\n function apply(func, thisArg, args) {\r\n switch (args.length) {\r\n case 0: return func.call(thisArg);\r\n case 1: return func.call(thisArg, args[0]);\r\n case 2: return func.call(thisArg, args[0], args[1]);\r\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\r\n }\r\n return func.apply(thisArg, args);\r\n }\r\n\r\n /**\r\n * A specialized version of `baseAggregator` for arrays.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to iterate over.\r\n * @param {Function} setter The function to set `accumulator` values.\r\n * @param {Function} iteratee The iteratee to transform keys.\r\n * @param {Object} accumulator The initial aggregated object.\r\n * @returns {Function} Returns `accumulator`.\r\n */\r\n function arrayAggregator(array, setter, iteratee, accumulator) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length;\r\n\r\n while (++index < length) {\r\n var value = array[index];\r\n setter(accumulator, value, iteratee(value), array);\r\n }\r\n return accumulator;\r\n }\r\n\r\n /**\r\n * A specialized version of `_.forEach` for arrays without support for\r\n * iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @returns {Array} Returns `array`.\r\n */\r\n function arrayEach(array, iteratee) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length;\r\n\r\n while (++index < length) {\r\n if (iteratee(array[index], index, array) === false) {\r\n break;\r\n }\r\n }\r\n return array;\r\n }\r\n\r\n /**\r\n * A specialized version of `_.every` for arrays without support for\r\n * iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to iterate over.\r\n * @param {Function} predicate The function invoked per iteration.\r\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\r\n * else `false`.\r\n */\r\n function arrayEvery(array, predicate) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length;\r\n\r\n while (++index < length) {\r\n if (!predicate(array[index], index, array)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n }\r\n\r\n /**\r\n * A specialized version of `_.filter` for arrays without support for\r\n * iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to iterate over.\r\n * @param {Function} predicate The function invoked per iteration.\r\n * @returns {Array} Returns the new filtered array.\r\n */\r\n function arrayFilter(array, predicate) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length,\r\n resIndex = 0,\r\n result = [];\r\n\r\n while (++index < length) {\r\n var value = array[index];\r\n if (predicate(value, index, array)) {\r\n result[resIndex++] = value;\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * A specialized version of `_.includes` for arrays without support for\r\n * specifying an index to search from.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to inspect.\r\n * @param {*} target The value to search for.\r\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\r\n */\r\n function arrayIncludes(array, value) {\r\n var length = array == null ? 0 : array.length;\r\n return !!length && baseIndexOf(array, value, 0) > -1;\r\n }\r\n\r\n /**\r\n * This function is like `arrayIncludes` except that it accepts a comparator.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to inspect.\r\n * @param {*} target The value to search for.\r\n * @param {Function} comparator The comparator invoked per element.\r\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\r\n */\r\n function arrayIncludesWith(array, value, comparator) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length;\r\n\r\n while (++index < length) {\r\n if (comparator(value, array[index])) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n /**\r\n * A specialized version of `_.map` for arrays without support for iteratee\r\n * shorthands.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @returns {Array} Returns the new mapped array.\r\n */\r\n function arrayMap(array, iteratee) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length,\r\n result = Array(length);\r\n\r\n while (++index < length) {\r\n result[index] = iteratee(array[index], index, array);\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Appends the elements of `values` to `array`.\r\n *\r\n * @private\r\n * @param {Array} array The array to modify.\r\n * @param {Array} values The values to append.\r\n * @returns {Array} Returns `array`.\r\n */\r\n function arrayPush(array, values) {\r\n var index = -1,\r\n length = values.length,\r\n offset = array.length;\r\n\r\n while (++index < length) {\r\n array[offset + index] = values[index];\r\n }\r\n return array;\r\n }\r\n\r\n /**\r\n * A specialized version of `_.reduce` for arrays without support for\r\n * iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @param {*} [accumulator] The initial value.\r\n * @param {boolean} [initAccum] Specify using the first element of `array` as\r\n * the initial value.\r\n * @returns {*} Returns the accumulated value.\r\n */\r\n function arrayReduce(array, iteratee, accumulator, initAccum) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length;\r\n\r\n if (initAccum && length) {\r\n accumulator = array[++index];\r\n }\r\n while (++index < length) {\r\n accumulator = iteratee(accumulator, array[index], index, array);\r\n }\r\n return accumulator;\r\n }\r\n\r\n /**\r\n * A specialized version of `_.some` for arrays without support for iteratee\r\n * shorthands.\r\n *\r\n * @private\r\n * @param {Array} [array] The array to iterate over.\r\n * @param {Function} predicate The function invoked per iteration.\r\n * @returns {boolean} Returns `true` if any element passes the predicate check,\r\n * else `false`.\r\n */\r\n function arraySome(array, predicate) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length;\r\n\r\n while (++index < length) {\r\n if (predicate(array[index], index, array)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n /**\r\n * Gets the size of an ASCII `string`.\r\n *\r\n * @private\r\n * @param {string} string The string inspect.\r\n * @returns {number} Returns the string size.\r\n */\r\n var asciiSize = baseProperty('length');\r\n\r\n /**\r\n * Converts an ASCII `string` to an array.\r\n *\r\n * @private\r\n * @param {string} string The string to convert.\r\n * @returns {Array} Returns the converted array.\r\n */\r\n function asciiToArray(string) {\r\n return string.split('');\r\n }\r\n\r\n /**\r\n * The base implementation of methods like `_.findKey` and `_.findLastKey`,\r\n * without support for iteratee shorthands, which iterates over `collection`\r\n * using `eachFunc`.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to inspect.\r\n * @param {Function} predicate The function invoked per iteration.\r\n * @param {Function} eachFunc The function to iterate over `collection`.\r\n * @returns {*} Returns the found element or its key, else `undefined`.\r\n */\r\n function baseFindKey(collection, predicate, eachFunc) {\r\n var result;\r\n eachFunc(collection, function(value, key, collection) {\r\n if (predicate(value, key, collection)) {\r\n result = key;\r\n return false;\r\n }\r\n });\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\r\n * support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array} array The array to inspect.\r\n * @param {Function} predicate The function invoked per iteration.\r\n * @param {number} fromIndex The index to search from.\r\n * @param {boolean} [fromRight] Specify iterating from right to left.\r\n * @returns {number} Returns the index of the matched value, else `-1`.\r\n */\r\n function baseFindIndex(array, predicate, fromIndex, fromRight) {\r\n var length = array.length,\r\n index = fromIndex + (fromRight ? 1 : -1);\r\n\r\n while ((fromRight ? index-- : ++index < length)) {\r\n if (predicate(array[index], index, array)) {\r\n return index;\r\n }\r\n }\r\n return -1;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\r\n *\r\n * @private\r\n * @param {Array} array The array to inspect.\r\n * @param {*} value The value to search for.\r\n * @param {number} fromIndex The index to search from.\r\n * @returns {number} Returns the index of the matched value, else `-1`.\r\n */\r\n function baseIndexOf(array, value, fromIndex) {\r\n return value === value\r\n ? strictIndexOf(array, value, fromIndex)\r\n : baseFindIndex(array, baseIsNaN, fromIndex);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isNaN` without support for number objects.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\r\n */\r\n function baseIsNaN(value) {\r\n return value !== value;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.property` without support for deep paths.\r\n *\r\n * @private\r\n * @param {string} key The key of the property to get.\r\n * @returns {Function} Returns the new accessor function.\r\n */\r\n function baseProperty(key) {\r\n return function(object) {\r\n return object == null ? undefined : object[key];\r\n };\r\n }\r\n\r\n /**\r\n * The base implementation of `_.propertyOf` without support for deep paths.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Function} Returns the new accessor function.\r\n */\r\n function basePropertyOf(object) {\r\n return function(key) {\r\n return object == null ? undefined : object[key];\r\n };\r\n }\r\n\r\n /**\r\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\r\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @param {*} accumulator The initial value.\r\n * @param {boolean} initAccum Specify using the first or last element of\r\n * `collection` as the initial value.\r\n * @param {Function} eachFunc The function to iterate over `collection`.\r\n * @returns {*} Returns the accumulated value.\r\n */\r\n function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\r\n eachFunc(collection, function(value, index, collection) {\r\n accumulator = initAccum\r\n ? (initAccum = false, value)\r\n : iteratee(accumulator, value, index, collection);\r\n });\r\n return accumulator;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.sortBy` which uses `comparer` to define the\r\n * sort order of `array` and replaces criteria objects with their corresponding\r\n * values.\r\n *\r\n * @private\r\n * @param {Array} array The array to sort.\r\n * @param {Function} comparer The function to define sort order.\r\n * @returns {Array} Returns `array`.\r\n */\r\n function baseSortBy(array, comparer) {\r\n var length = array.length;\r\n\r\n array.sort(comparer);\r\n while (length--) {\r\n array[length] = array[length].value;\r\n }\r\n return array;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.times` without support for iteratee shorthands\r\n * or max array length checks.\r\n *\r\n * @private\r\n * @param {number} n The number of times to invoke `iteratee`.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @returns {Array} Returns the array of results.\r\n */\r\n function baseTimes(n, iteratee) {\r\n var index = -1,\r\n result = Array(n);\r\n\r\n while (++index < n) {\r\n result[index] = iteratee(index);\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.unary` without support for storing metadata.\r\n *\r\n * @private\r\n * @param {Function} func The function to cap arguments for.\r\n * @returns {Function} Returns the new capped function.\r\n */\r\n function baseUnary(func) {\r\n return function(value) {\r\n return func(value);\r\n };\r\n }\r\n\r\n /**\r\n * The base implementation of `_.values` and `_.valuesIn` which creates an\r\n * array of `object` property values corresponding to the property names\r\n * of `props`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @param {Array} props The property names to get values for.\r\n * @returns {Object} Returns the array of property values.\r\n */\r\n function baseValues(object, props) {\r\n return arrayMap(props, function(key) {\r\n return object[key];\r\n });\r\n }\r\n\r\n /**\r\n * Checks if a `cache` value for `key` exists.\r\n *\r\n * @private\r\n * @param {Object} cache The cache to query.\r\n * @param {string} key The key of the entry to check.\r\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\r\n */\r\n function cacheHas(cache, key) {\r\n return cache.has(key);\r\n }\r\n\r\n /**\r\n * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol\r\n * that is not found in the character symbols.\r\n *\r\n * @private\r\n * @param {Array} strSymbols The string symbols to inspect.\r\n * @param {Array} chrSymbols The character symbols to find.\r\n * @returns {number} Returns the index of the first unmatched string symbol.\r\n */\r\n function charsStartIndex(strSymbols, chrSymbols) {\r\n var index = -1,\r\n length = strSymbols.length;\r\n\r\n while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\r\n return index;\r\n }\r\n\r\n /**\r\n * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol\r\n * that is not found in the character symbols.\r\n *\r\n * @private\r\n * @param {Array} strSymbols The string symbols to inspect.\r\n * @param {Array} chrSymbols The character symbols to find.\r\n * @returns {number} Returns the index of the last unmatched string symbol.\r\n */\r\n function charsEndIndex(strSymbols, chrSymbols) {\r\n var index = strSymbols.length;\r\n\r\n while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\r\n return index;\r\n }\r\n\r\n /**\r\n * Gets the number of `placeholder` occurrences in `array`.\r\n *\r\n * @private\r\n * @param {Array} array The array to inspect.\r\n * @param {*} placeholder The placeholder to search for.\r\n * @returns {number} Returns the placeholder count.\r\n */\r\n function countHolders(array, placeholder) {\r\n var length = array.length,\r\n result = 0;\r\n\r\n while (length--) {\r\n if (array[length] === placeholder) {\r\n ++result;\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Used by `_.escape` to convert characters to HTML entities.\r\n *\r\n * @private\r\n * @param {string} chr The matched character to escape.\r\n * @returns {string} Returns the escaped character.\r\n */\r\n var escapeHtmlChar = basePropertyOf(htmlEscapes);\r\n\r\n /**\r\n * Gets the value at `key` of `object`.\r\n *\r\n * @private\r\n * @param {Object} [object] The object to query.\r\n * @param {string} key The key of the property to get.\r\n * @returns {*} Returns the property value.\r\n */\r\n function getValue(object, key) {\r\n return object == null ? undefined : object[key];\r\n }\r\n\r\n /**\r\n * Checks if `string` contains Unicode symbols.\r\n *\r\n * @private\r\n * @param {string} string The string to inspect.\r\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\r\n */\r\n function hasUnicode(string) {\r\n return reHasUnicode.test(string);\r\n }\r\n\r\n /**\r\n * Converts `iterator` to an array.\r\n *\r\n * @private\r\n * @param {Object} iterator The iterator to convert.\r\n * @returns {Array} Returns the converted array.\r\n */\r\n function iteratorToArray(iterator) {\r\n var data,\r\n result = [];\r\n\r\n while (!(data = iterator.next()).done) {\r\n result.push(data.value);\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Converts `map` to its key-value pairs.\r\n *\r\n * @private\r\n * @param {Object} map The map to convert.\r\n * @returns {Array} Returns the key-value pairs.\r\n */\r\n function mapToArray(map) {\r\n var index = -1,\r\n result = Array(map.size);\r\n\r\n map.forEach(function(value, key) {\r\n result[++index] = [key, value];\r\n });\r\n return result;\r\n }\r\n\r\n /**\r\n * Creates a unary function that invokes `func` with its argument transformed.\r\n *\r\n * @private\r\n * @param {Function} func The function to wrap.\r\n * @param {Function} transform The argument transform.\r\n * @returns {Function} Returns the new function.\r\n */\r\n function overArg(func, transform) {\r\n return function(arg) {\r\n return func(transform(arg));\r\n };\r\n }\r\n\r\n /**\r\n * Replaces all `placeholder` elements in `array` with an internal placeholder\r\n * and returns an array of their indexes.\r\n *\r\n * @private\r\n * @param {Array} array The array to modify.\r\n * @param {*} placeholder The placeholder to replace.\r\n * @returns {Array} Returns the new array of placeholder indexes.\r\n */\r\n function replaceHolders(array, placeholder) {\r\n var index = -1,\r\n length = array.length,\r\n resIndex = 0,\r\n result = [];\r\n\r\n while (++index < length) {\r\n var value = array[index];\r\n if (value === placeholder || value === PLACEHOLDER) {\r\n array[index] = PLACEHOLDER;\r\n result[resIndex++] = index;\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Gets the value at `key`, unless `key` is \"__proto__\".\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @param {string} key The key of the property to get.\r\n * @returns {*} Returns the property value.\r\n */\r\n function safeGet(object, key) {\r\n return key == '__proto__'\r\n ? undefined\r\n : object[key];\r\n }\r\n\r\n /**\r\n * Converts `set` to an array of its values.\r\n *\r\n * @private\r\n * @param {Object} set The set to convert.\r\n * @returns {Array} Returns the values.\r\n */\r\n function setToArray(set) {\r\n var index = -1,\r\n result = Array(set.size);\r\n\r\n set.forEach(function(value) {\r\n result[++index] = value;\r\n });\r\n return result;\r\n }\r\n\r\n /**\r\n * A specialized version of `_.indexOf` which performs strict equality\r\n * comparisons of values, i.e. `===`.\r\n *\r\n * @private\r\n * @param {Array} array The array to inspect.\r\n * @param {*} value The value to search for.\r\n * @param {number} fromIndex The index to search from.\r\n * @returns {number} Returns the index of the matched value, else `-1`.\r\n */\r\n function strictIndexOf(array, value, fromIndex) {\r\n var index = fromIndex - 1,\r\n length = array.length;\r\n\r\n while (++index < length) {\r\n if (array[index] === value) {\r\n return index;\r\n }\r\n }\r\n return -1;\r\n }\r\n\r\n /**\r\n * Gets the number of symbols in `string`.\r\n *\r\n * @private\r\n * @param {string} string The string to inspect.\r\n * @returns {number} Returns the string size.\r\n */\r\n function stringSize(string) {\r\n return hasUnicode(string)\r\n ? unicodeSize(string)\r\n : asciiSize(string);\r\n }\r\n\r\n /**\r\n * Converts `string` to an array.\r\n *\r\n * @private\r\n * @param {string} string The string to convert.\r\n * @returns {Array} Returns the converted array.\r\n */\r\n function stringToArray(string) {\r\n return hasUnicode(string)\r\n ? unicodeToArray(string)\r\n : asciiToArray(string);\r\n }\r\n\r\n /**\r\n * Gets the size of a Unicode `string`.\r\n *\r\n * @private\r\n * @param {string} string The string inspect.\r\n * @returns {number} Returns the string size.\r\n */\r\n function unicodeSize(string) {\r\n var result = reUnicode.lastIndex = 0;\r\n while (reUnicode.test(string)) {\r\n ++result;\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Converts a Unicode `string` to an array.\r\n *\r\n * @private\r\n * @param {string} string The string to convert.\r\n * @returns {Array} Returns the converted array.\r\n */\r\n function unicodeToArray(string) {\r\n return string.match(reUnicode) || [];\r\n }\r\n\r\n /*--------------------------------------------------------------------------*/\r\n\r\n /** Used for built-in method references. */\r\n var arrayProto = Array.prototype,\r\n funcProto = Function.prototype,\r\n objectProto = Object.prototype;\r\n\r\n /** Used to detect overreaching core-js shims. */\r\n var coreJsData = root['__core-js_shared__'];\r\n\r\n /** Used to resolve the decompiled source of functions. */\r\n var funcToString = funcProto.toString;\r\n\r\n /** Used to check objects for own properties. */\r\n var hasOwnProperty = objectProto.hasOwnProperty;\r\n\r\n /** Used to generate unique IDs. */\r\n var idCounter = 0;\r\n\r\n /** Used to detect methods masquerading as native. */\r\n var maskSrcKey = (function() {\r\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\r\n return uid ? ('Symbol(src)_1.' + uid) : '';\r\n }());\r\n\r\n /**\r\n * Used to resolve the\r\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\r\n * of values.\r\n */\r\n var nativeObjectToString = objectProto.toString;\r\n\r\n /** Used to infer the `Object` constructor. */\r\n var objectCtorString = funcToString.call(Object);\r\n\r\n /** Used to restore the original `_` reference in `_.noConflict`. */\r\n var oldDash = root._;\r\n\r\n /** Used to detect if a method is native. */\r\n var reIsNative = RegExp('^' +\r\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\r\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\r\n );\r\n\r\n /** Built-in value references. */\r\n var Buffer = moduleExports ? root.Buffer : undefined,\r\n Symbol = root.Symbol,\r\n Uint8Array = root.Uint8Array,\r\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined,\r\n getPrototype = overArg(Object.getPrototypeOf, Object),\r\n objectCreate = Object.create,\r\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\r\n splice = arrayProto.splice,\r\n spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined,\r\n symIterator = Symbol ? Symbol.iterator : undefined,\r\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\r\n\r\n var defineProperty = (function() {\r\n try {\r\n var func = getNative(Object, 'defineProperty');\r\n func({}, '', {});\r\n return func;\r\n } catch (e) {}\r\n }());\r\n\r\n /* Built-in method references for those with the same name as other `lodash` methods. */\r\n var nativeCeil = Math.ceil,\r\n nativeFloor = Math.floor,\r\n nativeGetSymbols = Object.getOwnPropertySymbols,\r\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\r\n nativeIsFinite = root.isFinite,\r\n nativeKeys = overArg(Object.keys, Object),\r\n nativeMax = Math.max,\r\n nativeMin = Math.min,\r\n nativeNow = Date.now,\r\n nativeRandom = Math.random,\r\n nativeReverse = arrayProto.reverse;\r\n\r\n /* Built-in method references that are verified to be native. */\r\n var DataView = getNative(root, 'DataView'),\r\n Map = getNative(root, 'Map'),\r\n Promise = getNative(root, 'Promise'),\r\n Set = getNative(root, 'Set'),\r\n WeakMap = getNative(root, 'WeakMap'),\r\n nativeCreate = getNative(Object, 'create');\r\n\r\n /** Used to store function metadata. */\r\n var metaMap = WeakMap && new WeakMap;\r\n\r\n /** Used to lookup unminified function names. */\r\n var realNames = {};\r\n\r\n /** Used to detect maps, sets, and weakmaps. */\r\n var dataViewCtorString = toSource(DataView),\r\n mapCtorString = toSource(Map),\r\n promiseCtorString = toSource(Promise),\r\n setCtorString = toSource(Set),\r\n weakMapCtorString = toSource(WeakMap);\r\n\r\n /** Used to convert symbols to primitives and strings. */\r\n var symbolProto = Symbol ? Symbol.prototype : undefined,\r\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined,\r\n symbolToString = symbolProto ? symbolProto.toString : undefined;\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates a `lodash` object which wraps `value` to enable implicit method\r\n * chain sequences. Methods that operate on and return arrays, collections,\r\n * and functions can be chained together. Methods that retrieve a single value\r\n * or may return a primitive value will automatically end the chain sequence\r\n * and return the unwrapped value. Otherwise, the value must be unwrapped\r\n * with `_#value`.\r\n *\r\n * Explicit chain sequences, which must be unwrapped with `_#value`, may be\r\n * enabled using `_.chain`.\r\n *\r\n * The execution of chained methods is lazy, that is, it's deferred until\r\n * `_#value` is implicitly or explicitly called.\r\n *\r\n * Lazy evaluation allows several methods to support shortcut fusion.\r\n * Shortcut fusion is an optimization to merge iteratee calls; this avoids\r\n * the creation of intermediate arrays and can greatly reduce the number of\r\n * iteratee executions. Sections of a chain sequence qualify for shortcut\r\n * fusion if the section is applied to an array and iteratees accept only\r\n * one argument. The heuristic for whether a section qualifies for shortcut\r\n * fusion is subject to change.\r\n *\r\n * Chaining is supported in custom builds as long as the `_#value` method is\r\n * directly or indirectly included in the build.\r\n *\r\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\r\n *\r\n * The wrapper `Array` methods are:\r\n * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`\r\n *\r\n * The wrapper `String` methods are:\r\n * `replace` and `split`\r\n *\r\n * The wrapper methods that support shortcut fusion are:\r\n * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,\r\n * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,\r\n * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`\r\n *\r\n * The chainable wrapper methods are:\r\n * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,\r\n * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,\r\n * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,\r\n * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,\r\n * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,\r\n * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,\r\n * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,\r\n * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,\r\n * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,\r\n * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,\r\n * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,\r\n * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,\r\n * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,\r\n * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,\r\n * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,\r\n * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,\r\n * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,\r\n * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,\r\n * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,\r\n * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,\r\n * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,\r\n * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,\r\n * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,\r\n * `zipObject`, `zipObjectDeep`, and `zipWith`\r\n *\r\n * The wrapper methods that are **not** chainable by default are:\r\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,\r\n * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,\r\n * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,\r\n * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,\r\n * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,\r\n * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,\r\n * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,\r\n * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,\r\n * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,\r\n * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,\r\n * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,\r\n * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,\r\n * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,\r\n * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,\r\n * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,\r\n * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,\r\n * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,\r\n * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,\r\n * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,\r\n * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,\r\n * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,\r\n * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,\r\n * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,\r\n * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,\r\n * `upperFirst`, `value`, and `words`\r\n *\r\n * @name _\r\n * @constructor\r\n * @category Seq\r\n * @param {*} value The value to wrap in a `lodash` instance.\r\n * @returns {Object} Returns the new `lodash` wrapper instance.\r\n * @example\r\n *\r\n * function square(n) {\r\n * return n * n;\r\n * }\r\n *\r\n * var wrapped = _([1, 2, 3]);\r\n *\r\n * // Returns an unwrapped value.\r\n * wrapped.reduce(_.add);\r\n * // => 6\r\n *\r\n * // Returns a wrapped value.\r\n * var squares = wrapped.map(square);\r\n *\r\n * _.isArray(squares);\r\n * // => false\r\n *\r\n * _.isArray(squares.value());\r\n * // => true\r\n */\r\n function lodash(value) {\r\n if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\r\n if (value instanceof LodashWrapper) {\r\n return value;\r\n }\r\n if (hasOwnProperty.call(value, '__wrapped__')) {\r\n return wrapperClone(value);\r\n }\r\n }\r\n return new LodashWrapper(value);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.create` without support for assigning\r\n * properties to the created object.\r\n *\r\n * @private\r\n * @param {Object} proto The object to inherit from.\r\n * @returns {Object} Returns the new object.\r\n */\r\n var baseCreate = (function() {\r\n function object() {}\r\n return function(proto) {\r\n if (!isObject(proto)) {\r\n return {};\r\n }\r\n if (objectCreate) {\r\n return objectCreate(proto);\r\n }\r\n object.prototype = proto;\r\n var result = new object;\r\n object.prototype = undefined;\r\n return result;\r\n };\r\n }());\r\n\r\n /**\r\n * The function whose prototype chain sequence wrappers inherit from.\r\n *\r\n * @private\r\n */\r\n function baseLodash() {\r\n // No operation performed.\r\n }\r\n\r\n /**\r\n * The base constructor for creating `lodash` wrapper objects.\r\n *\r\n * @private\r\n * @param {*} value The value to wrap.\r\n * @param {boolean} [chainAll] Enable explicit method chain sequences.\r\n */\r\n function LodashWrapper(value, chainAll) {\r\n this.__wrapped__ = value;\r\n this.__actions__ = [];\r\n this.__chain__ = !!chainAll;\r\n this.__index__ = 0;\r\n this.__values__ = undefined;\r\n }\r\n\r\n // Ensure wrappers are instances of `baseLodash`.\r\n lodash.prototype = baseLodash.prototype;\r\n lodash.prototype.constructor = lodash;\r\n\r\n LodashWrapper.prototype = baseCreate(baseLodash.prototype);\r\n LodashWrapper.prototype.constructor = LodashWrapper;\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\r\n *\r\n * @private\r\n * @constructor\r\n * @param {*} value The value to wrap.\r\n */\r\n function LazyWrapper(value) {\r\n this.__wrapped__ = value;\r\n this.__actions__ = [];\r\n this.__dir__ = 1;\r\n this.__filtered__ = false;\r\n this.__iteratees__ = [];\r\n this.__takeCount__ = MAX_ARRAY_LENGTH;\r\n this.__views__ = [];\r\n }\r\n\r\n /**\r\n * Creates a clone of the lazy wrapper object.\r\n *\r\n * @private\r\n * @name clone\r\n * @memberOf LazyWrapper\r\n * @returns {Object} Returns the cloned `LazyWrapper` object.\r\n */\r\n function lazyClone() {\r\n var result = new LazyWrapper(this.__wrapped__);\r\n result.__actions__ = copyArray(this.__actions__);\r\n result.__dir__ = this.__dir__;\r\n result.__filtered__ = this.__filtered__;\r\n result.__iteratees__ = copyArray(this.__iteratees__);\r\n result.__takeCount__ = this.__takeCount__;\r\n result.__views__ = copyArray(this.__views__);\r\n return result;\r\n }\r\n\r\n /**\r\n * Reverses the direction of lazy iteration.\r\n *\r\n * @private\r\n * @name reverse\r\n * @memberOf LazyWrapper\r\n * @returns {Object} Returns the new reversed `LazyWrapper` object.\r\n */\r\n function lazyReverse() {\r\n if (this.__filtered__) {\r\n var result = new LazyWrapper(this);\r\n result.__dir__ = -1;\r\n result.__filtered__ = true;\r\n } else {\r\n result = this.clone();\r\n result.__dir__ *= -1;\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Extracts the unwrapped value from its lazy wrapper.\r\n *\r\n * @private\r\n * @name value\r\n * @memberOf LazyWrapper\r\n * @returns {*} Returns the unwrapped value.\r\n */\r\n function lazyValue() {\r\n var array = this.__wrapped__.value(),\r\n dir = this.__dir__,\r\n isArr = isArray(array),\r\n isRight = dir < 0,\r\n arrLength = isArr ? array.length : 0,\r\n view = getView(0, arrLength, this.__views__),\r\n start = view.start,\r\n end = view.end,\r\n length = end - start,\r\n index = isRight ? end : (start - 1),\r\n iteratees = this.__iteratees__,\r\n iterLength = iteratees.length,\r\n resIndex = 0,\r\n takeCount = nativeMin(length, this.__takeCount__);\r\n\r\n if (!isArr || (!isRight && arrLength == length && takeCount == length)) {\r\n return baseWrapperValue(array, this.__actions__);\r\n }\r\n var result = [];\r\n\r\n outer:\r\n while (length-- && resIndex < takeCount) {\r\n index += dir;\r\n\r\n var iterIndex = -1,\r\n value = array[index];\r\n\r\n while (++iterIndex < iterLength) {\r\n var data = iteratees[iterIndex],\r\n iteratee = data.iteratee,\r\n type = data.type,\r\n computed = iteratee(value);\r\n\r\n if (type == LAZY_MAP_FLAG) {\r\n value = computed;\r\n } else if (!computed) {\r\n if (type == LAZY_FILTER_FLAG) {\r\n continue outer;\r\n } else {\r\n break outer;\r\n }\r\n }\r\n }\r\n result[resIndex++] = value;\r\n }\r\n return result;\r\n }\r\n\r\n // Ensure `LazyWrapper` is an instance of `baseLodash`.\r\n LazyWrapper.prototype = baseCreate(baseLodash.prototype);\r\n LazyWrapper.prototype.constructor = LazyWrapper;\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates a hash object.\r\n *\r\n * @private\r\n * @constructor\r\n * @param {Array} [entries] The key-value pairs to cache.\r\n */\r\n function Hash(entries) {\r\n var index = -1,\r\n length = entries == null ? 0 : entries.length;\r\n\r\n this.clear();\r\n while (++index < length) {\r\n var entry = entries[index];\r\n this.set(entry[0], entry[1]);\r\n }\r\n }\r\n\r\n /**\r\n * Removes all key-value entries from the hash.\r\n *\r\n * @private\r\n * @name clear\r\n * @memberOf Hash\r\n */\r\n function hashClear() {\r\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\r\n this.size = 0;\r\n }\r\n\r\n /**\r\n * Removes `key` and its value from the hash.\r\n *\r\n * @private\r\n * @name delete\r\n * @memberOf Hash\r\n * @param {Object} hash The hash to modify.\r\n * @param {string} key The key of the value to remove.\r\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\r\n */\r\n function hashDelete(key) {\r\n var result = this.has(key) && delete this.__data__[key];\r\n this.size -= result ? 1 : 0;\r\n return result;\r\n }\r\n\r\n /**\r\n * Gets the hash value for `key`.\r\n *\r\n * @private\r\n * @name get\r\n * @memberOf Hash\r\n * @param {string} key The key of the value to get.\r\n * @returns {*} Returns the entry value.\r\n */\r\n function hashGet(key) {\r\n var data = this.__data__;\r\n if (nativeCreate) {\r\n var result = data[key];\r\n return result === HASH_UNDEFINED ? undefined : result;\r\n }\r\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\r\n }\r\n\r\n /**\r\n * Checks if a hash value for `key` exists.\r\n *\r\n * @private\r\n * @name has\r\n * @memberOf Hash\r\n * @param {string} key The key of the entry to check.\r\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\r\n */\r\n function hashHas(key) {\r\n var data = this.__data__;\r\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\r\n }\r\n\r\n /**\r\n * Sets the hash `key` to `value`.\r\n *\r\n * @private\r\n * @name set\r\n * @memberOf Hash\r\n * @param {string} key The key of the value to set.\r\n * @param {*} value The value to set.\r\n * @returns {Object} Returns the hash instance.\r\n */\r\n function hashSet(key, value) {\r\n var data = this.__data__;\r\n this.size += this.has(key) ? 0 : 1;\r\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\r\n return this;\r\n }\r\n\r\n // Add methods to `Hash`.\r\n Hash.prototype.clear = hashClear;\r\n Hash.prototype['delete'] = hashDelete;\r\n Hash.prototype.get = hashGet;\r\n Hash.prototype.has = hashHas;\r\n Hash.prototype.set = hashSet;\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates an list cache object.\r\n *\r\n * @private\r\n * @constructor\r\n * @param {Array} [entries] The key-value pairs to cache.\r\n */\r\n function ListCache(entries) {\r\n var index = -1,\r\n length = entries == null ? 0 : entries.length;\r\n\r\n this.clear();\r\n while (++index < length) {\r\n var entry = entries[index];\r\n this.set(entry[0], entry[1]);\r\n }\r\n }\r\n\r\n /**\r\n * Removes all key-value entries from the list cache.\r\n *\r\n * @private\r\n * @name clear\r\n * @memberOf ListCache\r\n */\r\n function listCacheClear() {\r\n this.__data__ = [];\r\n this.size = 0;\r\n }\r\n\r\n /**\r\n * Removes `key` and its value from the list cache.\r\n *\r\n * @private\r\n * @name delete\r\n * @memberOf ListCache\r\n * @param {string} key The key of the value to remove.\r\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\r\n */\r\n function listCacheDelete(key) {\r\n var data = this.__data__,\r\n index = assocIndexOf(data, key);\r\n\r\n if (index < 0) {\r\n return false;\r\n }\r\n var lastIndex = data.length - 1;\r\n if (index == lastIndex) {\r\n data.pop();\r\n } else {\r\n splice.call(data, index, 1);\r\n }\r\n --this.size;\r\n return true;\r\n }\r\n\r\n /**\r\n * Gets the list cache value for `key`.\r\n *\r\n * @private\r\n * @name get\r\n * @memberOf ListCache\r\n * @param {string} key The key of the value to get.\r\n * @returns {*} Returns the entry value.\r\n */\r\n function listCacheGet(key) {\r\n var data = this.__data__,\r\n index = assocIndexOf(data, key);\r\n\r\n return index < 0 ? undefined : data[index][1];\r\n }\r\n\r\n /**\r\n * Checks if a list cache value for `key` exists.\r\n *\r\n * @private\r\n * @name has\r\n * @memberOf ListCache\r\n * @param {string} key The key of the entry to check.\r\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\r\n */\r\n function listCacheHas(key) {\r\n return assocIndexOf(this.__data__, key) > -1;\r\n }\r\n\r\n /**\r\n * Sets the list cache `key` to `value`.\r\n *\r\n * @private\r\n * @name set\r\n * @memberOf ListCache\r\n * @param {string} key The key of the value to set.\r\n * @param {*} value The value to set.\r\n * @returns {Object} Returns the list cache instance.\r\n */\r\n function listCacheSet(key, value) {\r\n var data = this.__data__,\r\n index = assocIndexOf(data, key);\r\n\r\n if (index < 0) {\r\n ++this.size;\r\n data.push([key, value]);\r\n } else {\r\n data[index][1] = value;\r\n }\r\n return this;\r\n }\r\n\r\n // Add methods to `ListCache`.\r\n ListCache.prototype.clear = listCacheClear;\r\n ListCache.prototype['delete'] = listCacheDelete;\r\n ListCache.prototype.get = listCacheGet;\r\n ListCache.prototype.has = listCacheHas;\r\n ListCache.prototype.set = listCacheSet;\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates a map cache object to store key-value pairs.\r\n *\r\n * @private\r\n * @constructor\r\n * @param {Array} [entries] The key-value pairs to cache.\r\n */\r\n function MapCache(entries) {\r\n var index = -1,\r\n length = entries == null ? 0 : entries.length;\r\n\r\n this.clear();\r\n while (++index < length) {\r\n var entry = entries[index];\r\n this.set(entry[0], entry[1]);\r\n }\r\n }\r\n\r\n /**\r\n * Removes all key-value entries from the map.\r\n *\r\n * @private\r\n * @name clear\r\n * @memberOf MapCache\r\n */\r\n function mapCacheClear() {\r\n this.size = 0;\r\n this.__data__ = {\r\n 'hash': new Hash,\r\n 'map': new (Map || ListCache),\r\n 'string': new Hash\r\n };\r\n }\r\n\r\n /**\r\n * Removes `key` and its value from the map.\r\n *\r\n * @private\r\n * @name delete\r\n * @memberOf MapCache\r\n * @param {string} key The key of the value to remove.\r\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\r\n */\r\n function mapCacheDelete(key) {\r\n var result = getMapData(this, key)['delete'](key);\r\n this.size -= result ? 1 : 0;\r\n return result;\r\n }\r\n\r\n /**\r\n * Gets the map value for `key`.\r\n *\r\n * @private\r\n * @name get\r\n * @memberOf MapCache\r\n * @param {string} key The key of the value to get.\r\n * @returns {*} Returns the entry value.\r\n */\r\n function mapCacheGet(key) {\r\n return getMapData(this, key).get(key);\r\n }\r\n\r\n /**\r\n * Checks if a map value for `key` exists.\r\n *\r\n * @private\r\n * @name has\r\n * @memberOf MapCache\r\n * @param {string} key The key of the entry to check.\r\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\r\n */\r\n function mapCacheHas(key) {\r\n return getMapData(this, key).has(key);\r\n }\r\n\r\n /**\r\n * Sets the map `key` to `value`.\r\n *\r\n * @private\r\n * @name set\r\n * @memberOf MapCache\r\n * @param {string} key The key of the value to set.\r\n * @param {*} value The value to set.\r\n * @returns {Object} Returns the map cache instance.\r\n */\r\n function mapCacheSet(key, value) {\r\n var data = getMapData(this, key),\r\n size = data.size;\r\n\r\n data.set(key, value);\r\n this.size += data.size == size ? 0 : 1;\r\n return this;\r\n }\r\n\r\n // Add methods to `MapCache`.\r\n MapCache.prototype.clear = mapCacheClear;\r\n MapCache.prototype['delete'] = mapCacheDelete;\r\n MapCache.prototype.get = mapCacheGet;\r\n MapCache.prototype.has = mapCacheHas;\r\n MapCache.prototype.set = mapCacheSet;\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n *\r\n * Creates an array cache object to store unique values.\r\n *\r\n * @private\r\n * @constructor\r\n * @param {Array} [values] The values to cache.\r\n */\r\n function SetCache(values) {\r\n var index = -1,\r\n length = values == null ? 0 : values.length;\r\n\r\n this.__data__ = new MapCache;\r\n while (++index < length) {\r\n this.add(values[index]);\r\n }\r\n }\r\n\r\n /**\r\n * Adds `value` to the array cache.\r\n *\r\n * @private\r\n * @name add\r\n * @memberOf SetCache\r\n * @alias push\r\n * @param {*} value The value to cache.\r\n * @returns {Object} Returns the cache instance.\r\n */\r\n function setCacheAdd(value) {\r\n this.__data__.set(value, HASH_UNDEFINED);\r\n return this;\r\n }\r\n\r\n /**\r\n * Checks if `value` is in the array cache.\r\n *\r\n * @private\r\n * @name has\r\n * @memberOf SetCache\r\n * @param {*} value The value to search for.\r\n * @returns {number} Returns `true` if `value` is found, else `false`.\r\n */\r\n function setCacheHas(value) {\r\n return this.__data__.has(value);\r\n }\r\n\r\n // Add methods to `SetCache`.\r\n SetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\r\n SetCache.prototype.has = setCacheHas;\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates a stack cache object to store key-value pairs.\r\n *\r\n * @private\r\n * @constructor\r\n * @param {Array} [entries] The key-value pairs to cache.\r\n */\r\n function Stack(entries) {\r\n var data = this.__data__ = new ListCache(entries);\r\n this.size = data.size;\r\n }\r\n\r\n /**\r\n * Removes all key-value entries from the stack.\r\n *\r\n * @private\r\n * @name clear\r\n * @memberOf Stack\r\n */\r\n function stackClear() {\r\n this.__data__ = new ListCache;\r\n this.size = 0;\r\n }\r\n\r\n /**\r\n * Removes `key` and its value from the stack.\r\n *\r\n * @private\r\n * @name delete\r\n * @memberOf Stack\r\n * @param {string} key The key of the value to remove.\r\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\r\n */\r\n function stackDelete(key) {\r\n var data = this.__data__,\r\n result = data['delete'](key);\r\n\r\n this.size = data.size;\r\n return result;\r\n }\r\n\r\n /**\r\n * Gets the stack value for `key`.\r\n *\r\n * @private\r\n * @name get\r\n * @memberOf Stack\r\n * @param {string} key The key of the value to get.\r\n * @returns {*} Returns the entry value.\r\n */\r\n function stackGet(key) {\r\n return this.__data__.get(key);\r\n }\r\n\r\n /**\r\n * Checks if a stack value for `key` exists.\r\n *\r\n * @private\r\n * @name has\r\n * @memberOf Stack\r\n * @param {string} key The key of the entry to check.\r\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\r\n */\r\n function stackHas(key) {\r\n return this.__data__.has(key);\r\n }\r\n\r\n /**\r\n * Sets the stack `key` to `value`.\r\n *\r\n * @private\r\n * @name set\r\n * @memberOf Stack\r\n * @param {string} key The key of the value to set.\r\n * @param {*} value The value to set.\r\n * @returns {Object} Returns the stack cache instance.\r\n */\r\n function stackSet(key, value) {\r\n var data = this.__data__;\r\n if (data instanceof ListCache) {\r\n var pairs = data.__data__;\r\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\r\n pairs.push([key, value]);\r\n this.size = ++data.size;\r\n return this;\r\n }\r\n data = this.__data__ = new MapCache(pairs);\r\n }\r\n data.set(key, value);\r\n this.size = data.size;\r\n return this;\r\n }\r\n\r\n // Add methods to `Stack`.\r\n Stack.prototype.clear = stackClear;\r\n Stack.prototype['delete'] = stackDelete;\r\n Stack.prototype.get = stackGet;\r\n Stack.prototype.has = stackHas;\r\n Stack.prototype.set = stackSet;\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates an array of the enumerable property names of the array-like `value`.\r\n *\r\n * @private\r\n * @param {*} value The value to query.\r\n * @param {boolean} inherited Specify returning inherited property names.\r\n * @returns {Array} Returns the array of property names.\r\n */\r\n function arrayLikeKeys(value, inherited) {\r\n var isArr = isArray(value),\r\n isArg = !isArr && isArguments(value),\r\n isBuff = !isArr && !isArg && isBuffer(value),\r\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\r\n skipIndexes = isArr || isArg || isBuff || isType,\r\n result = skipIndexes ? baseTimes(value.length, String) : [],\r\n length = result.length;\r\n\r\n for (var key in value) {\r\n if ((inherited || hasOwnProperty.call(value, key)) &&\r\n !(skipIndexes && (\r\n // Safari 9 has enumerable `arguments.length` in strict mode.\r\n key == 'length' ||\r\n // Node.js 0.10 has enumerable non-index properties on buffers.\r\n (isBuff && (key == 'offset' || key == 'parent')) ||\r\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\r\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\r\n // Skip index properties.\r\n isIndex(key, length)\r\n ))) {\r\n result.push(key);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * This function is like `assignValue` except that it doesn't assign\r\n * `undefined` values.\r\n *\r\n * @private\r\n * @param {Object} object The object to modify.\r\n * @param {string} key The key of the property to assign.\r\n * @param {*} value The value to assign.\r\n */\r\n function assignMergeValue(object, key, value) {\r\n if ((value !== undefined && !eq(object[key], value)) ||\r\n (value === undefined && !(key in object))) {\r\n baseAssignValue(object, key, value);\r\n }\r\n }\r\n\r\n /**\r\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\r\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\r\n * for equality comparisons.\r\n *\r\n * @private\r\n * @param {Object} object The object to modify.\r\n * @param {string} key The key of the property to assign.\r\n * @param {*} value The value to assign.\r\n */\r\n function assignValue(object, key, value) {\r\n var objValue = object[key];\r\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\r\n (value === undefined && !(key in object))) {\r\n baseAssignValue(object, key, value);\r\n }\r\n }\r\n\r\n /**\r\n * Gets the index at which the `key` is found in `array` of key-value pairs.\r\n *\r\n * @private\r\n * @param {Array} array The array to inspect.\r\n * @param {*} key The key to search for.\r\n * @returns {number} Returns the index of the matched value, else `-1`.\r\n */\r\n function assocIndexOf(array, key) {\r\n var length = array.length;\r\n while (length--) {\r\n if (eq(array[length][0], key)) {\r\n return length;\r\n }\r\n }\r\n return -1;\r\n }\r\n\r\n /**\r\n * Aggregates elements of `collection` on `accumulator` with keys transformed\r\n * by `iteratee` and values set by `setter`.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} setter The function to set `accumulator` values.\r\n * @param {Function} iteratee The iteratee to transform keys.\r\n * @param {Object} accumulator The initial aggregated object.\r\n * @returns {Function} Returns `accumulator`.\r\n */\r\n function baseAggregator(collection, setter, iteratee, accumulator) {\r\n baseEach(collection, function(value, key, collection) {\r\n setter(accumulator, value, iteratee(value), collection);\r\n });\r\n return accumulator;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.assign` without support for multiple sources\r\n * or `customizer` functions.\r\n *\r\n * @private\r\n * @param {Object} object The destination object.\r\n * @param {Object} source The source object.\r\n * @returns {Object} Returns `object`.\r\n */\r\n function baseAssign(object, source) {\r\n return object && copyObject(source, keys(source), object);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.assignIn` without support for multiple sources\r\n * or `customizer` functions.\r\n *\r\n * @private\r\n * @param {Object} object The destination object.\r\n * @param {Object} source The source object.\r\n * @returns {Object} Returns `object`.\r\n */\r\n function baseAssignIn(object, source) {\r\n return object && copyObject(source, keysIn(source), object);\r\n }\r\n\r\n /**\r\n * The base implementation of `assignValue` and `assignMergeValue` without\r\n * value checks.\r\n *\r\n * @private\r\n * @param {Object} object The object to modify.\r\n * @param {string} key The key of the property to assign.\r\n * @param {*} value The value to assign.\r\n */\r\n function baseAssignValue(object, key, value) {\r\n if (key == '__proto__' && defineProperty) {\r\n defineProperty(object, key, {\r\n 'configurable': true,\r\n 'enumerable': true,\r\n 'value': value,\r\n 'writable': true\r\n });\r\n } else {\r\n object[key] = value;\r\n }\r\n }\r\n\r\n /**\r\n * The base implementation of `_.at` without support for individual paths.\r\n *\r\n * @private\r\n * @param {Object} object The object to iterate over.\r\n * @param {string[]} paths The property paths to pick.\r\n * @returns {Array} Returns the picked elements.\r\n */\r\n function baseAt(object, paths) {\r\n var index = -1,\r\n length = paths.length,\r\n result = Array(length),\r\n skip = object == null;\r\n\r\n while (++index < length) {\r\n result[index] = skip ? undefined : get(object, paths[index]);\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.clamp` which doesn't coerce arguments.\r\n *\r\n * @private\r\n * @param {number} number The number to clamp.\r\n * @param {number} [lower] The lower bound.\r\n * @param {number} upper The upper bound.\r\n * @returns {number} Returns the clamped number.\r\n */\r\n function baseClamp(number, lower, upper) {\r\n if (number === number) {\r\n if (upper !== undefined) {\r\n number = number <= upper ? number : upper;\r\n }\r\n if (lower !== undefined) {\r\n number = number >= lower ? number : lower;\r\n }\r\n }\r\n return number;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\r\n * traversed objects.\r\n *\r\n * @private\r\n * @param {*} value The value to clone.\r\n * @param {boolean} bitmask The bitmask flags.\r\n * 1 - Deep clone\r\n * 2 - Flatten inherited properties\r\n * 4 - Clone symbols\r\n * @param {Function} [customizer] The function to customize cloning.\r\n * @param {string} [key] The key of `value`.\r\n * @param {Object} [object] The parent object of `value`.\r\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\r\n * @returns {*} Returns the cloned value.\r\n */\r\n function baseClone(value, bitmask, customizer, key, object, stack) {\r\n var result,\r\n isDeep = bitmask & CLONE_DEEP_FLAG,\r\n isFlat = bitmask & CLONE_FLAT_FLAG,\r\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\r\n\r\n if (customizer) {\r\n result = object ? customizer(value, key, object, stack) : customizer(value);\r\n }\r\n if (result !== undefined) {\r\n return result;\r\n }\r\n if (!isObject(value)) {\r\n return value;\r\n }\r\n var isArr = isArray(value);\r\n if (isArr) {\r\n result = initCloneArray(value);\r\n if (!isDeep) {\r\n return copyArray(value, result);\r\n }\r\n } else {\r\n var tag = getTag(value),\r\n isFunc = tag == funcTag || tag == genTag;\r\n\r\n if (isBuffer(value)) {\r\n return cloneBuffer(value, isDeep);\r\n }\r\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\r\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\r\n if (!isDeep) {\r\n return isFlat\r\n ? copySymbolsIn(value, baseAssignIn(result, value))\r\n : copySymbols(value, baseAssign(result, value));\r\n }\r\n } else {\r\n if (!cloneableTags[tag]) {\r\n return object ? value : {};\r\n }\r\n result = initCloneByTag(value, tag, isDeep);\r\n }\r\n }\r\n // Check for circular references and return its corresponding clone.\r\n stack || (stack = new Stack);\r\n var stacked = stack.get(value);\r\n if (stacked) {\r\n return stacked;\r\n }\r\n stack.set(value, result);\r\n\r\n if (isSet(value)) {\r\n value.forEach(function(subValue) {\r\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\r\n });\r\n\r\n return result;\r\n }\r\n\r\n if (isMap(value)) {\r\n value.forEach(function(subValue, key) {\r\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\r\n });\r\n\r\n return result;\r\n }\r\n\r\n var keysFunc = isFull\r\n ? (isFlat ? getAllKeysIn : getAllKeys)\r\n : (isFlat ? keysIn : keys);\r\n\r\n var props = isArr ? undefined : keysFunc(value);\r\n arrayEach(props || value, function(subValue, key) {\r\n if (props) {\r\n key = subValue;\r\n subValue = value[key];\r\n }\r\n // Recursively populate clone (susceptible to call stack limits).\r\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\r\n });\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.delay` and `_.defer` which accepts `args`\r\n * to provide to `func`.\r\n *\r\n * @private\r\n * @param {Function} func The function to delay.\r\n * @param {number} wait The number of milliseconds to delay invocation.\r\n * @param {Array} args The arguments to provide to `func`.\r\n * @returns {number|Object} Returns the timer id or timeout object.\r\n */\r\n function baseDelay(func, wait, args) {\r\n if (typeof func != 'function') {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n return setTimeout(function() { func.apply(undefined, args); }, wait);\r\n }\r\n\r\n /**\r\n * The base implementation of methods like `_.difference` without support\r\n * for excluding multiple arrays or iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array} array The array to inspect.\r\n * @param {Array} values The values to exclude.\r\n * @param {Function} [iteratee] The iteratee invoked per element.\r\n * @param {Function} [comparator] The comparator invoked per element.\r\n * @returns {Array} Returns the new array of filtered values.\r\n */\r\n function baseDifference(array, values, iteratee, comparator) {\r\n var index = -1,\r\n includes = arrayIncludes,\r\n isCommon = true,\r\n length = array.length,\r\n result = [],\r\n valuesLength = values.length;\r\n\r\n if (!length) {\r\n return result;\r\n }\r\n if (iteratee) {\r\n values = arrayMap(values, baseUnary(iteratee));\r\n }\r\n if (comparator) {\r\n includes = arrayIncludesWith;\r\n isCommon = false;\r\n }\r\n else if (values.length >= LARGE_ARRAY_SIZE) {\r\n includes = cacheHas;\r\n isCommon = false;\r\n values = new SetCache(values);\r\n }\r\n outer:\r\n while (++index < length) {\r\n var value = array[index],\r\n computed = iteratee == null ? value : iteratee(value);\r\n\r\n value = (comparator || value !== 0) ? value : 0;\r\n if (isCommon && computed === computed) {\r\n var valuesIndex = valuesLength;\r\n while (valuesIndex--) {\r\n if (values[valuesIndex] === computed) {\r\n continue outer;\r\n }\r\n }\r\n result.push(value);\r\n }\r\n else if (!includes(values, computed, comparator)) {\r\n result.push(value);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.forEach` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @returns {Array|Object} Returns `collection`.\r\n */\r\n var baseEach = createBaseEach(baseForOwn);\r\n\r\n /**\r\n * The base implementation of `_.every` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} predicate The function invoked per iteration.\r\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\r\n * else `false`\r\n */\r\n function baseEvery(collection, predicate) {\r\n var result = true;\r\n baseEach(collection, function(value, index, collection) {\r\n result = !!predicate(value, index, collection);\r\n return result;\r\n });\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of methods like `_.max` and `_.min` which accepts a\r\n * `comparator` to determine the extremum value.\r\n *\r\n * @private\r\n * @param {Array} array The array to iterate over.\r\n * @param {Function} iteratee The iteratee invoked per iteration.\r\n * @param {Function} comparator The comparator used to compare values.\r\n * @returns {*} Returns the extremum value.\r\n */\r\n function baseExtremum(array, iteratee, comparator) {\r\n var index = -1,\r\n length = array.length;\r\n\r\n while (++index < length) {\r\n var value = array[index],\r\n current = iteratee(value);\r\n\r\n if (current != null && (computed === undefined\r\n ? (current === current && !isSymbol(current))\r\n : comparator(current, computed)\r\n )) {\r\n var computed = current,\r\n result = value;\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.filter` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} predicate The function invoked per iteration.\r\n * @returns {Array} Returns the new filtered array.\r\n */\r\n function baseFilter(collection, predicate) {\r\n var result = [];\r\n baseEach(collection, function(value, index, collection) {\r\n if (predicate(value, index, collection)) {\r\n result.push(value);\r\n }\r\n });\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.flatten` with support for restricting flattening.\r\n *\r\n * @private\r\n * @param {Array} array The array to flatten.\r\n * @param {number} depth The maximum recursion depth.\r\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\r\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\r\n * @param {Array} [result=[]] The initial result value.\r\n * @returns {Array} Returns the new flattened array.\r\n */\r\n function baseFlatten(array, depth, predicate, isStrict, result) {\r\n var index = -1,\r\n length = array.length;\r\n\r\n predicate || (predicate = isFlattenable);\r\n result || (result = []);\r\n\r\n while (++index < length) {\r\n var value = array[index];\r\n if (depth > 0 && predicate(value)) {\r\n if (depth > 1) {\r\n // Recursively flatten arrays (susceptible to call stack limits).\r\n baseFlatten(value, depth - 1, predicate, isStrict, result);\r\n } else {\r\n arrayPush(result, value);\r\n }\r\n } else if (!isStrict) {\r\n result[result.length] = value;\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `baseForOwn` which iterates over `object`\r\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\r\n * Iteratee functions may exit iteration early by explicitly returning `false`.\r\n *\r\n * @private\r\n * @param {Object} object The object to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @param {Function} keysFunc The function to get the keys of `object`.\r\n * @returns {Object} Returns `object`.\r\n */\r\n var baseFor = createBaseFor();\r\n\r\n /**\r\n * This function is like `baseFor` except that it iterates over properties\r\n * in the opposite order.\r\n *\r\n * @private\r\n * @param {Object} object The object to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @param {Function} keysFunc The function to get the keys of `object`.\r\n * @returns {Object} Returns `object`.\r\n */\r\n var baseForRight = createBaseFor(true);\r\n\r\n /**\r\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Object} object The object to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @returns {Object} Returns `object`.\r\n */\r\n function baseForOwn(object, iteratee) {\r\n return object && baseFor(object, iteratee, keys);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.forOwnRight` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Object} object The object to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @returns {Object} Returns `object`.\r\n */\r\n function baseForOwnRight(object, iteratee) {\r\n return object && baseForRight(object, iteratee, keys);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.functions` which creates an array of\r\n * `object` function property names filtered from `props`.\r\n *\r\n * @private\r\n * @param {Object} object The object to inspect.\r\n * @param {Array} props The property names to filter.\r\n * @returns {Array} Returns the function names.\r\n */\r\n function baseFunctions(object, props) {\r\n return arrayFilter(props, function(key) {\r\n return isFunction(object[key]);\r\n });\r\n }\r\n\r\n /**\r\n * The base implementation of `_.get` without support for default values.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @param {Array|string} path The path of the property to get.\r\n * @returns {*} Returns the resolved value.\r\n */\r\n function baseGet(object, path) {\r\n path = castPath(path, object);\r\n\r\n var index = 0,\r\n length = path.length;\r\n\r\n while (object != null && index < length) {\r\n object = object[toKey(path[index++])];\r\n }\r\n return (index && index == length) ? object : undefined;\r\n }\r\n\r\n /**\r\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\r\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\r\n * symbols of `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @param {Function} keysFunc The function to get the keys of `object`.\r\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\r\n * @returns {Array} Returns the array of property names and symbols.\r\n */\r\n function baseGetAllKeys(object, keysFunc, symbolsFunc) {\r\n var result = keysFunc(object);\r\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\r\n }\r\n\r\n /**\r\n * The base implementation of `getTag` without fallbacks for buggy environments.\r\n *\r\n * @private\r\n * @param {*} value The value to query.\r\n * @returns {string} Returns the `toStringTag`.\r\n */\r\n function baseGetTag(value) {\r\n if (value == null) {\r\n return value === undefined ? undefinedTag : nullTag;\r\n }\r\n return (symToStringTag && symToStringTag in Object(value))\r\n ? getRawTag(value)\r\n : objectToString(value);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.gt` which doesn't coerce arguments.\r\n *\r\n * @private\r\n * @param {*} value The value to compare.\r\n * @param {*} other The other value to compare.\r\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\r\n * else `false`.\r\n */\r\n function baseGt(value, other) {\r\n return value > other;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.has` without support for deep paths.\r\n *\r\n * @private\r\n * @param {Object} [object] The object to query.\r\n * @param {Array|string} key The key to check.\r\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\r\n */\r\n function baseHas(object, key) {\r\n return object != null && hasOwnProperty.call(object, key);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.hasIn` without support for deep paths.\r\n *\r\n * @private\r\n * @param {Object} [object] The object to query.\r\n * @param {Array|string} key The key to check.\r\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\r\n */\r\n function baseHasIn(object, key) {\r\n return object != null && key in Object(object);\r\n }\r\n\r\n /**\r\n * The base implementation of methods like `_.intersection`, without support\r\n * for iteratee shorthands, that accepts an array of arrays to inspect.\r\n *\r\n * @private\r\n * @param {Array} arrays The arrays to inspect.\r\n * @param {Function} [iteratee] The iteratee invoked per element.\r\n * @param {Function} [comparator] The comparator invoked per element.\r\n * @returns {Array} Returns the new array of shared values.\r\n */\r\n function baseIntersection(arrays, iteratee, comparator) {\r\n var includes = comparator ? arrayIncludesWith : arrayIncludes,\r\n length = arrays[0].length,\r\n othLength = arrays.length,\r\n othIndex = othLength,\r\n caches = Array(othLength),\r\n maxLength = Infinity,\r\n result = [];\r\n\r\n while (othIndex--) {\r\n var array = arrays[othIndex];\r\n if (othIndex && iteratee) {\r\n array = arrayMap(array, baseUnary(iteratee));\r\n }\r\n maxLength = nativeMin(array.length, maxLength);\r\n caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120))\r\n ? new SetCache(othIndex && array)\r\n : undefined;\r\n }\r\n array = arrays[0];\r\n\r\n var index = -1,\r\n seen = caches[0];\r\n\r\n outer:\r\n while (++index < length && result.length < maxLength) {\r\n var value = array[index],\r\n computed = iteratee ? iteratee(value) : value;\r\n\r\n value = (comparator || value !== 0) ? value : 0;\r\n if (!(seen\r\n ? cacheHas(seen, computed)\r\n : includes(result, computed, comparator)\r\n )) {\r\n othIndex = othLength;\r\n while (--othIndex) {\r\n var cache = caches[othIndex];\r\n if (!(cache\r\n ? cacheHas(cache, computed)\r\n : includes(arrays[othIndex], computed, comparator))\r\n ) {\r\n continue outer;\r\n }\r\n }\r\n if (seen) {\r\n seen.push(computed);\r\n }\r\n result.push(value);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.invert` and `_.invertBy` which inverts\r\n * `object` with values transformed by `iteratee` and set by `setter`.\r\n *\r\n * @private\r\n * @param {Object} object The object to iterate over.\r\n * @param {Function} setter The function to set `accumulator` values.\r\n * @param {Function} iteratee The iteratee to transform values.\r\n * @param {Object} accumulator The initial inverted object.\r\n * @returns {Function} Returns `accumulator`.\r\n */\r\n function baseInverter(object, setter, iteratee, accumulator) {\r\n baseForOwn(object, function(value, key, object) {\r\n setter(accumulator, iteratee(value), key, object);\r\n });\r\n return accumulator;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.invoke` without support for individual\r\n * method arguments.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @param {Array|string} path The path of the method to invoke.\r\n * @param {Array} args The arguments to invoke the method with.\r\n * @returns {*} Returns the result of the invoked method.\r\n */\r\n function baseInvoke(object, path, args) {\r\n path = castPath(path, object);\r\n object = parent(object, path);\r\n var func = object == null ? object : object[toKey(last(path))];\r\n return func == null ? undefined : apply(func, object, args);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isArguments`.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\r\n */\r\n function baseIsArguments(value) {\r\n return isObjectLike(value) && baseGetTag(value) == argsTag;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isDate` without Node.js optimizations.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\r\n */\r\n function baseIsDate(value) {\r\n return isObjectLike(value) && baseGetTag(value) == dateTag;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isEqual` which supports partial comparisons\r\n * and tracks traversed objects.\r\n *\r\n * @private\r\n * @param {*} value The value to compare.\r\n * @param {*} other The other value to compare.\r\n * @param {boolean} bitmask The bitmask flags.\r\n * 1 - Unordered comparison\r\n * 2 - Partial comparison\r\n * @param {Function} [customizer] The function to customize comparisons.\r\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\r\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\r\n */\r\n function baseIsEqual(value, other, bitmask, customizer, stack) {\r\n if (value === other) {\r\n return true;\r\n }\r\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\r\n return value !== value && other !== other;\r\n }\r\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\r\n }\r\n\r\n /**\r\n * A specialized version of `baseIsEqual` for arrays and objects which performs\r\n * deep comparisons and tracks traversed objects enabling objects with circular\r\n * references to be compared.\r\n *\r\n * @private\r\n * @param {Object} object The object to compare.\r\n * @param {Object} other The other object to compare.\r\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\r\n * @param {Function} customizer The function to customize comparisons.\r\n * @param {Function} equalFunc The function to determine equivalents of values.\r\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\r\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\r\n */\r\n function baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\r\n var objIsArr = isArray(object),\r\n othIsArr = isArray(other),\r\n objTag = objIsArr ? arrayTag : getTag(object),\r\n othTag = othIsArr ? arrayTag : getTag(other);\r\n\r\n objTag = objTag == argsTag ? objectTag : objTag;\r\n othTag = othTag == argsTag ? objectTag : othTag;\r\n\r\n var objIsObj = objTag == objectTag,\r\n othIsObj = othTag == objectTag,\r\n isSameTag = objTag == othTag;\r\n\r\n if (isSameTag && isBuffer(object)) {\r\n if (!isBuffer(other)) {\r\n return false;\r\n }\r\n objIsArr = true;\r\n objIsObj = false;\r\n }\r\n if (isSameTag && !objIsObj) {\r\n stack || (stack = new Stack);\r\n return (objIsArr || isTypedArray(object))\r\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\r\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\r\n }\r\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\r\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\r\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\r\n\r\n if (objIsWrapped || othIsWrapped) {\r\n var objUnwrapped = objIsWrapped ? object.value() : object,\r\n othUnwrapped = othIsWrapped ? other.value() : other;\r\n\r\n stack || (stack = new Stack);\r\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\r\n }\r\n }\r\n if (!isSameTag) {\r\n return false;\r\n }\r\n stack || (stack = new Stack);\r\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isMap` without Node.js optimizations.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\r\n */\r\n function baseIsMap(value) {\r\n return isObjectLike(value) && getTag(value) == mapTag;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Object} object The object to inspect.\r\n * @param {Object} source The object of property values to match.\r\n * @param {Array} matchData The property names, values, and compare flags to match.\r\n * @param {Function} [customizer] The function to customize comparisons.\r\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\r\n */\r\n function baseIsMatch(object, source, matchData, customizer) {\r\n var index = matchData.length,\r\n length = index,\r\n noCustomizer = !customizer;\r\n\r\n if (object == null) {\r\n return !length;\r\n }\r\n object = Object(object);\r\n while (index--) {\r\n var data = matchData[index];\r\n if ((noCustomizer && data[2])\r\n ? data[1] !== object[data[0]]\r\n : !(data[0] in object)\r\n ) {\r\n return false;\r\n }\r\n }\r\n while (++index < length) {\r\n data = matchData[index];\r\n var key = data[0],\r\n objValue = object[key],\r\n srcValue = data[1];\r\n\r\n if (noCustomizer && data[2]) {\r\n if (objValue === undefined && !(key in object)) {\r\n return false;\r\n }\r\n } else {\r\n var stack = new Stack;\r\n if (customizer) {\r\n var result = customizer(objValue, srcValue, key, object, source, stack);\r\n }\r\n if (!(result === undefined\r\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\r\n : result\r\n )) {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isNative` without bad shim checks.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a native function,\r\n * else `false`.\r\n */\r\n function baseIsNative(value) {\r\n if (!isObject(value) || isMasked(value)) {\r\n return false;\r\n }\r\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\r\n return pattern.test(toSource(value));\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isRegExp` without Node.js optimizations.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\r\n */\r\n function baseIsRegExp(value) {\r\n return isObjectLike(value) && baseGetTag(value) == regexpTag;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isSet` without Node.js optimizations.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\r\n */\r\n function baseIsSet(value) {\r\n return isObjectLike(value) && getTag(value) == setTag;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\r\n */\r\n function baseIsTypedArray(value) {\r\n return isObjectLike(value) &&\r\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\r\n }\r\n\r\n /**\r\n * The base implementation of `_.iteratee`.\r\n *\r\n * @private\r\n * @param {*} [value=_.identity] The value to convert to an iteratee.\r\n * @returns {Function} Returns the iteratee.\r\n */\r\n function baseIteratee(value) {\r\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\r\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\r\n if (typeof value == 'function') {\r\n return value;\r\n }\r\n if (value == null) {\r\n return identity;\r\n }\r\n if (typeof value == 'object') {\r\n return isArray(value)\r\n ? baseMatchesProperty(value[0], value[1])\r\n : baseMatches(value);\r\n }\r\n return property(value);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of property names.\r\n */\r\n function baseKeys(object) {\r\n if (!isPrototype(object)) {\r\n return nativeKeys(object);\r\n }\r\n var result = [];\r\n for (var key in Object(object)) {\r\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\r\n result.push(key);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of property names.\r\n */\r\n function baseKeysIn(object) {\r\n if (!isObject(object)) {\r\n return nativeKeysIn(object);\r\n }\r\n var isProto = isPrototype(object),\r\n result = [];\r\n\r\n for (var key in object) {\r\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\r\n result.push(key);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.lt` which doesn't coerce arguments.\r\n *\r\n * @private\r\n * @param {*} value The value to compare.\r\n * @param {*} other The other value to compare.\r\n * @returns {boolean} Returns `true` if `value` is less than `other`,\r\n * else `false`.\r\n */\r\n function baseLt(value, other) {\r\n return value < other;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.map` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} iteratee The function invoked per iteration.\r\n * @returns {Array} Returns the new mapped array.\r\n */\r\n function baseMap(collection, iteratee) {\r\n var index = -1,\r\n result = isArrayLike(collection) ? Array(collection.length) : [];\r\n\r\n baseEach(collection, function(value, key, collection) {\r\n result[++index] = iteratee(value, key, collection);\r\n });\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.matches` which doesn't clone `source`.\r\n *\r\n * @private\r\n * @param {Object} source The object of property values to match.\r\n * @returns {Function} Returns the new spec function.\r\n */\r\n function baseMatches(source) {\r\n var matchData = getMatchData(source);\r\n if (matchData.length == 1 && matchData[0][2]) {\r\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\r\n }\r\n return function(object) {\r\n return object === source || baseIsMatch(object, source, matchData);\r\n };\r\n }\r\n\r\n /**\r\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\r\n *\r\n * @private\r\n * @param {string} path The path of the property to get.\r\n * @param {*} srcValue The value to match.\r\n * @returns {Function} Returns the new spec function.\r\n */\r\n function baseMatchesProperty(path, srcValue) {\r\n if (isKey(path) && isStrictComparable(srcValue)) {\r\n return matchesStrictComparable(toKey(path), srcValue);\r\n }\r\n return function(object) {\r\n var objValue = get(object, path);\r\n return (objValue === undefined && objValue === srcValue)\r\n ? hasIn(object, path)\r\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\r\n };\r\n }\r\n\r\n /**\r\n * The base implementation of `_.merge` without support for multiple sources.\r\n *\r\n * @private\r\n * @param {Object} object The destination object.\r\n * @param {Object} source The source object.\r\n * @param {number} srcIndex The index of `source`.\r\n * @param {Function} [customizer] The function to customize merged values.\r\n * @param {Object} [stack] Tracks traversed source values and their merged\r\n * counterparts.\r\n */\r\n function baseMerge(object, source, srcIndex, customizer, stack) {\r\n if (object === source) {\r\n return;\r\n }\r\n baseFor(source, function(srcValue, key) {\r\n if (isObject(srcValue)) {\r\n stack || (stack = new Stack);\r\n baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\r\n }\r\n else {\r\n var newValue = customizer\r\n ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\r\n : undefined;\r\n\r\n if (newValue === undefined) {\r\n newValue = srcValue;\r\n }\r\n assignMergeValue(object, key, newValue);\r\n }\r\n }, keysIn);\r\n }\r\n\r\n /**\r\n * A specialized version of `baseMerge` for arrays and objects which performs\r\n * deep merges and tracks traversed objects enabling objects with circular\r\n * references to be merged.\r\n *\r\n * @private\r\n * @param {Object} object The destination object.\r\n * @param {Object} source The source object.\r\n * @param {string} key The key of the value to merge.\r\n * @param {number} srcIndex The index of `source`.\r\n * @param {Function} mergeFunc The function to merge values.\r\n * @param {Function} [customizer] The function to customize assigned values.\r\n * @param {Object} [stack] Tracks traversed source values and their merged\r\n * counterparts.\r\n */\r\n function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\r\n var objValue = safeGet(object, key),\r\n srcValue = safeGet(source, key),\r\n stacked = stack.get(srcValue);\r\n\r\n if (stacked) {\r\n assignMergeValue(object, key, stacked);\r\n return;\r\n }\r\n var newValue = customizer\r\n ? customizer(objValue, srcValue, (key + ''), object, source, stack)\r\n : undefined;\r\n\r\n var isCommon = newValue === undefined;\r\n\r\n if (isCommon) {\r\n var isArr = isArray(srcValue),\r\n isBuff = !isArr && isBuffer(srcValue),\r\n isTyped = !isArr && !isBuff && isTypedArray(srcValue);\r\n\r\n newValue = srcValue;\r\n if (isArr || isBuff || isTyped) {\r\n if (isArray(objValue)) {\r\n newValue = objValue;\r\n }\r\n else if (isArrayLikeObject(objValue)) {\r\n newValue = copyArray(objValue);\r\n }\r\n else if (isBuff) {\r\n isCommon = false;\r\n newValue = cloneBuffer(srcValue, true);\r\n }\r\n else if (isTyped) {\r\n isCommon = false;\r\n newValue = cloneTypedArray(srcValue, true);\r\n }\r\n else {\r\n newValue = [];\r\n }\r\n }\r\n else if (isPlainObject(srcValue) || isArguments(srcValue)) {\r\n newValue = objValue;\r\n if (isArguments(objValue)) {\r\n newValue = toPlainObject(objValue);\r\n }\r\n else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) {\r\n newValue = initCloneObject(srcValue);\r\n }\r\n }\r\n else {\r\n isCommon = false;\r\n }\r\n }\r\n if (isCommon) {\r\n // Recursively merge objects and arrays (susceptible to call stack limits).\r\n stack.set(srcValue, newValue);\r\n mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\r\n stack['delete'](srcValue);\r\n }\r\n assignMergeValue(object, key, newValue);\r\n }\r\n\r\n /**\r\n * The base implementation of `_.orderBy` without param guards.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.\r\n * @param {string[]} orders The sort orders of `iteratees`.\r\n * @returns {Array} Returns the new sorted array.\r\n */\r\n function baseOrderBy(collection, iteratees, orders) {\r\n var index = -1;\r\n iteratees = arrayMap(iteratees.length ? iteratees : [identity], baseUnary(baseIteratee));\r\n\r\n var result = baseMap(collection, function(value, key, collection) {\r\n var criteria = arrayMap(iteratees, function(iteratee) {\r\n return iteratee(value);\r\n });\r\n return { 'criteria': criteria, 'index': ++index, 'value': value };\r\n });\r\n\r\n return baseSortBy(result, function(object, other) {\r\n return compareMultiple(object, other, orders);\r\n });\r\n }\r\n\r\n /**\r\n * The base implementation of `_.pick` without support for individual\r\n * property identifiers.\r\n *\r\n * @private\r\n * @param {Object} object The source object.\r\n * @param {string[]} paths The property paths to pick.\r\n * @returns {Object} Returns the new object.\r\n */\r\n function basePick(object, paths) {\r\n return basePickBy(object, paths, function(value, path) {\r\n return hasIn(object, path);\r\n });\r\n }\r\n\r\n /**\r\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Object} object The source object.\r\n * @param {string[]} paths The property paths to pick.\r\n * @param {Function} predicate The function invoked per property.\r\n * @returns {Object} Returns the new object.\r\n */\r\n function basePickBy(object, paths, predicate) {\r\n var index = -1,\r\n length = paths.length,\r\n result = {};\r\n\r\n while (++index < length) {\r\n var path = paths[index],\r\n value = baseGet(object, path);\r\n\r\n if (predicate(value, path)) {\r\n baseSet(result, castPath(path, object), value);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * A specialized version of `baseProperty` which supports deep paths.\r\n *\r\n * @private\r\n * @param {Array|string} path The path of the property to get.\r\n * @returns {Function} Returns the new accessor function.\r\n */\r\n function basePropertyDeep(path) {\r\n return function(object) {\r\n return baseGet(object, path);\r\n };\r\n }\r\n\r\n /**\r\n * The base implementation of `_.random` without support for returning\r\n * floating-point numbers.\r\n *\r\n * @private\r\n * @param {number} lower The lower bound.\r\n * @param {number} upper The upper bound.\r\n * @returns {number} Returns the random number.\r\n */\r\n function baseRandom(lower, upper) {\r\n return lower + nativeFloor(nativeRandom() * (upper - lower + 1));\r\n }\r\n\r\n /**\r\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\r\n * coerce arguments.\r\n *\r\n * @private\r\n * @param {number} start The start of the range.\r\n * @param {number} end The end of the range.\r\n * @param {number} step The value to increment or decrement by.\r\n * @param {boolean} [fromRight] Specify iterating from right to left.\r\n * @returns {Array} Returns the range of numbers.\r\n */\r\n function baseRange(start, end, step, fromRight) {\r\n var index = -1,\r\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\r\n result = Array(length);\r\n\r\n while (length--) {\r\n result[fromRight ? length : ++index] = start;\r\n start += step;\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\r\n *\r\n * @private\r\n * @param {Function} func The function to apply a rest parameter to.\r\n * @param {number} [start=func.length-1] The start position of the rest parameter.\r\n * @returns {Function} Returns the new function.\r\n */\r\n function baseRest(func, start) {\r\n return setToString(overRest(func, start, identity), func + '');\r\n }\r\n\r\n /**\r\n * The base implementation of `_.set`.\r\n *\r\n * @private\r\n * @param {Object} object The object to modify.\r\n * @param {Array|string} path The path of the property to set.\r\n * @param {*} value The value to set.\r\n * @param {Function} [customizer] The function to customize path creation.\r\n * @returns {Object} Returns `object`.\r\n */\r\n function baseSet(object, path, value, customizer) {\r\n if (!isObject(object)) {\r\n return object;\r\n }\r\n path = castPath(path, object);\r\n\r\n var index = -1,\r\n length = path.length,\r\n lastIndex = length - 1,\r\n nested = object;\r\n\r\n while (nested != null && ++index < length) {\r\n var key = toKey(path[index]),\r\n newValue = value;\r\n\r\n if (index != lastIndex) {\r\n var objValue = nested[key];\r\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\r\n if (newValue === undefined) {\r\n newValue = isObject(objValue)\r\n ? objValue\r\n : (isIndex(path[index + 1]) ? [] : {});\r\n }\r\n }\r\n assignValue(nested, key, newValue);\r\n nested = nested[key];\r\n }\r\n return object;\r\n }\r\n\r\n /**\r\n * The base implementation of `setData` without support for hot loop shorting.\r\n *\r\n * @private\r\n * @param {Function} func The function to associate metadata with.\r\n * @param {*} data The metadata.\r\n * @returns {Function} Returns `func`.\r\n */\r\n var baseSetData = !metaMap ? identity : function(func, data) {\r\n metaMap.set(func, data);\r\n return func;\r\n };\r\n\r\n /**\r\n * The base implementation of `setToString` without support for hot loop shorting.\r\n *\r\n * @private\r\n * @param {Function} func The function to modify.\r\n * @param {Function} string The `toString` result.\r\n * @returns {Function} Returns `func`.\r\n */\r\n var baseSetToString = !defineProperty ? identity : function(func, string) {\r\n return defineProperty(func, 'toString', {\r\n 'configurable': true,\r\n 'enumerable': false,\r\n 'value': constant(string),\r\n 'writable': true\r\n });\r\n };\r\n\r\n /**\r\n * The base implementation of `_.slice` without an iteratee call guard.\r\n *\r\n * @private\r\n * @param {Array} array The array to slice.\r\n * @param {number} [start=0] The start position.\r\n * @param {number} [end=array.length] The end position.\r\n * @returns {Array} Returns the slice of `array`.\r\n */\r\n function baseSlice(array, start, end) {\r\n var index = -1,\r\n length = array.length;\r\n\r\n if (start < 0) {\r\n start = -start > length ? 0 : (length + start);\r\n }\r\n end = end > length ? length : end;\r\n if (end < 0) {\r\n end += length;\r\n }\r\n length = start > end ? 0 : ((end - start) >>> 0);\r\n start >>>= 0;\r\n\r\n var result = Array(length);\r\n while (++index < length) {\r\n result[index] = array[index + start];\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.some` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} predicate The function invoked per iteration.\r\n * @returns {boolean} Returns `true` if any element passes the predicate check,\r\n * else `false`.\r\n */\r\n function baseSome(collection, predicate) {\r\n var result;\r\n\r\n baseEach(collection, function(value, index, collection) {\r\n result = predicate(value, index, collection);\r\n return !result;\r\n });\r\n return !!result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.toString` which doesn't convert nullish\r\n * values to empty strings.\r\n *\r\n * @private\r\n * @param {*} value The value to process.\r\n * @returns {string} Returns the string.\r\n */\r\n function baseToString(value) {\r\n // Exit early for strings to avoid a performance hit in some environments.\r\n if (typeof value == 'string') {\r\n return value;\r\n }\r\n if (isArray(value)) {\r\n // Recursively convert values (susceptible to call stack limits).\r\n return arrayMap(value, baseToString) + '';\r\n }\r\n if (isSymbol(value)) {\r\n return symbolToString ? symbolToString.call(value) : '';\r\n }\r\n var result = (value + '');\r\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\r\n *\r\n * @private\r\n * @param {Array} array The array to inspect.\r\n * @param {Function} [iteratee] The iteratee invoked per element.\r\n * @param {Function} [comparator] The comparator invoked per element.\r\n * @returns {Array} Returns the new duplicate free array.\r\n */\r\n function baseUniq(array, iteratee, comparator) {\r\n var index = -1,\r\n includes = arrayIncludes,\r\n length = array.length,\r\n isCommon = true,\r\n result = [],\r\n seen = result;\r\n\r\n if (comparator) {\r\n isCommon = false;\r\n includes = arrayIncludesWith;\r\n }\r\n else if (length >= LARGE_ARRAY_SIZE) {\r\n var set = iteratee ? null : createSet(array);\r\n if (set) {\r\n return setToArray(set);\r\n }\r\n isCommon = false;\r\n includes = cacheHas;\r\n seen = new SetCache;\r\n }\r\n else {\r\n seen = iteratee ? [] : result;\r\n }\r\n outer:\r\n while (++index < length) {\r\n var value = array[index],\r\n computed = iteratee ? iteratee(value) : value;\r\n\r\n value = (comparator || value !== 0) ? value : 0;\r\n if (isCommon && computed === computed) {\r\n var seenIndex = seen.length;\r\n while (seenIndex--) {\r\n if (seen[seenIndex] === computed) {\r\n continue outer;\r\n }\r\n }\r\n if (iteratee) {\r\n seen.push(computed);\r\n }\r\n result.push(value);\r\n }\r\n else if (!includes(seen, computed, comparator)) {\r\n if (seen !== result) {\r\n seen.push(computed);\r\n }\r\n result.push(value);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * The base implementation of `_.unset`.\r\n *\r\n * @private\r\n * @param {Object} object The object to modify.\r\n * @param {Array|string} path The property path to unset.\r\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\r\n */\r\n function baseUnset(object, path) {\r\n path = castPath(path, object);\r\n object = parent(object, path);\r\n return object == null || delete object[toKey(last(path))];\r\n }\r\n\r\n /**\r\n * The base implementation of `wrapperValue` which returns the result of\r\n * performing a sequence of actions on the unwrapped `value`, where each\r\n * successive action is supplied the return value of the previous.\r\n *\r\n * @private\r\n * @param {*} value The unwrapped value.\r\n * @param {Array} actions Actions to perform to resolve the unwrapped value.\r\n * @returns {*} Returns the resolved value.\r\n */\r\n function baseWrapperValue(value, actions) {\r\n var result = value;\r\n if (result instanceof LazyWrapper) {\r\n result = result.value();\r\n }\r\n return arrayReduce(actions, function(result, action) {\r\n return action.func.apply(action.thisArg, arrayPush([result], action.args));\r\n }, result);\r\n }\r\n\r\n /**\r\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\r\n *\r\n * @private\r\n * @param {Array} props The property identifiers.\r\n * @param {Array} values The property values.\r\n * @param {Function} assignFunc The function to assign values.\r\n * @returns {Object} Returns the new object.\r\n */\r\n function baseZipObject(props, values, assignFunc) {\r\n var index = -1,\r\n length = props.length,\r\n valsLength = values.length,\r\n result = {};\r\n\r\n while (++index < length) {\r\n var value = index < valsLength ? values[index] : undefined;\r\n assignFunc(result, props[index], value);\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Casts `value` to an empty array if it's not an array like object.\r\n *\r\n * @private\r\n * @param {*} value The value to inspect.\r\n * @returns {Array|Object} Returns the cast array-like object.\r\n */\r\n function castArrayLikeObject(value) {\r\n return isArrayLikeObject(value) ? value : [];\r\n }\r\n\r\n /**\r\n * Casts `value` to a path array if it's not one.\r\n *\r\n * @private\r\n * @param {*} value The value to inspect.\r\n * @param {Object} [object] The object to query keys on.\r\n * @returns {Array} Returns the cast property path array.\r\n */\r\n function castPath(value, object) {\r\n if (isArray(value)) {\r\n return value;\r\n }\r\n return isKey(value, object) ? [value] : stringToPath(toString(value));\r\n }\r\n\r\n /**\r\n * Casts `array` to a slice if it's needed.\r\n *\r\n * @private\r\n * @param {Array} array The array to inspect.\r\n * @param {number} start The start position.\r\n * @param {number} [end=array.length] The end position.\r\n * @returns {Array} Returns the cast slice.\r\n */\r\n function castSlice(array, start, end) {\r\n var length = array.length;\r\n end = end === undefined ? length : end;\r\n return (!start && end >= length) ? array : baseSlice(array, start, end);\r\n }\r\n\r\n /**\r\n * Creates a clone of `buffer`.\r\n *\r\n * @private\r\n * @param {Buffer} buffer The buffer to clone.\r\n * @param {boolean} [isDeep] Specify a deep clone.\r\n * @returns {Buffer} Returns the cloned buffer.\r\n */\r\n function cloneBuffer(buffer, isDeep) {\r\n if (isDeep) {\r\n return buffer.slice();\r\n }\r\n var length = buffer.length,\r\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\r\n\r\n buffer.copy(result);\r\n return result;\r\n }\r\n\r\n /**\r\n * Creates a clone of `arrayBuffer`.\r\n *\r\n * @private\r\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\r\n * @returns {ArrayBuffer} Returns the cloned array buffer.\r\n */\r\n function cloneArrayBuffer(arrayBuffer) {\r\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\r\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\r\n return result;\r\n }\r\n\r\n /**\r\n * Creates a clone of `dataView`.\r\n *\r\n * @private\r\n * @param {Object} dataView The data view to clone.\r\n * @param {boolean} [isDeep] Specify a deep clone.\r\n * @returns {Object} Returns the cloned data view.\r\n */\r\n function cloneDataView(dataView, isDeep) {\r\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\r\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\r\n }\r\n\r\n /**\r\n * Creates a clone of `regexp`.\r\n *\r\n * @private\r\n * @param {Object} regexp The regexp to clone.\r\n * @returns {Object} Returns the cloned regexp.\r\n */\r\n function cloneRegExp(regexp) {\r\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\r\n result.lastIndex = regexp.lastIndex;\r\n return result;\r\n }\r\n\r\n /**\r\n * Creates a clone of the `symbol` object.\r\n *\r\n * @private\r\n * @param {Object} symbol The symbol object to clone.\r\n * @returns {Object} Returns the cloned symbol object.\r\n */\r\n function cloneSymbol(symbol) {\r\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\r\n }\r\n\r\n /**\r\n * Creates a clone of `typedArray`.\r\n *\r\n * @private\r\n * @param {Object} typedArray The typed array to clone.\r\n * @param {boolean} [isDeep] Specify a deep clone.\r\n * @returns {Object} Returns the cloned typed array.\r\n */\r\n function cloneTypedArray(typedArray, isDeep) {\r\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\r\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\r\n }\r\n\r\n /**\r\n * Compares values to sort them in ascending order.\r\n *\r\n * @private\r\n * @param {*} value The value to compare.\r\n * @param {*} other The other value to compare.\r\n * @returns {number} Returns the sort order indicator for `value`.\r\n */\r\n function compareAscending(value, other) {\r\n if (value !== other) {\r\n var valIsDefined = value !== undefined,\r\n valIsNull = value === null,\r\n valIsReflexive = value === value,\r\n valIsSymbol = isSymbol(value);\r\n\r\n var othIsDefined = other !== undefined,\r\n othIsNull = other === null,\r\n othIsReflexive = other === other,\r\n othIsSymbol = isSymbol(other);\r\n\r\n if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) ||\r\n (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) ||\r\n (valIsNull && othIsDefined && othIsReflexive) ||\r\n (!valIsDefined && othIsReflexive) ||\r\n !valIsReflexive) {\r\n return 1;\r\n }\r\n if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) ||\r\n (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) ||\r\n (othIsNull && valIsDefined && valIsReflexive) ||\r\n (!othIsDefined && valIsReflexive) ||\r\n !othIsReflexive) {\r\n return -1;\r\n }\r\n }\r\n return 0;\r\n }\r\n\r\n /**\r\n * Used by `_.orderBy` to compare multiple properties of a value to another\r\n * and stable sort them.\r\n *\r\n * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,\r\n * specify an order of \"desc\" for descending or \"asc\" for ascending sort order\r\n * of corresponding values.\r\n *\r\n * @private\r\n * @param {Object} object The object to compare.\r\n * @param {Object} other The other object to compare.\r\n * @param {boolean[]|string[]} orders The order to sort by for each property.\r\n * @returns {number} Returns the sort order indicator for `object`.\r\n */\r\n function compareMultiple(object, other, orders) {\r\n var index = -1,\r\n objCriteria = object.criteria,\r\n othCriteria = other.criteria,\r\n length = objCriteria.length,\r\n ordersLength = orders.length;\r\n\r\n while (++index < length) {\r\n var result = compareAscending(objCriteria[index], othCriteria[index]);\r\n if (result) {\r\n if (index >= ordersLength) {\r\n return result;\r\n }\r\n var order = orders[index];\r\n return result * (order == 'desc' ? -1 : 1);\r\n }\r\n }\r\n // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications\r\n // that causes it, under certain circumstances, to provide the same value for\r\n // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247\r\n // for more details.\r\n //\r\n // This also ensures a stable sort in V8 and other engines.\r\n // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\r\n return object.index - other.index;\r\n }\r\n\r\n /**\r\n * Creates an array that is the composition of partially applied arguments,\r\n * placeholders, and provided arguments into a single array of arguments.\r\n *\r\n * @private\r\n * @param {Array} args The provided arguments.\r\n * @param {Array} partials The arguments to prepend to those provided.\r\n * @param {Array} holders The `partials` placeholder indexes.\r\n * @params {boolean} [isCurried] Specify composing for a curried function.\r\n * @returns {Array} Returns the new array of composed arguments.\r\n */\r\n function composeArgs(args, partials, holders, isCurried) {\r\n var argsIndex = -1,\r\n argsLength = args.length,\r\n holdersLength = holders.length,\r\n leftIndex = -1,\r\n leftLength = partials.length,\r\n rangeLength = nativeMax(argsLength - holdersLength, 0),\r\n result = Array(leftLength + rangeLength),\r\n isUncurried = !isCurried;\r\n\r\n while (++leftIndex < leftLength) {\r\n result[leftIndex] = partials[leftIndex];\r\n }\r\n while (++argsIndex < holdersLength) {\r\n if (isUncurried || argsIndex < argsLength) {\r\n result[holders[argsIndex]] = args[argsIndex];\r\n }\r\n }\r\n while (rangeLength--) {\r\n result[leftIndex++] = args[argsIndex++];\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * This function is like `composeArgs` except that the arguments composition\r\n * is tailored for `_.partialRight`.\r\n *\r\n * @private\r\n * @param {Array} args The provided arguments.\r\n * @param {Array} partials The arguments to append to those provided.\r\n * @param {Array} holders The `partials` placeholder indexes.\r\n * @params {boolean} [isCurried] Specify composing for a curried function.\r\n * @returns {Array} Returns the new array of composed arguments.\r\n */\r\n function composeArgsRight(args, partials, holders, isCurried) {\r\n var argsIndex = -1,\r\n argsLength = args.length,\r\n holdersIndex = -1,\r\n holdersLength = holders.length,\r\n rightIndex = -1,\r\n rightLength = partials.length,\r\n rangeLength = nativeMax(argsLength - holdersLength, 0),\r\n result = Array(rangeLength + rightLength),\r\n isUncurried = !isCurried;\r\n\r\n while (++argsIndex < rangeLength) {\r\n result[argsIndex] = args[argsIndex];\r\n }\r\n var offset = argsIndex;\r\n while (++rightIndex < rightLength) {\r\n result[offset + rightIndex] = partials[rightIndex];\r\n }\r\n while (++holdersIndex < holdersLength) {\r\n if (isUncurried || argsIndex < argsLength) {\r\n result[offset + holders[holdersIndex]] = args[argsIndex++];\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Copies the values of `source` to `array`.\r\n *\r\n * @private\r\n * @param {Array} source The array to copy values from.\r\n * @param {Array} [array=[]] The array to copy values to.\r\n * @returns {Array} Returns `array`.\r\n */\r\n function copyArray(source, array) {\r\n var index = -1,\r\n length = source.length;\r\n\r\n array || (array = Array(length));\r\n while (++index < length) {\r\n array[index] = source[index];\r\n }\r\n return array;\r\n }\r\n\r\n /**\r\n * Copies properties of `source` to `object`.\r\n *\r\n * @private\r\n * @param {Object} source The object to copy properties from.\r\n * @param {Array} props The property identifiers to copy.\r\n * @param {Object} [object={}] The object to copy properties to.\r\n * @param {Function} [customizer] The function to customize copied values.\r\n * @returns {Object} Returns `object`.\r\n */\r\n function copyObject(source, props, object, customizer) {\r\n var isNew = !object;\r\n object || (object = {});\r\n\r\n var index = -1,\r\n length = props.length;\r\n\r\n while (++index < length) {\r\n var key = props[index];\r\n\r\n var newValue = customizer\r\n ? customizer(object[key], source[key], key, object, source)\r\n : undefined;\r\n\r\n if (newValue === undefined) {\r\n newValue = source[key];\r\n }\r\n if (isNew) {\r\n baseAssignValue(object, key, newValue);\r\n } else {\r\n assignValue(object, key, newValue);\r\n }\r\n }\r\n return object;\r\n }\r\n\r\n /**\r\n * Copies own symbols of `source` to `object`.\r\n *\r\n * @private\r\n * @param {Object} source The object to copy symbols from.\r\n * @param {Object} [object={}] The object to copy symbols to.\r\n * @returns {Object} Returns `object`.\r\n */\r\n function copySymbols(source, object) {\r\n return copyObject(source, getSymbols(source), object);\r\n }\r\n\r\n /**\r\n * Copies own and inherited symbols of `source` to `object`.\r\n *\r\n * @private\r\n * @param {Object} source The object to copy symbols from.\r\n * @param {Object} [object={}] The object to copy symbols to.\r\n * @returns {Object} Returns `object`.\r\n */\r\n function copySymbolsIn(source, object) {\r\n return copyObject(source, getSymbolsIn(source), object);\r\n }\r\n\r\n /**\r\n * Creates a function like `_.groupBy`.\r\n *\r\n * @private\r\n * @param {Function} setter The function to set accumulator values.\r\n * @param {Function} [initializer] The accumulator object initializer.\r\n * @returns {Function} Returns the new aggregator function.\r\n */\r\n function createAggregator(setter, initializer) {\r\n return function(collection, iteratee) {\r\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\r\n accumulator = initializer ? initializer() : {};\r\n\r\n return func(collection, setter, baseIteratee(iteratee, 2), accumulator);\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function like `_.assign`.\r\n *\r\n * @private\r\n * @param {Function} assigner The function to assign values.\r\n * @returns {Function} Returns the new assigner function.\r\n */\r\n function createAssigner(assigner) {\r\n return baseRest(function(object, sources) {\r\n var index = -1,\r\n length = sources.length,\r\n customizer = length > 1 ? sources[length - 1] : undefined,\r\n guard = length > 2 ? sources[2] : undefined;\r\n\r\n customizer = (assigner.length > 3 && typeof customizer == 'function')\r\n ? (length--, customizer)\r\n : undefined;\r\n\r\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\r\n customizer = length < 3 ? undefined : customizer;\r\n length = 1;\r\n }\r\n object = Object(object);\r\n while (++index < length) {\r\n var source = sources[index];\r\n if (source) {\r\n assigner(object, source, index, customizer);\r\n }\r\n }\r\n return object;\r\n });\r\n }\r\n\r\n /**\r\n * Creates a `baseEach` or `baseEachRight` function.\r\n *\r\n * @private\r\n * @param {Function} eachFunc The function to iterate over a collection.\r\n * @param {boolean} [fromRight] Specify iterating from right to left.\r\n * @returns {Function} Returns the new base function.\r\n */\r\n function createBaseEach(eachFunc, fromRight) {\r\n return function(collection, iteratee) {\r\n if (collection == null) {\r\n return collection;\r\n }\r\n if (!isArrayLike(collection)) {\r\n return eachFunc(collection, iteratee);\r\n }\r\n var length = collection.length,\r\n index = fromRight ? length : -1,\r\n iterable = Object(collection);\r\n\r\n while ((fromRight ? index-- : ++index < length)) {\r\n if (iteratee(iterable[index], index, iterable) === false) {\r\n break;\r\n }\r\n }\r\n return collection;\r\n };\r\n }\r\n\r\n /**\r\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\r\n *\r\n * @private\r\n * @param {boolean} [fromRight] Specify iterating from right to left.\r\n * @returns {Function} Returns the new base function.\r\n */\r\n function createBaseFor(fromRight) {\r\n return function(object, iteratee, keysFunc) {\r\n var index = -1,\r\n iterable = Object(object),\r\n props = keysFunc(object),\r\n length = props.length;\r\n\r\n while (length--) {\r\n var key = props[fromRight ? length : ++index];\r\n if (iteratee(iterable[key], key, iterable) === false) {\r\n break;\r\n }\r\n }\r\n return object;\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function that wraps `func` to invoke it with the optional `this`\r\n * binding of `thisArg`.\r\n *\r\n * @private\r\n * @param {Function} func The function to wrap.\r\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\r\n * @param {*} [thisArg] The `this` binding of `func`.\r\n * @returns {Function} Returns the new wrapped function.\r\n */\r\n function createBind(func, bitmask, thisArg) {\r\n var isBind = bitmask & WRAP_BIND_FLAG,\r\n Ctor = createCtor(func);\r\n\r\n function wrapper() {\r\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\r\n return fn.apply(isBind ? thisArg : this, arguments);\r\n }\r\n return wrapper;\r\n }\r\n\r\n /**\r\n * Creates a function that produces an instance of `Ctor` regardless of\r\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\r\n *\r\n * @private\r\n * @param {Function} Ctor The constructor to wrap.\r\n * @returns {Function} Returns the new wrapped function.\r\n */\r\n function createCtor(Ctor) {\r\n return function() {\r\n // Use a `switch` statement to work with class constructors. See\r\n // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\r\n // for more details.\r\n var args = arguments;\r\n switch (args.length) {\r\n case 0: return new Ctor;\r\n case 1: return new Ctor(args[0]);\r\n case 2: return new Ctor(args[0], args[1]);\r\n case 3: return new Ctor(args[0], args[1], args[2]);\r\n case 4: return new Ctor(args[0], args[1], args[2], args[3]);\r\n case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\r\n case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\r\n case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\r\n }\r\n var thisBinding = baseCreate(Ctor.prototype),\r\n result = Ctor.apply(thisBinding, args);\r\n\r\n // Mimic the constructor's `return` behavior.\r\n // See https://es5.github.io/#x13.2.2 for more details.\r\n return isObject(result) ? result : thisBinding;\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function that wraps `func` to enable currying.\r\n *\r\n * @private\r\n * @param {Function} func The function to wrap.\r\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\r\n * @param {number} arity The arity of `func`.\r\n * @returns {Function} Returns the new wrapped function.\r\n */\r\n function createCurry(func, bitmask, arity) {\r\n var Ctor = createCtor(func);\r\n\r\n function wrapper() {\r\n var length = arguments.length,\r\n args = Array(length),\r\n index = length,\r\n placeholder = getHolder(wrapper);\r\n\r\n while (index--) {\r\n args[index] = arguments[index];\r\n }\r\n var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder)\r\n ? []\r\n : replaceHolders(args, placeholder);\r\n\r\n length -= holders.length;\r\n if (length < arity) {\r\n return createRecurry(\r\n func, bitmask, createHybrid, wrapper.placeholder, undefined,\r\n args, holders, undefined, undefined, arity - length);\r\n }\r\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\r\n return apply(fn, this, args);\r\n }\r\n return wrapper;\r\n }\r\n\r\n /**\r\n * Creates a `_.find` or `_.findLast` function.\r\n *\r\n * @private\r\n * @param {Function} findIndexFunc The function to find the collection index.\r\n * @returns {Function} Returns the new find function.\r\n */\r\n function createFind(findIndexFunc) {\r\n return function(collection, predicate, fromIndex) {\r\n var iterable = Object(collection);\r\n if (!isArrayLike(collection)) {\r\n var iteratee = baseIteratee(predicate, 3);\r\n collection = keys(collection);\r\n predicate = function(key) { return iteratee(iterable[key], key, iterable); };\r\n }\r\n var index = findIndexFunc(collection, predicate, fromIndex);\r\n return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function that wraps `func` to invoke it with optional `this`\r\n * binding of `thisArg`, partial application, and currying.\r\n *\r\n * @private\r\n * @param {Function|string} func The function or method name to wrap.\r\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\r\n * @param {*} [thisArg] The `this` binding of `func`.\r\n * @param {Array} [partials] The arguments to prepend to those provided to\r\n * the new function.\r\n * @param {Array} [holders] The `partials` placeholder indexes.\r\n * @param {Array} [partialsRight] The arguments to append to those provided\r\n * to the new function.\r\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\r\n * @param {Array} [argPos] The argument positions of the new function.\r\n * @param {number} [ary] The arity cap of `func`.\r\n * @param {number} [arity] The arity of `func`.\r\n * @returns {Function} Returns the new wrapped function.\r\n */\r\n function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\r\n var isAry = bitmask & WRAP_ARY_FLAG,\r\n isBind = bitmask & WRAP_BIND_FLAG,\r\n isBindKey = bitmask & WRAP_BIND_KEY_FLAG,\r\n isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG),\r\n isFlip = bitmask & WRAP_FLIP_FLAG,\r\n Ctor = isBindKey ? undefined : createCtor(func);\r\n\r\n function wrapper() {\r\n var length = arguments.length,\r\n args = Array(length),\r\n index = length;\r\n\r\n while (index--) {\r\n args[index] = arguments[index];\r\n }\r\n if (isCurried) {\r\n var placeholder = getHolder(wrapper),\r\n holdersCount = countHolders(args, placeholder);\r\n }\r\n if (partials) {\r\n args = composeArgs(args, partials, holders, isCurried);\r\n }\r\n if (partialsRight) {\r\n args = composeArgsRight(args, partialsRight, holdersRight, isCurried);\r\n }\r\n length -= holdersCount;\r\n if (isCurried && length < arity) {\r\n var newHolders = replaceHolders(args, placeholder);\r\n return createRecurry(\r\n func, bitmask, createHybrid, wrapper.placeholder, thisArg,\r\n args, newHolders, argPos, ary, arity - length\r\n );\r\n }\r\n var thisBinding = isBind ? thisArg : this,\r\n fn = isBindKey ? thisBinding[func] : func;\r\n\r\n length = args.length;\r\n if (argPos) {\r\n args = reorder(args, argPos);\r\n } else if (isFlip && length > 1) {\r\n args.reverse();\r\n }\r\n if (isAry && ary < length) {\r\n args.length = ary;\r\n }\r\n if (this && this !== root && this instanceof wrapper) {\r\n fn = Ctor || createCtor(fn);\r\n }\r\n return fn.apply(thisBinding, args);\r\n }\r\n return wrapper;\r\n }\r\n\r\n /**\r\n * Creates a function like `_.invertBy`.\r\n *\r\n * @private\r\n * @param {Function} setter The function to set accumulator values.\r\n * @param {Function} toIteratee The function to resolve iteratees.\r\n * @returns {Function} Returns the new inverter function.\r\n */\r\n function createInverter(setter, toIteratee) {\r\n return function(object, iteratee) {\r\n return baseInverter(object, setter, toIteratee(iteratee), {});\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function that wraps `func` to invoke it with the `this` binding\r\n * of `thisArg` and `partials` prepended to the arguments it receives.\r\n *\r\n * @private\r\n * @param {Function} func The function to wrap.\r\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\r\n * @param {*} thisArg The `this` binding of `func`.\r\n * @param {Array} partials The arguments to prepend to those provided to\r\n * the new function.\r\n * @returns {Function} Returns the new wrapped function.\r\n */\r\n function createPartial(func, bitmask, thisArg, partials) {\r\n var isBind = bitmask & WRAP_BIND_FLAG,\r\n Ctor = createCtor(func);\r\n\r\n function wrapper() {\r\n var argsIndex = -1,\r\n argsLength = arguments.length,\r\n leftIndex = -1,\r\n leftLength = partials.length,\r\n args = Array(leftLength + argsLength),\r\n fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\r\n\r\n while (++leftIndex < leftLength) {\r\n args[leftIndex] = partials[leftIndex];\r\n }\r\n while (argsLength--) {\r\n args[leftIndex++] = arguments[++argsIndex];\r\n }\r\n return apply(fn, isBind ? thisArg : this, args);\r\n }\r\n return wrapper;\r\n }\r\n\r\n /**\r\n * Creates a `_.range` or `_.rangeRight` function.\r\n *\r\n * @private\r\n * @param {boolean} [fromRight] Specify iterating from right to left.\r\n * @returns {Function} Returns the new range function.\r\n */\r\n function createRange(fromRight) {\r\n return function(start, end, step) {\r\n if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\r\n end = step = undefined;\r\n }\r\n // Ensure the sign of `-0` is preserved.\r\n start = toFinite(start);\r\n if (end === undefined) {\r\n end = start;\r\n start = 0;\r\n } else {\r\n end = toFinite(end);\r\n }\r\n step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\r\n return baseRange(start, end, step, fromRight);\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function that wraps `func` to continue currying.\r\n *\r\n * @private\r\n * @param {Function} func The function to wrap.\r\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\r\n * @param {Function} wrapFunc The function to create the `func` wrapper.\r\n * @param {*} placeholder The placeholder value.\r\n * @param {*} [thisArg] The `this` binding of `func`.\r\n * @param {Array} [partials] The arguments to prepend to those provided to\r\n * the new function.\r\n * @param {Array} [holders] The `partials` placeholder indexes.\r\n * @param {Array} [argPos] The argument positions of the new function.\r\n * @param {number} [ary] The arity cap of `func`.\r\n * @param {number} [arity] The arity of `func`.\r\n * @returns {Function} Returns the new wrapped function.\r\n */\r\n function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) {\r\n var isCurry = bitmask & WRAP_CURRY_FLAG,\r\n newHolders = isCurry ? holders : undefined,\r\n newHoldersRight = isCurry ? undefined : holders,\r\n newPartials = isCurry ? partials : undefined,\r\n newPartialsRight = isCurry ? undefined : partials;\r\n\r\n bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG);\r\n bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG);\r\n\r\n if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) {\r\n bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG);\r\n }\r\n var newData = [\r\n func, bitmask, thisArg, newPartials, newHolders, newPartialsRight,\r\n newHoldersRight, argPos, ary, arity\r\n ];\r\n\r\n var result = wrapFunc.apply(undefined, newData);\r\n if (isLaziable(func)) {\r\n setData(result, newData);\r\n }\r\n result.placeholder = placeholder;\r\n return setWrapToString(result, func, bitmask);\r\n }\r\n\r\n /**\r\n * Creates a set object of `values`.\r\n *\r\n * @private\r\n * @param {Array} values The values to add to the set.\r\n * @returns {Object} Returns the new set.\r\n */\r\n var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\r\n return new Set(values);\r\n };\r\n\r\n /**\r\n * Creates a function that either curries or invokes `func` with optional\r\n * `this` binding and partially applied arguments.\r\n *\r\n * @private\r\n * @param {Function|string} func The function or method name to wrap.\r\n * @param {number} bitmask The bitmask flags.\r\n * 1 - `_.bind`\r\n * 2 - `_.bindKey`\r\n * 4 - `_.curry` or `_.curryRight` of a bound function\r\n * 8 - `_.curry`\r\n * 16 - `_.curryRight`\r\n * 32 - `_.partial`\r\n * 64 - `_.partialRight`\r\n * 128 - `_.rearg`\r\n * 256 - `_.ary`\r\n * 512 - `_.flip`\r\n * @param {*} [thisArg] The `this` binding of `func`.\r\n * @param {Array} [partials] The arguments to be partially applied.\r\n * @param {Array} [holders] The `partials` placeholder indexes.\r\n * @param {Array} [argPos] The argument positions of the new function.\r\n * @param {number} [ary] The arity cap of `func`.\r\n * @param {number} [arity] The arity of `func`.\r\n * @returns {Function} Returns the new wrapped function.\r\n */\r\n function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\r\n var isBindKey = bitmask & WRAP_BIND_KEY_FLAG;\r\n if (!isBindKey && typeof func != 'function') {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n var length = partials ? partials.length : 0;\r\n if (!length) {\r\n bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG);\r\n partials = holders = undefined;\r\n }\r\n ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0);\r\n arity = arity === undefined ? arity : toInteger(arity);\r\n length -= holders ? holders.length : 0;\r\n\r\n if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) {\r\n var partialsRight = partials,\r\n holdersRight = holders;\r\n\r\n partials = holders = undefined;\r\n }\r\n var data = isBindKey ? undefined : getData(func);\r\n\r\n var newData = [\r\n func, bitmask, thisArg, partials, holders, partialsRight, holdersRight,\r\n argPos, ary, arity\r\n ];\r\n\r\n if (data) {\r\n mergeData(newData, data);\r\n }\r\n func = newData[0];\r\n bitmask = newData[1];\r\n thisArg = newData[2];\r\n partials = newData[3];\r\n holders = newData[4];\r\n arity = newData[9] = newData[9] === undefined\r\n ? (isBindKey ? 0 : func.length)\r\n : nativeMax(newData[9] - length, 0);\r\n\r\n if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) {\r\n bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG);\r\n }\r\n if (!bitmask || bitmask == WRAP_BIND_FLAG) {\r\n var result = createBind(func, bitmask, thisArg);\r\n } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) {\r\n result = createCurry(func, bitmask, arity);\r\n } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) {\r\n result = createPartial(func, bitmask, thisArg, partials);\r\n } else {\r\n result = createHybrid.apply(undefined, newData);\r\n }\r\n var setter = data ? baseSetData : setData;\r\n return setWrapToString(setter(result, newData), func, bitmask);\r\n }\r\n\r\n /**\r\n * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source\r\n * objects into destination objects that are passed thru.\r\n *\r\n * @private\r\n * @param {*} objValue The destination value.\r\n * @param {*} srcValue The source value.\r\n * @param {string} key The key of the property to merge.\r\n * @param {Object} object The parent object of `objValue`.\r\n * @param {Object} source The parent object of `srcValue`.\r\n * @param {Object} [stack] Tracks traversed source values and their merged\r\n * counterparts.\r\n * @returns {*} Returns the value to assign.\r\n */\r\n function customDefaultsMerge(objValue, srcValue, key, object, source, stack) {\r\n if (isObject(objValue) && isObject(srcValue)) {\r\n // Recursively merge objects and arrays (susceptible to call stack limits).\r\n stack.set(srcValue, objValue);\r\n baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack);\r\n stack['delete'](srcValue);\r\n }\r\n return objValue;\r\n }\r\n\r\n /**\r\n * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain\r\n * objects.\r\n *\r\n * @private\r\n * @param {*} value The value to inspect.\r\n * @param {string} key The key of the property to inspect.\r\n * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.\r\n */\r\n function customOmitClone(value) {\r\n return isPlainObject(value) ? undefined : value;\r\n }\r\n\r\n /**\r\n * A specialized version of `baseIsEqualDeep` for arrays with support for\r\n * partial deep comparisons.\r\n *\r\n * @private\r\n * @param {Array} array The array to compare.\r\n * @param {Array} other The other array to compare.\r\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\r\n * @param {Function} customizer The function to customize comparisons.\r\n * @param {Function} equalFunc The function to determine equivalents of values.\r\n * @param {Object} stack Tracks traversed `array` and `other` objects.\r\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\r\n */\r\n function equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\r\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\r\n arrLength = array.length,\r\n othLength = other.length;\r\n\r\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\r\n return false;\r\n }\r\n // Assume cyclic values are equal.\r\n var stacked = stack.get(array);\r\n if (stacked && stack.get(other)) {\r\n return stacked == other;\r\n }\r\n var index = -1,\r\n result = true,\r\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\r\n\r\n stack.set(array, other);\r\n stack.set(other, array);\r\n\r\n // Ignore non-index properties.\r\n while (++index < arrLength) {\r\n var arrValue = array[index],\r\n othValue = other[index];\r\n\r\n if (customizer) {\r\n var compared = isPartial\r\n ? customizer(othValue, arrValue, index, other, array, stack)\r\n : customizer(arrValue, othValue, index, array, other, stack);\r\n }\r\n if (compared !== undefined) {\r\n if (compared) {\r\n continue;\r\n }\r\n result = false;\r\n break;\r\n }\r\n // Recursively compare arrays (susceptible to call stack limits).\r\n if (seen) {\r\n if (!arraySome(other, function(othValue, othIndex) {\r\n if (!cacheHas(seen, othIndex) &&\r\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\r\n return seen.push(othIndex);\r\n }\r\n })) {\r\n result = false;\r\n break;\r\n }\r\n } else if (!(\r\n arrValue === othValue ||\r\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\r\n )) {\r\n result = false;\r\n break;\r\n }\r\n }\r\n stack['delete'](array);\r\n stack['delete'](other);\r\n return result;\r\n }\r\n\r\n /**\r\n * A specialized version of `baseIsEqualDeep` for comparing objects of\r\n * the same `toStringTag`.\r\n *\r\n * **Note:** This function only supports comparing values with tags of\r\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\r\n *\r\n * @private\r\n * @param {Object} object The object to compare.\r\n * @param {Object} other The other object to compare.\r\n * @param {string} tag The `toStringTag` of the objects to compare.\r\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\r\n * @param {Function} customizer The function to customize comparisons.\r\n * @param {Function} equalFunc The function to determine equivalents of values.\r\n * @param {Object} stack Tracks traversed `object` and `other` objects.\r\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\r\n */\r\n function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\r\n switch (tag) {\r\n case dataViewTag:\r\n if ((object.byteLength != other.byteLength) ||\r\n (object.byteOffset != other.byteOffset)) {\r\n return false;\r\n }\r\n object = object.buffer;\r\n other = other.buffer;\r\n\r\n case arrayBufferTag:\r\n if ((object.byteLength != other.byteLength) ||\r\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\r\n return false;\r\n }\r\n return true;\r\n\r\n case boolTag:\r\n case dateTag:\r\n case numberTag:\r\n // Coerce booleans to `1` or `0` and dates to milliseconds.\r\n // Invalid dates are coerced to `NaN`.\r\n return eq(+object, +other);\r\n\r\n case errorTag:\r\n return object.name == other.name && object.message == other.message;\r\n\r\n case regexpTag:\r\n case stringTag:\r\n // Coerce regexes to strings and treat strings, primitives and objects,\r\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\r\n // for more details.\r\n return object == (other + '');\r\n\r\n case mapTag:\r\n var convert = mapToArray;\r\n\r\n case setTag:\r\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\r\n convert || (convert = setToArray);\r\n\r\n if (object.size != other.size && !isPartial) {\r\n return false;\r\n }\r\n // Assume cyclic values are equal.\r\n var stacked = stack.get(object);\r\n if (stacked) {\r\n return stacked == other;\r\n }\r\n bitmask |= COMPARE_UNORDERED_FLAG;\r\n\r\n // Recursively compare objects (susceptible to call stack limits).\r\n stack.set(object, other);\r\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\r\n stack['delete'](object);\r\n return result;\r\n\r\n case symbolTag:\r\n if (symbolValueOf) {\r\n return symbolValueOf.call(object) == symbolValueOf.call(other);\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n /**\r\n * A specialized version of `baseIsEqualDeep` for objects with support for\r\n * partial deep comparisons.\r\n *\r\n * @private\r\n * @param {Object} object The object to compare.\r\n * @param {Object} other The other object to compare.\r\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\r\n * @param {Function} customizer The function to customize comparisons.\r\n * @param {Function} equalFunc The function to determine equivalents of values.\r\n * @param {Object} stack Tracks traversed `object` and `other` objects.\r\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\r\n */\r\n function equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\r\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\r\n objProps = getAllKeys(object),\r\n objLength = objProps.length,\r\n othProps = getAllKeys(other),\r\n othLength = othProps.length;\r\n\r\n if (objLength != othLength && !isPartial) {\r\n return false;\r\n }\r\n var index = objLength;\r\n while (index--) {\r\n var key = objProps[index];\r\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\r\n return false;\r\n }\r\n }\r\n // Assume cyclic values are equal.\r\n var stacked = stack.get(object);\r\n if (stacked && stack.get(other)) {\r\n return stacked == other;\r\n }\r\n var result = true;\r\n stack.set(object, other);\r\n stack.set(other, object);\r\n\r\n var skipCtor = isPartial;\r\n while (++index < objLength) {\r\n key = objProps[index];\r\n var objValue = object[key],\r\n othValue = other[key];\r\n\r\n if (customizer) {\r\n var compared = isPartial\r\n ? customizer(othValue, objValue, key, other, object, stack)\r\n : customizer(objValue, othValue, key, object, other, stack);\r\n }\r\n // Recursively compare objects (susceptible to call stack limits).\r\n if (!(compared === undefined\r\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\r\n : compared\r\n )) {\r\n result = false;\r\n break;\r\n }\r\n skipCtor || (skipCtor = key == 'constructor');\r\n }\r\n if (result && !skipCtor) {\r\n var objCtor = object.constructor,\r\n othCtor = other.constructor;\r\n\r\n // Non `Object` object instances with different constructors are not equal.\r\n if (objCtor != othCtor &&\r\n ('constructor' in object && 'constructor' in other) &&\r\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\r\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\r\n result = false;\r\n }\r\n }\r\n stack['delete'](object);\r\n stack['delete'](other);\r\n return result;\r\n }\r\n\r\n /**\r\n * A specialized version of `baseRest` which flattens the rest array.\r\n *\r\n * @private\r\n * @param {Function} func The function to apply a rest parameter to.\r\n * @returns {Function} Returns the new function.\r\n */\r\n function flatRest(func) {\r\n return setToString(overRest(func, undefined, flatten), func + '');\r\n }\r\n\r\n /**\r\n * Creates an array of own enumerable property names and symbols of `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of property names and symbols.\r\n */\r\n function getAllKeys(object) {\r\n return baseGetAllKeys(object, keys, getSymbols);\r\n }\r\n\r\n /**\r\n * Creates an array of own and inherited enumerable property names and\r\n * symbols of `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of property names and symbols.\r\n */\r\n function getAllKeysIn(object) {\r\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\r\n }\r\n\r\n /**\r\n * Gets metadata for `func`.\r\n *\r\n * @private\r\n * @param {Function} func The function to query.\r\n * @returns {*} Returns the metadata for `func`.\r\n */\r\n var getData = !metaMap ? noop : function(func) {\r\n return metaMap.get(func);\r\n };\r\n\r\n /**\r\n * Gets the name of `func`.\r\n *\r\n * @private\r\n * @param {Function} func The function to query.\r\n * @returns {string} Returns the function name.\r\n */\r\n function getFuncName(func) {\r\n var result = (func.name + ''),\r\n array = realNames[result],\r\n length = hasOwnProperty.call(realNames, result) ? array.length : 0;\r\n\r\n while (length--) {\r\n var data = array[length],\r\n otherFunc = data.func;\r\n if (otherFunc == null || otherFunc == func) {\r\n return data.name;\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Gets the argument placeholder value for `func`.\r\n *\r\n * @private\r\n * @param {Function} func The function to inspect.\r\n * @returns {*} Returns the placeholder value.\r\n */\r\n function getHolder(func) {\r\n var object = hasOwnProperty.call(lodash, 'placeholder') ? lodash : func;\r\n return object.placeholder;\r\n }\r\n\r\n /**\r\n * Gets the data for `map`.\r\n *\r\n * @private\r\n * @param {Object} map The map to query.\r\n * @param {string} key The reference key.\r\n * @returns {*} Returns the map data.\r\n */\r\n function getMapData(map, key) {\r\n var data = map.__data__;\r\n return isKeyable(key)\r\n ? data[typeof key == 'string' ? 'string' : 'hash']\r\n : data.map;\r\n }\r\n\r\n /**\r\n * Gets the property names, values, and compare flags of `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the match data of `object`.\r\n */\r\n function getMatchData(object) {\r\n var result = keys(object),\r\n length = result.length;\r\n\r\n while (length--) {\r\n var key = result[length],\r\n value = object[key];\r\n\r\n result[length] = [key, value, isStrictComparable(value)];\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Gets the native function at `key` of `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @param {string} key The key of the method to get.\r\n * @returns {*} Returns the function if it's native, else `undefined`.\r\n */\r\n function getNative(object, key) {\r\n var value = getValue(object, key);\r\n return baseIsNative(value) ? value : undefined;\r\n }\r\n\r\n /**\r\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\r\n *\r\n * @private\r\n * @param {*} value The value to query.\r\n * @returns {string} Returns the raw `toStringTag`.\r\n */\r\n function getRawTag(value) {\r\n var isOwn = hasOwnProperty.call(value, symToStringTag),\r\n tag = value[symToStringTag];\r\n\r\n try {\r\n value[symToStringTag] = undefined;\r\n var unmasked = true;\r\n } catch (e) {}\r\n\r\n var result = nativeObjectToString.call(value);\r\n if (unmasked) {\r\n if (isOwn) {\r\n value[symToStringTag] = tag;\r\n } else {\r\n delete value[symToStringTag];\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Creates an array of the own enumerable symbols of `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of symbols.\r\n */\r\n var getSymbols = !nativeGetSymbols ? stubArray : function(object) {\r\n if (object == null) {\r\n return [];\r\n }\r\n object = Object(object);\r\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\r\n return propertyIsEnumerable.call(object, symbol);\r\n });\r\n };\r\n\r\n /**\r\n * Creates an array of the own and inherited enumerable symbols of `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of symbols.\r\n */\r\n var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\r\n var result = [];\r\n while (object) {\r\n arrayPush(result, getSymbols(object));\r\n object = getPrototype(object);\r\n }\r\n return result;\r\n };\r\n\r\n /**\r\n * Gets the `toStringTag` of `value`.\r\n *\r\n * @private\r\n * @param {*} value The value to query.\r\n * @returns {string} Returns the `toStringTag`.\r\n */\r\n var getTag = baseGetTag;\r\n\r\n // Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\r\n if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\r\n (Map && getTag(new Map) != mapTag) ||\r\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\r\n (Set && getTag(new Set) != setTag) ||\r\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\r\n getTag = function(value) {\r\n var result = baseGetTag(value),\r\n Ctor = result == objectTag ? value.constructor : undefined,\r\n ctorString = Ctor ? toSource(Ctor) : '';\r\n\r\n if (ctorString) {\r\n switch (ctorString) {\r\n case dataViewCtorString: return dataViewTag;\r\n case mapCtorString: return mapTag;\r\n case promiseCtorString: return promiseTag;\r\n case setCtorString: return setTag;\r\n case weakMapCtorString: return weakMapTag;\r\n }\r\n }\r\n return result;\r\n };\r\n }\r\n\r\n /**\r\n * Gets the view, applying any `transforms` to the `start` and `end` positions.\r\n *\r\n * @private\r\n * @param {number} start The start of the view.\r\n * @param {number} end The end of the view.\r\n * @param {Array} transforms The transformations to apply to the view.\r\n * @returns {Object} Returns an object containing the `start` and `end`\r\n * positions of the view.\r\n */\r\n function getView(start, end, transforms) {\r\n var index = -1,\r\n length = transforms.length;\r\n\r\n while (++index < length) {\r\n var data = transforms[index],\r\n size = data.size;\r\n\r\n switch (data.type) {\r\n case 'drop': start += size; break;\r\n case 'dropRight': end -= size; break;\r\n case 'take': end = nativeMin(end, start + size); break;\r\n case 'takeRight': start = nativeMax(start, end - size); break;\r\n }\r\n }\r\n return { 'start': start, 'end': end };\r\n }\r\n\r\n /**\r\n * Extracts wrapper details from the `source` body comment.\r\n *\r\n * @private\r\n * @param {string} source The source to inspect.\r\n * @returns {Array} Returns the wrapper details.\r\n */\r\n function getWrapDetails(source) {\r\n var match = source.match(reWrapDetails);\r\n return match ? match[1].split(reSplitDetails) : [];\r\n }\r\n\r\n /**\r\n * Checks if `path` exists on `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @param {Array|string} path The path to check.\r\n * @param {Function} hasFunc The function to check properties.\r\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\r\n */\r\n function hasPath(object, path, hasFunc) {\r\n path = castPath(path, object);\r\n\r\n var index = -1,\r\n length = path.length,\r\n result = false;\r\n\r\n while (++index < length) {\r\n var key = toKey(path[index]);\r\n if (!(result = object != null && hasFunc(object, key))) {\r\n break;\r\n }\r\n object = object[key];\r\n }\r\n if (result || ++index != length) {\r\n return result;\r\n }\r\n length = object == null ? 0 : object.length;\r\n return !!length && isLength(length) && isIndex(key, length) &&\r\n (isArray(object) || isArguments(object));\r\n }\r\n\r\n /**\r\n * Initializes an array clone.\r\n *\r\n * @private\r\n * @param {Array} array The array to clone.\r\n * @returns {Array} Returns the initialized clone.\r\n */\r\n function initCloneArray(array) {\r\n var length = array.length,\r\n result = new array.constructor(length);\r\n\r\n // Add properties assigned by `RegExp#exec`.\r\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\r\n result.index = array.index;\r\n result.input = array.input;\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Initializes an object clone.\r\n *\r\n * @private\r\n * @param {Object} object The object to clone.\r\n * @returns {Object} Returns the initialized clone.\r\n */\r\n function initCloneObject(object) {\r\n return (typeof object.constructor == 'function' && !isPrototype(object))\r\n ? baseCreate(getPrototype(object))\r\n : {};\r\n }\r\n\r\n /**\r\n * Initializes an object clone based on its `toStringTag`.\r\n *\r\n * **Note:** This function only supports cloning values with tags of\r\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\r\n *\r\n * @private\r\n * @param {Object} object The object to clone.\r\n * @param {string} tag The `toStringTag` of the object to clone.\r\n * @param {boolean} [isDeep] Specify a deep clone.\r\n * @returns {Object} Returns the initialized clone.\r\n */\r\n function initCloneByTag(object, tag, isDeep) {\r\n var Ctor = object.constructor;\r\n switch (tag) {\r\n case arrayBufferTag:\r\n return cloneArrayBuffer(object);\r\n\r\n case boolTag:\r\n case dateTag:\r\n return new Ctor(+object);\r\n\r\n case dataViewTag:\r\n return cloneDataView(object, isDeep);\r\n\r\n case float32Tag: case float64Tag:\r\n case int8Tag: case int16Tag: case int32Tag:\r\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\r\n return cloneTypedArray(object, isDeep);\r\n\r\n case mapTag:\r\n return new Ctor;\r\n\r\n case numberTag:\r\n case stringTag:\r\n return new Ctor(object);\r\n\r\n case regexpTag:\r\n return cloneRegExp(object);\r\n\r\n case setTag:\r\n return new Ctor;\r\n\r\n case symbolTag:\r\n return cloneSymbol(object);\r\n }\r\n }\r\n\r\n /**\r\n * Inserts wrapper `details` in a comment at the top of the `source` body.\r\n *\r\n * @private\r\n * @param {string} source The source to modify.\r\n * @returns {Array} details The details to insert.\r\n * @returns {string} Returns the modified source.\r\n */\r\n function insertWrapDetails(source, details) {\r\n var length = details.length;\r\n if (!length) {\r\n return source;\r\n }\r\n var lastIndex = length - 1;\r\n details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex];\r\n details = details.join(length > 2 ? ', ' : ' ');\r\n return source.replace(reWrapComment, '{\\n/* [wrapped with ' + details + '] */\\n');\r\n }\r\n\r\n /**\r\n * Checks if `value` is a flattenable `arguments` object or array.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\r\n */\r\n function isFlattenable(value) {\r\n return isArray(value) || isArguments(value) ||\r\n !!(spreadableSymbol && value && value[spreadableSymbol]);\r\n }\r\n\r\n /**\r\n * Checks if `value` is a valid array-like index.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\r\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\r\n */\r\n function isIndex(value, length) {\r\n var type = typeof value;\r\n length = length == null ? MAX_SAFE_INTEGER : length;\r\n\r\n return !!length &&\r\n (type == 'number' ||\r\n (type != 'symbol' && reIsUint.test(value))) &&\r\n (value > -1 && value % 1 == 0 && value < length);\r\n }\r\n\r\n /**\r\n * Checks if the given arguments are from an iteratee call.\r\n *\r\n * @private\r\n * @param {*} value The potential iteratee value argument.\r\n * @param {*} index The potential iteratee index or key argument.\r\n * @param {*} object The potential iteratee object argument.\r\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\r\n * else `false`.\r\n */\r\n function isIterateeCall(value, index, object) {\r\n if (!isObject(object)) {\r\n return false;\r\n }\r\n var type = typeof index;\r\n if (type == 'number'\r\n ? (isArrayLike(object) && isIndex(index, object.length))\r\n : (type == 'string' && index in object)\r\n ) {\r\n return eq(object[index], value);\r\n }\r\n return false;\r\n }\r\n\r\n /**\r\n * Checks if `value` is a property name and not a property path.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @param {Object} [object] The object to query keys on.\r\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\r\n */\r\n function isKey(value, object) {\r\n if (isArray(value)) {\r\n return false;\r\n }\r\n var type = typeof value;\r\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\r\n value == null || isSymbol(value)) {\r\n return true;\r\n }\r\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\r\n (object != null && value in Object(object));\r\n }\r\n\r\n /**\r\n * Checks if `value` is suitable for use as unique object key.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\r\n */\r\n function isKeyable(value) {\r\n var type = typeof value;\r\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\r\n ? (value !== '__proto__')\r\n : (value === null);\r\n }\r\n\r\n /**\r\n * Checks if `func` has a lazy counterpart.\r\n *\r\n * @private\r\n * @param {Function} func The function to check.\r\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart,\r\n * else `false`.\r\n */\r\n function isLaziable(func) {\r\n var funcName = getFuncName(func),\r\n other = lodash[funcName];\r\n\r\n if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\r\n return false;\r\n }\r\n if (func === other) {\r\n return true;\r\n }\r\n var data = getData(other);\r\n return !!data && func === data[0];\r\n }\r\n\r\n /**\r\n * Checks if `func` has its source masked.\r\n *\r\n * @private\r\n * @param {Function} func The function to check.\r\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\r\n */\r\n function isMasked(func) {\r\n return !!maskSrcKey && (maskSrcKey in func);\r\n }\r\n\r\n /**\r\n * Checks if `value` is likely a prototype object.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\r\n */\r\n function isPrototype(value) {\r\n var Ctor = value && value.constructor,\r\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\r\n\r\n return value === proto;\r\n }\r\n\r\n /**\r\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\r\n *\r\n * @private\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` if suitable for strict\r\n * equality comparisons, else `false`.\r\n */\r\n function isStrictComparable(value) {\r\n return value === value && !isObject(value);\r\n }\r\n\r\n /**\r\n * A specialized version of `matchesProperty` for source values suitable\r\n * for strict equality comparisons, i.e. `===`.\r\n *\r\n * @private\r\n * @param {string} key The key of the property to get.\r\n * @param {*} srcValue The value to match.\r\n * @returns {Function} Returns the new spec function.\r\n */\r\n function matchesStrictComparable(key, srcValue) {\r\n return function(object) {\r\n if (object == null) {\r\n return false;\r\n }\r\n return object[key] === srcValue &&\r\n (srcValue !== undefined || (key in Object(object)));\r\n };\r\n }\r\n\r\n /**\r\n * A specialized version of `_.memoize` which clears the memoized function's\r\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\r\n *\r\n * @private\r\n * @param {Function} func The function to have its output memoized.\r\n * @returns {Function} Returns the new memoized function.\r\n */\r\n function memoizeCapped(func) {\r\n var result = memoize(func, function(key) {\r\n if (cache.size === MAX_MEMOIZE_SIZE) {\r\n cache.clear();\r\n }\r\n return key;\r\n });\r\n\r\n var cache = result.cache;\r\n return result;\r\n }\r\n\r\n /**\r\n * Merges the function metadata of `source` into `data`.\r\n *\r\n * Merging metadata reduces the number of wrappers used to invoke a function.\r\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\r\n * may be applied regardless of execution order. Methods like `_.ary` and\r\n * `_.rearg` modify function arguments, making the order in which they are\r\n * executed important, preventing the merging of metadata. However, we make\r\n * an exception for a safe combined case where curried functions have `_.ary`\r\n * and or `_.rearg` applied.\r\n *\r\n * @private\r\n * @param {Array} data The destination metadata.\r\n * @param {Array} source The source metadata.\r\n * @returns {Array} Returns `data`.\r\n */\r\n function mergeData(data, source) {\r\n var bitmask = data[1],\r\n srcBitmask = source[1],\r\n newBitmask = bitmask | srcBitmask,\r\n isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG);\r\n\r\n var isCombo =\r\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) ||\r\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) ||\r\n ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG));\r\n\r\n // Exit early if metadata can't be merged.\r\n if (!(isCommon || isCombo)) {\r\n return data;\r\n }\r\n // Use source `thisArg` if available.\r\n if (srcBitmask & WRAP_BIND_FLAG) {\r\n data[2] = source[2];\r\n // Set when currying a bound function.\r\n newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG;\r\n }\r\n // Compose partial arguments.\r\n var value = source[3];\r\n if (value) {\r\n var partials = data[3];\r\n data[3] = partials ? composeArgs(partials, value, source[4]) : value;\r\n data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4];\r\n }\r\n // Compose partial right arguments.\r\n value = source[5];\r\n if (value) {\r\n partials = data[5];\r\n data[5] = partials ? composeArgsRight(partials, value, source[6]) : value;\r\n data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6];\r\n }\r\n // Use source `argPos` if available.\r\n value = source[7];\r\n if (value) {\r\n data[7] = value;\r\n }\r\n // Use source `ary` if it's smaller.\r\n if (srcBitmask & WRAP_ARY_FLAG) {\r\n data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\r\n }\r\n // Use source `arity` if one is not provided.\r\n if (data[9] == null) {\r\n data[9] = source[9];\r\n }\r\n // Use source `func` and merge bitmasks.\r\n data[0] = source[0];\r\n data[1] = newBitmask;\r\n\r\n return data;\r\n }\r\n\r\n /**\r\n * This function is like\r\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\r\n * except that it includes inherited enumerable properties.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of property names.\r\n */\r\n function nativeKeysIn(object) {\r\n var result = [];\r\n if (object != null) {\r\n for (var key in Object(object)) {\r\n result.push(key);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Converts `value` to a string using `Object.prototype.toString`.\r\n *\r\n * @private\r\n * @param {*} value The value to convert.\r\n * @returns {string} Returns the converted string.\r\n */\r\n function objectToString(value) {\r\n return nativeObjectToString.call(value);\r\n }\r\n\r\n /**\r\n * A specialized version of `baseRest` which transforms the rest array.\r\n *\r\n * @private\r\n * @param {Function} func The function to apply a rest parameter to.\r\n * @param {number} [start=func.length-1] The start position of the rest parameter.\r\n * @param {Function} transform The rest array transform.\r\n * @returns {Function} Returns the new function.\r\n */\r\n function overRest(func, start, transform) {\r\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\r\n return function() {\r\n var args = arguments,\r\n index = -1,\r\n length = nativeMax(args.length - start, 0),\r\n array = Array(length);\r\n\r\n while (++index < length) {\r\n array[index] = args[start + index];\r\n }\r\n index = -1;\r\n var otherArgs = Array(start + 1);\r\n while (++index < start) {\r\n otherArgs[index] = args[index];\r\n }\r\n otherArgs[start] = transform(array);\r\n return apply(func, this, otherArgs);\r\n };\r\n }\r\n\r\n /**\r\n * Gets the parent value at `path` of `object`.\r\n *\r\n * @private\r\n * @param {Object} object The object to query.\r\n * @param {Array} path The path to get the parent value of.\r\n * @returns {*} Returns the parent value.\r\n */\r\n function parent(object, path) {\r\n return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\r\n }\r\n\r\n /**\r\n * Reorder `array` according to the specified indexes where the element at\r\n * the first index is assigned as the first element, the element at\r\n * the second index is assigned as the second element, and so on.\r\n *\r\n * @private\r\n * @param {Array} array The array to reorder.\r\n * @param {Array} indexes The arranged array indexes.\r\n * @returns {Array} Returns `array`.\r\n */\r\n function reorder(array, indexes) {\r\n var arrLength = array.length,\r\n length = nativeMin(indexes.length, arrLength),\r\n oldArray = copyArray(array);\r\n\r\n while (length--) {\r\n var index = indexes[length];\r\n array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\r\n }\r\n return array;\r\n }\r\n\r\n /**\r\n * Sets metadata for `func`.\r\n *\r\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\r\n * period of time, it will trip its breaker and transition to an identity\r\n * function to avoid garbage collection pauses in V8. See\r\n * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)\r\n * for more details.\r\n *\r\n * @private\r\n * @param {Function} func The function to associate metadata with.\r\n * @param {*} data The metadata.\r\n * @returns {Function} Returns `func`.\r\n */\r\n var setData = shortOut(baseSetData);\r\n\r\n /**\r\n * Sets the `toString` method of `func` to return `string`.\r\n *\r\n * @private\r\n * @param {Function} func The function to modify.\r\n * @param {Function} string The `toString` result.\r\n * @returns {Function} Returns `func`.\r\n */\r\n var setToString = shortOut(baseSetToString);\r\n\r\n /**\r\n * Sets the `toString` method of `wrapper` to mimic the source of `reference`\r\n * with wrapper details in a comment at the top of the source body.\r\n *\r\n * @private\r\n * @param {Function} wrapper The function to modify.\r\n * @param {Function} reference The reference function.\r\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\r\n * @returns {Function} Returns `wrapper`.\r\n */\r\n function setWrapToString(wrapper, reference, bitmask) {\r\n var source = (reference + '');\r\n return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask)));\r\n }\r\n\r\n /**\r\n * Creates a function that'll short out and invoke `identity` instead\r\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\r\n * milliseconds.\r\n *\r\n * @private\r\n * @param {Function} func The function to restrict.\r\n * @returns {Function} Returns the new shortable function.\r\n */\r\n function shortOut(func) {\r\n var count = 0,\r\n lastCalled = 0;\r\n\r\n return function() {\r\n var stamp = nativeNow(),\r\n remaining = HOT_SPAN - (stamp - lastCalled);\r\n\r\n lastCalled = stamp;\r\n if (remaining > 0) {\r\n if (++count >= HOT_COUNT) {\r\n return arguments[0];\r\n }\r\n } else {\r\n count = 0;\r\n }\r\n return func.apply(undefined, arguments);\r\n };\r\n }\r\n\r\n /**\r\n * Converts `string` to a property path array.\r\n *\r\n * @private\r\n * @param {string} string The string to convert.\r\n * @returns {Array} Returns the property path array.\r\n */\r\n var stringToPath = memoizeCapped(function(string) {\r\n var result = [];\r\n if (string.charCodeAt(0) === 46 /* . */) {\r\n result.push('');\r\n }\r\n string.replace(rePropName, function(match, number, quote, subString) {\r\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\r\n });\r\n return result;\r\n });\r\n\r\n /**\r\n * Converts `value` to a string key if it's not a string or symbol.\r\n *\r\n * @private\r\n * @param {*} value The value to inspect.\r\n * @returns {string|symbol} Returns the key.\r\n */\r\n function toKey(value) {\r\n if (typeof value == 'string' || isSymbol(value)) {\r\n return value;\r\n }\r\n var result = (value + '');\r\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\r\n }\r\n\r\n /**\r\n * Converts `func` to its source code.\r\n *\r\n * @private\r\n * @param {Function} func The function to convert.\r\n * @returns {string} Returns the source code.\r\n */\r\n function toSource(func) {\r\n if (func != null) {\r\n try {\r\n return funcToString.call(func);\r\n } catch (e) {}\r\n try {\r\n return (func + '');\r\n } catch (e) {}\r\n }\r\n return '';\r\n }\r\n\r\n /**\r\n * Updates wrapper `details` based on `bitmask` flags.\r\n *\r\n * @private\r\n * @returns {Array} details The details to modify.\r\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\r\n * @returns {Array} Returns `details`.\r\n */\r\n function updateWrapDetails(details, bitmask) {\r\n arrayEach(wrapFlags, function(pair) {\r\n var value = '_.' + pair[0];\r\n if ((bitmask & pair[1]) && !arrayIncludes(details, value)) {\r\n details.push(value);\r\n }\r\n });\r\n return details.sort();\r\n }\r\n\r\n /**\r\n * Creates a clone of `wrapper`.\r\n *\r\n * @private\r\n * @param {Object} wrapper The wrapper to clone.\r\n * @returns {Object} Returns the cloned wrapper.\r\n */\r\n function wrapperClone(wrapper) {\r\n if (wrapper instanceof LazyWrapper) {\r\n return wrapper.clone();\r\n }\r\n var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__);\r\n result.__actions__ = copyArray(wrapper.__actions__);\r\n result.__index__ = wrapper.__index__;\r\n result.__values__ = wrapper.__values__;\r\n return result;\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates an array with all falsey values removed. The values `false`, `null`,\r\n * `0`, `\"\"`, `undefined`, and `NaN` are falsey.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to compact.\r\n * @returns {Array} Returns the new array of filtered values.\r\n * @example\r\n *\r\n * _.compact([0, 1, false, 2, '', 3]);\r\n * // => [1, 2, 3]\r\n */\r\n function compact(array) {\r\n var index = -1,\r\n length = array == null ? 0 : array.length,\r\n resIndex = 0,\r\n result = [];\r\n\r\n while (++index < length) {\r\n var value = array[index];\r\n if (value) {\r\n result[resIndex++] = value;\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Creates a new array concatenating `array` with any additional arrays\r\n * and/or values.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Array\r\n * @param {Array} array The array to concatenate.\r\n * @param {...*} [values] The values to concatenate.\r\n * @returns {Array} Returns the new concatenated array.\r\n * @example\r\n *\r\n * var array = [1];\r\n * var other = _.concat(array, 2, [3], [[4]]);\r\n *\r\n * console.log(other);\r\n * // => [1, 2, 3, [4]]\r\n *\r\n * console.log(array);\r\n * // => [1]\r\n */\r\n function concat() {\r\n var length = arguments.length;\r\n if (!length) {\r\n return [];\r\n }\r\n var args = Array(length - 1),\r\n array = arguments[0],\r\n index = length;\r\n\r\n while (index--) {\r\n args[index - 1] = arguments[index];\r\n }\r\n return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1));\r\n }\r\n\r\n /**\r\n * Creates an array of `array` values not included in the other given arrays\r\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\r\n * for equality comparisons. The order and references of result values are\r\n * determined by the first array.\r\n *\r\n * **Note:** Unlike `_.pullAll`, this method returns a new array.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to inspect.\r\n * @param {...Array} [values] The values to exclude.\r\n * @returns {Array} Returns the new array of filtered values.\r\n * @see _.without, _.xor\r\n * @example\r\n *\r\n * _.difference([2, 1], [2, 3]);\r\n * // => [1]\r\n */\r\n var difference = baseRest(function(array, values) {\r\n return isArrayLikeObject(array)\r\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true))\r\n : [];\r\n });\r\n\r\n /**\r\n * Creates a slice of `array` with `n` elements dropped from the beginning.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.5.0\r\n * @category Array\r\n * @param {Array} array The array to query.\r\n * @param {number} [n=1] The number of elements to drop.\r\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\r\n * @returns {Array} Returns the slice of `array`.\r\n * @example\r\n *\r\n * _.drop([1, 2, 3]);\r\n * // => [2, 3]\r\n *\r\n * _.drop([1, 2, 3], 2);\r\n * // => [3]\r\n *\r\n * _.drop([1, 2, 3], 5);\r\n * // => []\r\n *\r\n * _.drop([1, 2, 3], 0);\r\n * // => [1, 2, 3]\r\n */\r\n function drop(array, n, guard) {\r\n var length = array == null ? 0 : array.length;\r\n if (!length) {\r\n return [];\r\n }\r\n n = (guard || n === undefined) ? 1 : toInteger(n);\r\n return baseSlice(array, n < 0 ? 0 : n, length);\r\n }\r\n\r\n /**\r\n * This method is like `_.find` except that it returns the index of the first\r\n * element `predicate` returns truthy for instead of the element itself.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 1.1.0\r\n * @category Array\r\n * @param {Array} array The array to inspect.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @param {number} [fromIndex=0] The index to search from.\r\n * @returns {number} Returns the index of the found element, else `-1`.\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'active': false },\r\n * { 'user': 'fred', 'active': false },\r\n * { 'user': 'pebbles', 'active': true }\r\n * ];\r\n *\r\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\r\n * // => 0\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.findIndex(users, { 'user': 'fred', 'active': false });\r\n * // => 1\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.findIndex(users, ['active', false]);\r\n * // => 0\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.findIndex(users, 'active');\r\n * // => 2\r\n */\r\n function findIndex(array, predicate, fromIndex) {\r\n var length = array == null ? 0 : array.length;\r\n if (!length) {\r\n return -1;\r\n }\r\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\r\n if (index < 0) {\r\n index = nativeMax(length + index, 0);\r\n }\r\n return baseFindIndex(array, baseIteratee(predicate, 3), index);\r\n }\r\n\r\n /**\r\n * This method is like `_.findIndex` except that it iterates over elements\r\n * of `collection` from right to left.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 2.0.0\r\n * @category Array\r\n * @param {Array} array The array to inspect.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @param {number} [fromIndex=array.length-1] The index to search from.\r\n * @returns {number} Returns the index of the found element, else `-1`.\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'active': true },\r\n * { 'user': 'fred', 'active': false },\r\n * { 'user': 'pebbles', 'active': false }\r\n * ];\r\n *\r\n * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });\r\n * // => 2\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.findLastIndex(users, { 'user': 'barney', 'active': true });\r\n * // => 0\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.findLastIndex(users, ['active', false]);\r\n * // => 2\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.findLastIndex(users, 'active');\r\n * // => 0\r\n */\r\n function findLastIndex(array, predicate, fromIndex) {\r\n var length = array == null ? 0 : array.length;\r\n if (!length) {\r\n return -1;\r\n }\r\n var index = length - 1;\r\n if (fromIndex !== undefined) {\r\n index = toInteger(fromIndex);\r\n index = fromIndex < 0\r\n ? nativeMax(length + index, 0)\r\n : nativeMin(index, length - 1);\r\n }\r\n return baseFindIndex(array, baseIteratee(predicate, 3), index, true);\r\n }\r\n\r\n /**\r\n * Flattens `array` a single level deep.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to flatten.\r\n * @returns {Array} Returns the new flattened array.\r\n * @example\r\n *\r\n * _.flatten([1, [2, [3, [4]], 5]]);\r\n * // => [1, 2, [3, [4]], 5]\r\n */\r\n function flatten(array) {\r\n var length = array == null ? 0 : array.length;\r\n return length ? baseFlatten(array, 1) : [];\r\n }\r\n\r\n /**\r\n * Recursively flattens `array`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Array\r\n * @param {Array} array The array to flatten.\r\n * @returns {Array} Returns the new flattened array.\r\n * @example\r\n *\r\n * _.flattenDeep([1, [2, [3, [4]], 5]]);\r\n * // => [1, 2, 3, 4, 5]\r\n */\r\n function flattenDeep(array) {\r\n var length = array == null ? 0 : array.length;\r\n return length ? baseFlatten(array, INFINITY) : [];\r\n }\r\n\r\n /**\r\n * Gets the first element of `array`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @alias first\r\n * @category Array\r\n * @param {Array} array The array to query.\r\n * @returns {*} Returns the first element of `array`.\r\n * @example\r\n *\r\n * _.head([1, 2, 3]);\r\n * // => 1\r\n *\r\n * _.head([]);\r\n * // => undefined\r\n */\r\n function head(array) {\r\n return (array && array.length) ? array[0] : undefined;\r\n }\r\n\r\n /**\r\n * Gets the index at which the first occurrence of `value` is found in `array`\r\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\r\n * for equality comparisons. If `fromIndex` is negative, it's used as the\r\n * offset from the end of `array`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to inspect.\r\n * @param {*} value The value to search for.\r\n * @param {number} [fromIndex=0] The index to search from.\r\n * @returns {number} Returns the index of the matched value, else `-1`.\r\n * @example\r\n *\r\n * _.indexOf([1, 2, 1, 2], 2);\r\n * // => 1\r\n *\r\n * // Search from the `fromIndex`.\r\n * _.indexOf([1, 2, 1, 2], 2, 2);\r\n * // => 3\r\n */\r\n function indexOf(array, value, fromIndex) {\r\n var length = array == null ? 0 : array.length;\r\n if (!length) {\r\n return -1;\r\n }\r\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\r\n if (index < 0) {\r\n index = nativeMax(length + index, 0);\r\n }\r\n return baseIndexOf(array, value, index);\r\n }\r\n\r\n /**\r\n * Gets all but the last element of `array`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to query.\r\n * @returns {Array} Returns the slice of `array`.\r\n * @example\r\n *\r\n * _.initial([1, 2, 3]);\r\n * // => [1, 2]\r\n */\r\n function initial(array) {\r\n var length = array == null ? 0 : array.length;\r\n return length ? baseSlice(array, 0, -1) : [];\r\n }\r\n\r\n /**\r\n * Creates an array of unique values that are included in all given arrays\r\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\r\n * for equality comparisons. The order and references of result values are\r\n * determined by the first array.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {...Array} [arrays] The arrays to inspect.\r\n * @returns {Array} Returns the new array of intersecting values.\r\n * @example\r\n *\r\n * _.intersection([2, 1], [2, 3]);\r\n * // => [2]\r\n */\r\n var intersection = baseRest(function(arrays) {\r\n var mapped = arrayMap(arrays, castArrayLikeObject);\r\n return (mapped.length && mapped[0] === arrays[0])\r\n ? baseIntersection(mapped)\r\n : [];\r\n });\r\n\r\n /**\r\n * Gets the last element of `array`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to query.\r\n * @returns {*} Returns the last element of `array`.\r\n * @example\r\n *\r\n * _.last([1, 2, 3]);\r\n * // => 3\r\n */\r\n function last(array) {\r\n var length = array == null ? 0 : array.length;\r\n return length ? array[length - 1] : undefined;\r\n }\r\n\r\n /**\r\n * Reverses `array` so that the first element becomes the last, the second\r\n * element becomes the second to last, and so on.\r\n *\r\n * **Note:** This method mutates `array` and is based on\r\n * [`Array#reverse`](https://mdn.io/Array/reverse).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Array\r\n * @param {Array} array The array to modify.\r\n * @returns {Array} Returns `array`.\r\n * @example\r\n *\r\n * var array = [1, 2, 3];\r\n *\r\n * _.reverse(array);\r\n * // => [3, 2, 1]\r\n *\r\n * console.log(array);\r\n * // => [3, 2, 1]\r\n */\r\n function reverse(array) {\r\n return array == null ? array : nativeReverse.call(array);\r\n }\r\n\r\n /**\r\n * Creates a slice of `array` from `start` up to, but not including, `end`.\r\n *\r\n * **Note:** This method is used instead of\r\n * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are\r\n * returned.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Array\r\n * @param {Array} array The array to slice.\r\n * @param {number} [start=0] The start position.\r\n * @param {number} [end=array.length] The end position.\r\n * @returns {Array} Returns the slice of `array`.\r\n */\r\n function slice(array, start, end) {\r\n var length = array == null ? 0 : array.length;\r\n if (!length) {\r\n return [];\r\n }\r\n if (end && typeof end != 'number' && isIterateeCall(array, start, end)) {\r\n start = 0;\r\n end = length;\r\n }\r\n else {\r\n start = start == null ? 0 : toInteger(start);\r\n end = end === undefined ? length : toInteger(end);\r\n }\r\n return baseSlice(array, start, end);\r\n }\r\n\r\n /**\r\n * Creates a slice of `array` with `n` elements taken from the beginning.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to query.\r\n * @param {number} [n=1] The number of elements to take.\r\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\r\n * @returns {Array} Returns the slice of `array`.\r\n * @example\r\n *\r\n * _.take([1, 2, 3]);\r\n * // => [1]\r\n *\r\n * _.take([1, 2, 3], 2);\r\n * // => [1, 2]\r\n *\r\n * _.take([1, 2, 3], 5);\r\n * // => [1, 2, 3]\r\n *\r\n * _.take([1, 2, 3], 0);\r\n * // => []\r\n */\r\n function take(array, n, guard) {\r\n if (!(array && array.length)) {\r\n return [];\r\n }\r\n n = (guard || n === undefined) ? 1 : toInteger(n);\r\n return baseSlice(array, 0, n < 0 ? 0 : n);\r\n }\r\n\r\n /**\r\n * Creates a slice of `array` with `n` elements taken from the end.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Array\r\n * @param {Array} array The array to query.\r\n * @param {number} [n=1] The number of elements to take.\r\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\r\n * @returns {Array} Returns the slice of `array`.\r\n * @example\r\n *\r\n * _.takeRight([1, 2, 3]);\r\n * // => [3]\r\n *\r\n * _.takeRight([1, 2, 3], 2);\r\n * // => [2, 3]\r\n *\r\n * _.takeRight([1, 2, 3], 5);\r\n * // => [1, 2, 3]\r\n *\r\n * _.takeRight([1, 2, 3], 0);\r\n * // => []\r\n */\r\n function takeRight(array, n, guard) {\r\n var length = array == null ? 0 : array.length;\r\n if (!length) {\r\n return [];\r\n }\r\n n = (guard || n === undefined) ? 1 : toInteger(n);\r\n n = length - n;\r\n return baseSlice(array, n < 0 ? 0 : n, length);\r\n }\r\n\r\n /**\r\n * Creates an array of unique values, in order, from all given arrays using\r\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\r\n * for equality comparisons.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {...Array} [arrays] The arrays to inspect.\r\n * @returns {Array} Returns the new array of combined values.\r\n * @example\r\n *\r\n * _.union([2], [1, 2]);\r\n * // => [2, 1]\r\n */\r\n var union = baseRest(function(arrays) {\r\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\r\n });\r\n\r\n /**\r\n * Creates a duplicate-free version of an array, using\r\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\r\n * for equality comparisons, in which only the first occurrence of each element\r\n * is kept. The order of result values is determined by the order they occur\r\n * in the array.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to inspect.\r\n * @returns {Array} Returns the new duplicate free array.\r\n * @example\r\n *\r\n * _.uniq([2, 1, 2]);\r\n * // => [2, 1]\r\n */\r\n function uniq(array) {\r\n return (array && array.length) ? baseUniq(array) : [];\r\n }\r\n\r\n /**\r\n * This method is like `_.uniq` except that it accepts `iteratee` which is\r\n * invoked for each element in `array` to generate the criterion by which\r\n * uniqueness is computed. The order of result values is determined by the\r\n * order they occur in the array. The iteratee is invoked with one argument:\r\n * (value).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Array\r\n * @param {Array} array The array to inspect.\r\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\r\n * @returns {Array} Returns the new duplicate free array.\r\n * @example\r\n *\r\n * _.uniqBy([2.1, 1.2, 2.3], Math.floor);\r\n * // => [2.1, 1.2]\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');\r\n * // => [{ 'x': 1 }, { 'x': 2 }]\r\n */\r\n function uniqBy(array, iteratee) {\r\n return (array && array.length) ? baseUniq(array, baseIteratee(iteratee, 2)) : [];\r\n }\r\n\r\n /**\r\n * This method is like `_.zip` except that it accepts an array of grouped\r\n * elements and creates an array regrouping the elements to their pre-zip\r\n * configuration.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 1.2.0\r\n * @category Array\r\n * @param {Array} array The array of grouped elements to process.\r\n * @returns {Array} Returns the new array of regrouped elements.\r\n * @example\r\n *\r\n * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]);\r\n * // => [['a', 1, true], ['b', 2, false]]\r\n *\r\n * _.unzip(zipped);\r\n * // => [['a', 'b'], [1, 2], [true, false]]\r\n */\r\n function unzip(array) {\r\n if (!(array && array.length)) {\r\n return [];\r\n }\r\n var length = 0;\r\n array = arrayFilter(array, function(group) {\r\n if (isArrayLikeObject(group)) {\r\n length = nativeMax(group.length, length);\r\n return true;\r\n }\r\n });\r\n return baseTimes(length, function(index) {\r\n return arrayMap(array, baseProperty(index));\r\n });\r\n }\r\n\r\n /**\r\n * Creates an array excluding all given values using\r\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\r\n * for equality comparisons.\r\n *\r\n * **Note:** Unlike `_.pull`, this method returns a new array.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {Array} array The array to inspect.\r\n * @param {...*} [values] The values to exclude.\r\n * @returns {Array} Returns the new array of filtered values.\r\n * @see _.difference, _.xor\r\n * @example\r\n *\r\n * _.without([2, 1, 2, 3], 1, 2);\r\n * // => [3]\r\n */\r\n var without = baseRest(function(array, values) {\r\n return isArrayLikeObject(array)\r\n ? baseDifference(array, values)\r\n : [];\r\n });\r\n\r\n /**\r\n * Creates an array of grouped elements, the first of which contains the\r\n * first elements of the given arrays, the second of which contains the\r\n * second elements of the given arrays, and so on.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Array\r\n * @param {...Array} [arrays] The arrays to process.\r\n * @returns {Array} Returns the new array of grouped elements.\r\n * @example\r\n *\r\n * _.zip(['a', 'b'], [1, 2], [true, false]);\r\n * // => [['a', 1, true], ['b', 2, false]]\r\n */\r\n var zip = baseRest(unzip);\r\n\r\n /**\r\n * This method is like `_.fromPairs` except that it accepts two arrays,\r\n * one of property identifiers and one of corresponding values.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.4.0\r\n * @category Array\r\n * @param {Array} [props=[]] The property identifiers.\r\n * @param {Array} [values=[]] The property values.\r\n * @returns {Object} Returns the new object.\r\n * @example\r\n *\r\n * _.zipObject(['a', 'b'], [1, 2]);\r\n * // => { 'a': 1, 'b': 2 }\r\n */\r\n function zipObject(props, values) {\r\n return baseZipObject(props || [], values || [], assignValue);\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates a `lodash` wrapper instance that wraps `value` with explicit method\r\n * chain sequences enabled. The result of such sequences must be unwrapped\r\n * with `_#value`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 1.3.0\r\n * @category Seq\r\n * @param {*} value The value to wrap.\r\n * @returns {Object} Returns the new `lodash` wrapper instance.\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'age': 36 },\r\n * { 'user': 'fred', 'age': 40 },\r\n * { 'user': 'pebbles', 'age': 1 }\r\n * ];\r\n *\r\n * var youngest = _\r\n * .chain(users)\r\n * .sortBy('age')\r\n * .map(function(o) {\r\n * return o.user + ' is ' + o.age;\r\n * })\r\n * .head()\r\n * .value();\r\n * // => 'pebbles is 1'\r\n */\r\n function chain(value) {\r\n var result = lodash(value);\r\n result.__chain__ = true;\r\n return result;\r\n }\r\n\r\n /**\r\n * This method invokes `interceptor` and returns `value`. The interceptor\r\n * is invoked with one argument; (value). The purpose of this method is to\r\n * \"tap into\" a method chain sequence in order to modify intermediate results.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Seq\r\n * @param {*} value The value to provide to `interceptor`.\r\n * @param {Function} interceptor The function to invoke.\r\n * @returns {*} Returns `value`.\r\n * @example\r\n *\r\n * _([1, 2, 3])\r\n * .tap(function(array) {\r\n * // Mutate input array.\r\n * array.pop();\r\n * })\r\n * .reverse()\r\n * .value();\r\n * // => [2, 1]\r\n */\r\n function tap(value, interceptor) {\r\n interceptor(value);\r\n return value;\r\n }\r\n\r\n /**\r\n * This method is like `_.tap` except that it returns the result of `interceptor`.\r\n * The purpose of this method is to \"pass thru\" values replacing intermediate\r\n * results in a method chain sequence.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Seq\r\n * @param {*} value The value to provide to `interceptor`.\r\n * @param {Function} interceptor The function to invoke.\r\n * @returns {*} Returns the result of `interceptor`.\r\n * @example\r\n *\r\n * _(' abc ')\r\n * .chain()\r\n * .trim()\r\n * .thru(function(value) {\r\n * return [value];\r\n * })\r\n * .value();\r\n * // => ['abc']\r\n */\r\n function thru(value, interceptor) {\r\n return interceptor(value);\r\n }\r\n\r\n /**\r\n * This method is the wrapper version of `_.at`.\r\n *\r\n * @name at\r\n * @memberOf _\r\n * @since 1.0.0\r\n * @category Seq\r\n * @param {...(string|string[])} [paths] The property paths to pick.\r\n * @returns {Object} Returns the new `lodash` wrapper instance.\r\n * @example\r\n *\r\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\r\n *\r\n * _(object).at(['a[0].b.c', 'a[1]']).value();\r\n * // => [3, 4]\r\n */\r\n var wrapperAt = flatRest(function(paths) {\r\n var length = paths.length,\r\n start = length ? paths[0] : 0,\r\n value = this.__wrapped__,\r\n interceptor = function(object) { return baseAt(object, paths); };\r\n\r\n if (length > 1 || this.__actions__.length ||\r\n !(value instanceof LazyWrapper) || !isIndex(start)) {\r\n return this.thru(interceptor);\r\n }\r\n value = value.slice(start, +start + (length ? 1 : 0));\r\n value.__actions__.push({\r\n 'func': thru,\r\n 'args': [interceptor],\r\n 'thisArg': undefined\r\n });\r\n return new LodashWrapper(value, this.__chain__).thru(function(array) {\r\n if (length && !array.length) {\r\n array.push(undefined);\r\n }\r\n return array;\r\n });\r\n });\r\n\r\n /**\r\n * Creates a `lodash` wrapper instance with explicit method chain sequences enabled.\r\n *\r\n * @name chain\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Seq\r\n * @returns {Object} Returns the new `lodash` wrapper instance.\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'age': 36 },\r\n * { 'user': 'fred', 'age': 40 }\r\n * ];\r\n *\r\n * // A sequence without explicit chaining.\r\n * _(users).head();\r\n * // => { 'user': 'barney', 'age': 36 }\r\n *\r\n * // A sequence with explicit chaining.\r\n * _(users)\r\n * .chain()\r\n * .head()\r\n * .pick('user')\r\n * .value();\r\n * // => { 'user': 'barney' }\r\n */\r\n function wrapperChain() {\r\n return chain(this);\r\n }\r\n\r\n /**\r\n * Executes the chain sequence and returns the wrapped result.\r\n *\r\n * @name commit\r\n * @memberOf _\r\n * @since 3.2.0\r\n * @category Seq\r\n * @returns {Object} Returns the new `lodash` wrapper instance.\r\n * @example\r\n *\r\n * var array = [1, 2];\r\n * var wrapped = _(array).push(3);\r\n *\r\n * console.log(array);\r\n * // => [1, 2]\r\n *\r\n * wrapped = wrapped.commit();\r\n * console.log(array);\r\n * // => [1, 2, 3]\r\n *\r\n * wrapped.last();\r\n * // => 3\r\n *\r\n * console.log(array);\r\n * // => [1, 2, 3]\r\n */\r\n function wrapperCommit() {\r\n return new LodashWrapper(this.value(), this.__chain__);\r\n }\r\n\r\n /**\r\n * Gets the next value on a wrapped object following the\r\n * [iterator protocol](https://mdn.io/iteration_protocols#iterator).\r\n *\r\n * @name next\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Seq\r\n * @returns {Object} Returns the next iterator value.\r\n * @example\r\n *\r\n * var wrapped = _([1, 2]);\r\n *\r\n * wrapped.next();\r\n * // => { 'done': false, 'value': 1 }\r\n *\r\n * wrapped.next();\r\n * // => { 'done': false, 'value': 2 }\r\n *\r\n * wrapped.next();\r\n * // => { 'done': true, 'value': undefined }\r\n */\r\n function wrapperNext() {\r\n if (this.__values__ === undefined) {\r\n this.__values__ = toArray(this.value());\r\n }\r\n var done = this.__index__ >= this.__values__.length,\r\n value = done ? undefined : this.__values__[this.__index__++];\r\n\r\n return { 'done': done, 'value': value };\r\n }\r\n\r\n /**\r\n * Enables the wrapper to be iterable.\r\n *\r\n * @name Symbol.iterator\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Seq\r\n * @returns {Object} Returns the wrapper object.\r\n * @example\r\n *\r\n * var wrapped = _([1, 2]);\r\n *\r\n * wrapped[Symbol.iterator]() === wrapped;\r\n * // => true\r\n *\r\n * Array.from(wrapped);\r\n * // => [1, 2]\r\n */\r\n function wrapperToIterator() {\r\n return this;\r\n }\r\n\r\n /**\r\n * Creates a clone of the chain sequence planting `value` as the wrapped value.\r\n *\r\n * @name plant\r\n * @memberOf _\r\n * @since 3.2.0\r\n * @category Seq\r\n * @param {*} value The value to plant.\r\n * @returns {Object} Returns the new `lodash` wrapper instance.\r\n * @example\r\n *\r\n * function square(n) {\r\n * return n * n;\r\n * }\r\n *\r\n * var wrapped = _([1, 2]).map(square);\r\n * var other = wrapped.plant([3, 4]);\r\n *\r\n * other.value();\r\n * // => [9, 16]\r\n *\r\n * wrapped.value();\r\n * // => [1, 4]\r\n */\r\n function wrapperPlant(value) {\r\n var result,\r\n parent = this;\r\n\r\n while (parent instanceof baseLodash) {\r\n var clone = wrapperClone(parent);\r\n clone.__index__ = 0;\r\n clone.__values__ = undefined;\r\n if (result) {\r\n previous.__wrapped__ = clone;\r\n } else {\r\n result = clone;\r\n }\r\n var previous = clone;\r\n parent = parent.__wrapped__;\r\n }\r\n previous.__wrapped__ = value;\r\n return result;\r\n }\r\n\r\n /**\r\n * This method is the wrapper version of `_.reverse`.\r\n *\r\n * **Note:** This method mutates the wrapped array.\r\n *\r\n * @name reverse\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Seq\r\n * @returns {Object} Returns the new `lodash` wrapper instance.\r\n * @example\r\n *\r\n * var array = [1, 2, 3];\r\n *\r\n * _(array).reverse().value()\r\n * // => [3, 2, 1]\r\n *\r\n * console.log(array);\r\n * // => [3, 2, 1]\r\n */\r\n function wrapperReverse() {\r\n var value = this.__wrapped__;\r\n if (value instanceof LazyWrapper) {\r\n var wrapped = value;\r\n if (this.__actions__.length) {\r\n wrapped = new LazyWrapper(this);\r\n }\r\n wrapped = wrapped.reverse();\r\n wrapped.__actions__.push({\r\n 'func': thru,\r\n 'args': [reverse],\r\n 'thisArg': undefined\r\n });\r\n return new LodashWrapper(wrapped, this.__chain__);\r\n }\r\n return this.thru(reverse);\r\n }\r\n\r\n /**\r\n * Executes the chain sequence to resolve the unwrapped value.\r\n *\r\n * @name value\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @alias toJSON, valueOf\r\n * @category Seq\r\n * @returns {*} Returns the resolved unwrapped value.\r\n * @example\r\n *\r\n * _([1, 2, 3]).value();\r\n * // => [1, 2, 3]\r\n */\r\n function wrapperValue() {\r\n return baseWrapperValue(this.__wrapped__, this.__actions__);\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates an object composed of keys generated from the results of running\r\n * each element of `collection` thru `iteratee`. The corresponding value of\r\n * each key is the number of times the key was returned by `iteratee`. The\r\n * iteratee is invoked with one argument: (value).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.5.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\r\n * @returns {Object} Returns the composed aggregate object.\r\n * @example\r\n *\r\n * _.countBy([6.1, 4.2, 6.3], Math.floor);\r\n * // => { '4': 1, '6': 2 }\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.countBy(['one', 'two', 'three'], 'length');\r\n * // => { '3': 2, '5': 1 }\r\n */\r\n var countBy = createAggregator(function(result, value, key) {\r\n if (hasOwnProperty.call(result, key)) {\r\n ++result[key];\r\n } else {\r\n baseAssignValue(result, key, 1);\r\n }\r\n });\r\n\r\n /**\r\n * Checks if `predicate` returns truthy for **all** elements of `collection`.\r\n * Iteration is stopped once `predicate` returns falsey. The predicate is\r\n * invoked with three arguments: (value, index|key, collection).\r\n *\r\n * **Note:** This method returns `true` for\r\n * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because\r\n * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of\r\n * elements of empty collections.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\r\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\r\n * else `false`.\r\n * @example\r\n *\r\n * _.every([true, 1, null, 'yes'], Boolean);\r\n * // => false\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'age': 36, 'active': false },\r\n * { 'user': 'fred', 'age': 40, 'active': false }\r\n * ];\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.every(users, { 'user': 'barney', 'active': false });\r\n * // => false\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.every(users, ['active', false]);\r\n * // => true\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.every(users, 'active');\r\n * // => false\r\n */\r\n function every(collection, predicate, guard) {\r\n var func = isArray(collection) ? arrayEvery : baseEvery;\r\n if (guard && isIterateeCall(collection, predicate, guard)) {\r\n predicate = undefined;\r\n }\r\n return func(collection, baseIteratee(predicate, 3));\r\n }\r\n\r\n /**\r\n * Iterates over elements of `collection`, returning an array of all elements\r\n * `predicate` returns truthy for. The predicate is invoked with three\r\n * arguments: (value, index|key, collection).\r\n *\r\n * **Note:** Unlike `_.remove`, this method returns a new array.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @returns {Array} Returns the new filtered array.\r\n * @see _.reject\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'age': 36, 'active': true },\r\n * { 'user': 'fred', 'age': 40, 'active': false }\r\n * ];\r\n *\r\n * _.filter(users, function(o) { return !o.active; });\r\n * // => objects for ['fred']\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.filter(users, { 'age': 36, 'active': true });\r\n * // => objects for ['barney']\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.filter(users, ['active', false]);\r\n * // => objects for ['fred']\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.filter(users, 'active');\r\n * // => objects for ['barney']\r\n */\r\n function filter(collection, predicate) {\r\n var func = isArray(collection) ? arrayFilter : baseFilter;\r\n return func(collection, baseIteratee(predicate, 3));\r\n }\r\n\r\n /**\r\n * Iterates over elements of `collection`, returning the first element\r\n * `predicate` returns truthy for. The predicate is invoked with three\r\n * arguments: (value, index|key, collection).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to inspect.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @param {number} [fromIndex=0] The index to search from.\r\n * @returns {*} Returns the matched element, else `undefined`.\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'age': 36, 'active': true },\r\n * { 'user': 'fred', 'age': 40, 'active': false },\r\n * { 'user': 'pebbles', 'age': 1, 'active': true }\r\n * ];\r\n *\r\n * _.find(users, function(o) { return o.age < 40; });\r\n * // => object for 'barney'\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.find(users, { 'age': 1, 'active': true });\r\n * // => object for 'pebbles'\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.find(users, ['active', false]);\r\n * // => object for 'fred'\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.find(users, 'active');\r\n * // => object for 'barney'\r\n */\r\n var find = createFind(findIndex);\r\n\r\n /**\r\n * Iterates over elements of `collection` and invokes `iteratee` for each element.\r\n * The iteratee is invoked with three arguments: (value, index|key, collection).\r\n * Iteratee functions may exit iteration early by explicitly returning `false`.\r\n *\r\n * **Note:** As with other \"Collections\" methods, objects with a \"length\"\r\n * property are iterated like arrays. To avoid this behavior use `_.forIn`\r\n * or `_.forOwn` for object iteration.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @alias each\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\r\n * @returns {Array|Object} Returns `collection`.\r\n * @see _.forEachRight\r\n * @example\r\n *\r\n * _.forEach([1, 2], function(value) {\r\n * console.log(value);\r\n * });\r\n * // => Logs `1` then `2`.\r\n *\r\n * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {\r\n * console.log(key);\r\n * });\r\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\r\n */\r\n function forEach(collection, iteratee) {\r\n var func = isArray(collection) ? arrayEach : baseEach;\r\n return func(collection, baseIteratee(iteratee, 3));\r\n }\r\n\r\n /**\r\n * Creates an object composed of keys generated from the results of running\r\n * each element of `collection` thru `iteratee`. The order of grouped values\r\n * is determined by the order they occur in `collection`. The corresponding\r\n * value of each key is an array of elements responsible for generating the\r\n * key. The iteratee is invoked with one argument: (value).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\r\n * @returns {Object} Returns the composed aggregate object.\r\n * @example\r\n *\r\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\r\n * // => { '4': [4.2], '6': [6.1, 6.3] }\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.groupBy(['one', 'two', 'three'], 'length');\r\n * // => { '3': ['one', 'two'], '5': ['three'] }\r\n */\r\n var groupBy = createAggregator(function(result, value, key) {\r\n if (hasOwnProperty.call(result, key)) {\r\n result[key].push(value);\r\n } else {\r\n baseAssignValue(result, key, [value]);\r\n }\r\n });\r\n\r\n /**\r\n * Creates an array of values by running each element in `collection` thru\r\n * `iteratee`. The iteratee is invoked with three arguments:\r\n * (value, index|key, collection).\r\n *\r\n * Many lodash methods are guarded to work as iteratees for methods like\r\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\r\n *\r\n * The guarded methods are:\r\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\r\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\r\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\r\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\r\n * @returns {Array} Returns the new mapped array.\r\n * @example\r\n *\r\n * function square(n) {\r\n * return n * n;\r\n * }\r\n *\r\n * _.map([4, 8], square);\r\n * // => [16, 64]\r\n *\r\n * _.map({ 'a': 4, 'b': 8 }, square);\r\n * // => [16, 64] (iteration order is not guaranteed)\r\n *\r\n * var users = [\r\n * { 'user': 'barney' },\r\n * { 'user': 'fred' }\r\n * ];\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.map(users, 'user');\r\n * // => ['barney', 'fred']\r\n */\r\n function map(collection, iteratee) {\r\n var func = isArray(collection) ? arrayMap : baseMap;\r\n return func(collection, baseIteratee(iteratee, 3));\r\n }\r\n\r\n /**\r\n * Reduces `collection` to a value which is the accumulated result of running\r\n * each element in `collection` thru `iteratee`, where each successive\r\n * invocation is supplied the return value of the previous. If `accumulator`\r\n * is not given, the first element of `collection` is used as the initial\r\n * value. The iteratee is invoked with four arguments:\r\n * (accumulator, value, index|key, collection).\r\n *\r\n * Many lodash methods are guarded to work as iteratees for methods like\r\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\r\n *\r\n * The guarded methods are:\r\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\r\n * and `sortBy`\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\r\n * @param {*} [accumulator] The initial value.\r\n * @returns {*} Returns the accumulated value.\r\n * @see _.reduceRight\r\n * @example\r\n *\r\n * _.reduce([1, 2], function(sum, n) {\r\n * return sum + n;\r\n * }, 0);\r\n * // => 3\r\n *\r\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\r\n * (result[value] || (result[value] = [])).push(key);\r\n * return result;\r\n * }, {});\r\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\r\n */\r\n function reduce(collection, iteratee, accumulator) {\r\n var func = isArray(collection) ? arrayReduce : baseReduce,\r\n initAccum = arguments.length < 3;\r\n\r\n return func(collection, baseIteratee(iteratee, 4), accumulator, initAccum, baseEach);\r\n }\r\n\r\n /**\r\n * The opposite of `_.filter`; this method returns the elements of `collection`\r\n * that `predicate` does **not** return truthy for.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @returns {Array} Returns the new filtered array.\r\n * @see _.filter\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'age': 36, 'active': false },\r\n * { 'user': 'fred', 'age': 40, 'active': true }\r\n * ];\r\n *\r\n * _.reject(users, function(o) { return !o.active; });\r\n * // => objects for ['fred']\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.reject(users, { 'age': 40, 'active': true });\r\n * // => objects for ['barney']\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.reject(users, ['active', false]);\r\n * // => objects for ['fred']\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.reject(users, 'active');\r\n * // => objects for ['barney']\r\n */\r\n function reject(collection, predicate) {\r\n var func = isArray(collection) ? arrayFilter : baseFilter;\r\n return func(collection, negate(baseIteratee(predicate, 3)));\r\n }\r\n\r\n /**\r\n * Gets the size of `collection` by returning its length for array-like\r\n * values or the number of own enumerable string keyed properties for objects.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object|string} collection The collection to inspect.\r\n * @returns {number} Returns the collection size.\r\n * @example\r\n *\r\n * _.size([1, 2, 3]);\r\n * // => 3\r\n *\r\n * _.size({ 'a': 1, 'b': 2 });\r\n * // => 2\r\n *\r\n * _.size('pebbles');\r\n * // => 7\r\n */\r\n function size(collection) {\r\n if (collection == null) {\r\n return 0;\r\n }\r\n if (isArrayLike(collection)) {\r\n return isString(collection) ? stringSize(collection) : collection.length;\r\n }\r\n var tag = getTag(collection);\r\n if (tag == mapTag || tag == setTag) {\r\n return collection.size;\r\n }\r\n return baseKeys(collection).length;\r\n }\r\n\r\n /**\r\n * Checks if `predicate` returns truthy for **any** element of `collection`.\r\n * Iteration is stopped once `predicate` returns truthy. The predicate is\r\n * invoked with three arguments: (value, index|key, collection).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\r\n * @returns {boolean} Returns `true` if any element passes the predicate check,\r\n * else `false`.\r\n * @example\r\n *\r\n * _.some([null, 0, 'yes', false], Boolean);\r\n * // => true\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'active': true },\r\n * { 'user': 'fred', 'active': false }\r\n * ];\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.some(users, { 'user': 'barney', 'active': false });\r\n * // => false\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.some(users, ['active', false]);\r\n * // => true\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.some(users, 'active');\r\n * // => true\r\n */\r\n function some(collection, predicate, guard) {\r\n var func = isArray(collection) ? arraySome : baseSome;\r\n if (guard && isIterateeCall(collection, predicate, guard)) {\r\n predicate = undefined;\r\n }\r\n return func(collection, baseIteratee(predicate, 3));\r\n }\r\n\r\n /**\r\n * Creates an array of elements, sorted in ascending order by the results of\r\n * running each element in a collection thru each iteratee. This method\r\n * performs a stable sort, that is, it preserves the original sort order of\r\n * equal elements. The iteratees are invoked with one argument: (value).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Collection\r\n * @param {Array|Object} collection The collection to iterate over.\r\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\r\n * The iteratees to sort by.\r\n * @returns {Array} Returns the new sorted array.\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'fred', 'age': 48 },\r\n * { 'user': 'barney', 'age': 36 },\r\n * { 'user': 'fred', 'age': 40 },\r\n * { 'user': 'barney', 'age': 34 }\r\n * ];\r\n *\r\n * _.sortBy(users, [function(o) { return o.user; }]);\r\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]\r\n *\r\n * _.sortBy(users, ['user', 'age']);\r\n * // => objects for [['barney', 34], ['barney', 36], ['fred', 40], ['fred', 48]]\r\n */\r\n var sortBy = baseRest(function(collection, iteratees) {\r\n if (collection == null) {\r\n return [];\r\n }\r\n var length = iteratees.length;\r\n if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) {\r\n iteratees = [];\r\n } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) {\r\n iteratees = [iteratees[0]];\r\n }\r\n return baseOrderBy(collection, baseFlatten(iteratees, 1), []);\r\n });\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Gets the timestamp of the number of milliseconds that have elapsed since\r\n * the Unix epoch (1 January 1970 00:00:00 UTC).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 2.4.0\r\n * @category Date\r\n * @returns {number} Returns the timestamp.\r\n * @example\r\n *\r\n * _.defer(function(stamp) {\r\n * console.log(_.now() - stamp);\r\n * }, _.now());\r\n * // => Logs the number of milliseconds it took for the deferred invocation.\r\n */\r\n var now = function() {\r\n return root.Date.now();\r\n };\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * The opposite of `_.before`; this method creates a function that invokes\r\n * `func` once it's called `n` or more times.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Function\r\n * @param {number} n The number of calls before `func` is invoked.\r\n * @param {Function} func The function to restrict.\r\n * @returns {Function} Returns the new restricted function.\r\n * @example\r\n *\r\n * var saves = ['profile', 'settings'];\r\n *\r\n * var done = _.after(saves.length, function() {\r\n * console.log('done saving!');\r\n * });\r\n *\r\n * _.forEach(saves, function(type) {\r\n * asyncSave({ 'type': type, 'complete': done });\r\n * });\r\n * // => Logs 'done saving!' after the two async saves have completed.\r\n */\r\n function after(n, func) {\r\n if (typeof func != 'function') {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n n = toInteger(n);\r\n return function() {\r\n if (--n < 1) {\r\n return func.apply(this, arguments);\r\n }\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function that invokes `func`, with the `this` binding and arguments\r\n * of the created function, while it's called less than `n` times. Subsequent\r\n * calls to the created function return the result of the last `func` invocation.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Function\r\n * @param {number} n The number of calls at which `func` is no longer invoked.\r\n * @param {Function} func The function to restrict.\r\n * @returns {Function} Returns the new restricted function.\r\n * @example\r\n *\r\n * jQuery(element).on('click', _.before(5, addContactToList));\r\n * // => Allows adding up to 4 contacts to the list.\r\n */\r\n function before(n, func) {\r\n var result;\r\n if (typeof func != 'function') {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n n = toInteger(n);\r\n return function() {\r\n if (--n > 0) {\r\n result = func.apply(this, arguments);\r\n }\r\n if (n <= 1) {\r\n func = undefined;\r\n }\r\n return result;\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function that invokes `func` with the `this` binding of `thisArg`\r\n * and `partials` prepended to the arguments it receives.\r\n *\r\n * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,\r\n * may be used as a placeholder for partially applied arguments.\r\n *\r\n * **Note:** Unlike native `Function#bind`, this method doesn't set the \"length\"\r\n * property of bound functions.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Function\r\n * @param {Function} func The function to bind.\r\n * @param {*} thisArg The `this` binding of `func`.\r\n * @param {...*} [partials] The arguments to be partially applied.\r\n * @returns {Function} Returns the new bound function.\r\n * @example\r\n *\r\n * function greet(greeting, punctuation) {\r\n * return greeting + ' ' + this.user + punctuation;\r\n * }\r\n *\r\n * var object = { 'user': 'fred' };\r\n *\r\n * var bound = _.bind(greet, object, 'hi');\r\n * bound('!');\r\n * // => 'hi fred!'\r\n *\r\n * // Bound with placeholders.\r\n * var bound = _.bind(greet, object, _, '!');\r\n * bound('hi');\r\n * // => 'hi fred!'\r\n */\r\n var bind = baseRest(function(func, thisArg, partials) {\r\n var bitmask = WRAP_BIND_FLAG;\r\n if (partials.length) {\r\n var holders = replaceHolders(partials, getHolder(bind));\r\n bitmask |= WRAP_PARTIAL_FLAG;\r\n }\r\n return createWrap(func, bitmask, thisArg, partials, holders);\r\n });\r\n\r\n /**\r\n * Creates a debounced function that delays invoking `func` until after `wait`\r\n * milliseconds have elapsed since the last time the debounced function was\r\n * invoked. The debounced function comes with a `cancel` method to cancel\r\n * delayed `func` invocations and a `flush` method to immediately invoke them.\r\n * Provide `options` to indicate whether `func` should be invoked on the\r\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\r\n * with the last arguments provided to the debounced function. Subsequent\r\n * calls to the debounced function return the result of the last `func`\r\n * invocation.\r\n *\r\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\r\n * invoked on the trailing edge of the timeout only if the debounced function\r\n * is invoked more than once during the `wait` timeout.\r\n *\r\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\r\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\r\n *\r\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\r\n * for details over the differences between `_.debounce` and `_.throttle`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Function\r\n * @param {Function} func The function to debounce.\r\n * @param {number} [wait=0] The number of milliseconds to delay.\r\n * @param {Object} [options={}] The options object.\r\n * @param {boolean} [options.leading=false]\r\n * Specify invoking on the leading edge of the timeout.\r\n * @param {number} [options.maxWait]\r\n * The maximum time `func` is allowed to be delayed before it's invoked.\r\n * @param {boolean} [options.trailing=true]\r\n * Specify invoking on the trailing edge of the timeout.\r\n * @returns {Function} Returns the new debounced function.\r\n * @example\r\n *\r\n * // Avoid costly calculations while the window size is in flux.\r\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\r\n *\r\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\r\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\r\n * 'leading': true,\r\n * 'trailing': false\r\n * }));\r\n *\r\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\r\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\r\n * var source = new EventSource('/stream');\r\n * jQuery(source).on('message', debounced);\r\n *\r\n * // Cancel the trailing debounced invocation.\r\n * jQuery(window).on('popstate', debounced.cancel);\r\n */\r\n function debounce(func, wait, options) {\r\n var lastArgs,\r\n lastThis,\r\n maxWait,\r\n result,\r\n timerId,\r\n lastCallTime,\r\n lastInvokeTime = 0,\r\n leading = false,\r\n maxing = false,\r\n trailing = true;\r\n\r\n if (typeof func != 'function') {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n wait = toNumber(wait) || 0;\r\n if (isObject(options)) {\r\n leading = !!options.leading;\r\n maxing = 'maxWait' in options;\r\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\r\n trailing = 'trailing' in options ? !!options.trailing : trailing;\r\n }\r\n\r\n function invokeFunc(time) {\r\n var args = lastArgs,\r\n thisArg = lastThis;\r\n\r\n lastArgs = lastThis = undefined;\r\n lastInvokeTime = time;\r\n result = func.apply(thisArg, args);\r\n return result;\r\n }\r\n\r\n function leadingEdge(time) {\r\n // Reset any `maxWait` timer.\r\n lastInvokeTime = time;\r\n // Start the timer for the trailing edge.\r\n timerId = setTimeout(timerExpired, wait);\r\n // Invoke the leading edge.\r\n return leading ? invokeFunc(time) : result;\r\n }\r\n\r\n function remainingWait(time) {\r\n var timeSinceLastCall = time - lastCallTime,\r\n timeSinceLastInvoke = time - lastInvokeTime,\r\n timeWaiting = wait - timeSinceLastCall;\r\n\r\n return maxing\r\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\r\n : timeWaiting;\r\n }\r\n\r\n function shouldInvoke(time) {\r\n var timeSinceLastCall = time - lastCallTime,\r\n timeSinceLastInvoke = time - lastInvokeTime;\r\n\r\n // Either this is the first call, activity has stopped and we're at the\r\n // trailing edge, the system time has gone backwards and we're treating\r\n // it as the trailing edge, or we've hit the `maxWait` limit.\r\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\r\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\r\n }\r\n\r\n function timerExpired() {\r\n var time = now();\r\n if (shouldInvoke(time)) {\r\n return trailingEdge(time);\r\n }\r\n // Restart the timer.\r\n timerId = setTimeout(timerExpired, remainingWait(time));\r\n }\r\n\r\n function trailingEdge(time) {\r\n timerId = undefined;\r\n\r\n // Only invoke if we have `lastArgs` which means `func` has been\r\n // debounced at least once.\r\n if (trailing && lastArgs) {\r\n return invokeFunc(time);\r\n }\r\n lastArgs = lastThis = undefined;\r\n return result;\r\n }\r\n\r\n function cancel() {\r\n if (timerId !== undefined) {\r\n clearTimeout(timerId);\r\n }\r\n lastInvokeTime = 0;\r\n lastArgs = lastCallTime = lastThis = timerId = undefined;\r\n }\r\n\r\n function flush() {\r\n return timerId === undefined ? result : trailingEdge(now());\r\n }\r\n\r\n function debounced() {\r\n var time = now(),\r\n isInvoking = shouldInvoke(time);\r\n\r\n lastArgs = arguments;\r\n lastThis = this;\r\n lastCallTime = time;\r\n\r\n if (isInvoking) {\r\n if (timerId === undefined) {\r\n return leadingEdge(lastCallTime);\r\n }\r\n if (maxing) {\r\n // Handle invocations in a tight loop.\r\n timerId = setTimeout(timerExpired, wait);\r\n return invokeFunc(lastCallTime);\r\n }\r\n }\r\n if (timerId === undefined) {\r\n timerId = setTimeout(timerExpired, wait);\r\n }\r\n return result;\r\n }\r\n debounced.cancel = cancel;\r\n debounced.flush = flush;\r\n return debounced;\r\n }\r\n\r\n /**\r\n * Defers invoking the `func` until the current call stack has cleared. Any\r\n * additional arguments are provided to `func` when it's invoked.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Function\r\n * @param {Function} func The function to defer.\r\n * @param {...*} [args] The arguments to invoke `func` with.\r\n * @returns {number} Returns the timer id.\r\n * @example\r\n *\r\n * _.defer(function(text) {\r\n * console.log(text);\r\n * }, 'deferred');\r\n * // => Logs 'deferred' after one millisecond.\r\n */\r\n var defer = baseRest(function(func, args) {\r\n return baseDelay(func, 1, args);\r\n });\r\n\r\n /**\r\n * Invokes `func` after `wait` milliseconds. Any additional arguments are\r\n * provided to `func` when it's invoked.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Function\r\n * @param {Function} func The function to delay.\r\n * @param {number} wait The number of milliseconds to delay invocation.\r\n * @param {...*} [args] The arguments to invoke `func` with.\r\n * @returns {number} Returns the timer id.\r\n * @example\r\n *\r\n * _.delay(function(text) {\r\n * console.log(text);\r\n * }, 1000, 'later');\r\n * // => Logs 'later' after one second.\r\n */\r\n var delay = baseRest(function(func, wait, args) {\r\n return baseDelay(func, toNumber(wait) || 0, args);\r\n });\r\n\r\n /**\r\n * Creates a function that memoizes the result of `func`. If `resolver` is\r\n * provided, it determines the cache key for storing the result based on the\r\n * arguments provided to the memoized function. By default, the first argument\r\n * provided to the memoized function is used as the map cache key. The `func`\r\n * is invoked with the `this` binding of the memoized function.\r\n *\r\n * **Note:** The cache is exposed as the `cache` property on the memoized\r\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\r\n * constructor with one whose instances implement the\r\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\r\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Function\r\n * @param {Function} func The function to have its output memoized.\r\n * @param {Function} [resolver] The function to resolve the cache key.\r\n * @returns {Function} Returns the new memoized function.\r\n * @example\r\n *\r\n * var object = { 'a': 1, 'b': 2 };\r\n * var other = { 'c': 3, 'd': 4 };\r\n *\r\n * var values = _.memoize(_.values);\r\n * values(object);\r\n * // => [1, 2]\r\n *\r\n * values(other);\r\n * // => [3, 4]\r\n *\r\n * object.a = 2;\r\n * values(object);\r\n * // => [1, 2]\r\n *\r\n * // Modify the result cache.\r\n * values.cache.set(object, ['a', 'b']);\r\n * values(object);\r\n * // => ['a', 'b']\r\n *\r\n * // Replace `_.memoize.Cache`.\r\n * _.memoize.Cache = WeakMap;\r\n */\r\n function memoize(func, resolver) {\r\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n var memoized = function() {\r\n var args = arguments,\r\n key = resolver ? resolver.apply(this, args) : args[0],\r\n cache = memoized.cache;\r\n\r\n if (cache.has(key)) {\r\n return cache.get(key);\r\n }\r\n var result = func.apply(this, args);\r\n memoized.cache = cache.set(key, result) || cache;\r\n return result;\r\n };\r\n memoized.cache = new (memoize.Cache || MapCache);\r\n return memoized;\r\n }\r\n\r\n // Expose `MapCache`.\r\n memoize.Cache = MapCache;\r\n\r\n /**\r\n * Creates a function that negates the result of the predicate `func`. The\r\n * `func` predicate is invoked with the `this` binding and arguments of the\r\n * created function.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Function\r\n * @param {Function} predicate The predicate to negate.\r\n * @returns {Function} Returns the new negated function.\r\n * @example\r\n *\r\n * function isEven(n) {\r\n * return n % 2 == 0;\r\n * }\r\n *\r\n * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven));\r\n * // => [1, 3, 5]\r\n */\r\n function negate(predicate) {\r\n if (typeof predicate != 'function') {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n return function() {\r\n var args = arguments;\r\n switch (args.length) {\r\n case 0: return !predicate.call(this);\r\n case 1: return !predicate.call(this, args[0]);\r\n case 2: return !predicate.call(this, args[0], args[1]);\r\n case 3: return !predicate.call(this, args[0], args[1], args[2]);\r\n }\r\n return !predicate.apply(this, args);\r\n };\r\n }\r\n\r\n /**\r\n * Creates a function that is restricted to invoking `func` once. Repeat calls\r\n * to the function return the value of the first invocation. The `func` is\r\n * invoked with the `this` binding and arguments of the created function.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Function\r\n * @param {Function} func The function to restrict.\r\n * @returns {Function} Returns the new restricted function.\r\n * @example\r\n *\r\n * var initialize = _.once(createApplication);\r\n * initialize();\r\n * initialize();\r\n * // => `createApplication` is invoked once\r\n */\r\n function once(func) {\r\n return before(2, func);\r\n }\r\n\r\n /**\r\n * Creates a function that invokes `func` with the `this` binding of the\r\n * created function and arguments from `start` and beyond provided as\r\n * an array.\r\n *\r\n * **Note:** This method is based on the\r\n * [rest parameter](https://mdn.io/rest_parameters).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Function\r\n * @param {Function} func The function to apply a rest parameter to.\r\n * @param {number} [start=func.length-1] The start position of the rest parameter.\r\n * @returns {Function} Returns the new function.\r\n * @example\r\n *\r\n * var say = _.rest(function(what, names) {\r\n * return what + ' ' + _.initial(names).join(', ') +\r\n * (_.size(names) > 1 ? ', & ' : '') + _.last(names);\r\n * });\r\n *\r\n * say('hello', 'fred', 'barney', 'pebbles');\r\n * // => 'hello fred, barney, & pebbles'\r\n */\r\n function rest(func, start) {\r\n if (typeof func != 'function') {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n start = start === undefined ? start : toInteger(start);\r\n return baseRest(func, start);\r\n }\r\n\r\n /**\r\n * Creates a throttled function that only invokes `func` at most once per\r\n * every `wait` milliseconds. The throttled function comes with a `cancel`\r\n * method to cancel delayed `func` invocations and a `flush` method to\r\n * immediately invoke them. Provide `options` to indicate whether `func`\r\n * should be invoked on the leading and/or trailing edge of the `wait`\r\n * timeout. The `func` is invoked with the last arguments provided to the\r\n * throttled function. Subsequent calls to the throttled function return the\r\n * result of the last `func` invocation.\r\n *\r\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\r\n * invoked on the trailing edge of the timeout only if the throttled function\r\n * is invoked more than once during the `wait` timeout.\r\n *\r\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\r\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\r\n *\r\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\r\n * for details over the differences between `_.throttle` and `_.debounce`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Function\r\n * @param {Function} func The function to throttle.\r\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\r\n * @param {Object} [options={}] The options object.\r\n * @param {boolean} [options.leading=true]\r\n * Specify invoking on the leading edge of the timeout.\r\n * @param {boolean} [options.trailing=true]\r\n * Specify invoking on the trailing edge of the timeout.\r\n * @returns {Function} Returns the new throttled function.\r\n * @example\r\n *\r\n * // Avoid excessively updating the position while scrolling.\r\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\r\n *\r\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\r\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\r\n * jQuery(element).on('click', throttled);\r\n *\r\n * // Cancel the trailing throttled invocation.\r\n * jQuery(window).on('popstate', throttled.cancel);\r\n */\r\n function throttle(func, wait, options) {\r\n var leading = true,\r\n trailing = true;\r\n\r\n if (typeof func != 'function') {\r\n throw new TypeError(FUNC_ERROR_TEXT);\r\n }\r\n if (isObject(options)) {\r\n leading = 'leading' in options ? !!options.leading : leading;\r\n trailing = 'trailing' in options ? !!options.trailing : trailing;\r\n }\r\n return debounce(func, wait, {\r\n 'leading': leading,\r\n 'maxWait': wait,\r\n 'trailing': trailing\r\n });\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates a shallow clone of `value`.\r\n *\r\n * **Note:** This method is loosely based on the\r\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\r\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\r\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\r\n * arrays. The own enumerable properties of `arguments` objects are cloned\r\n * as plain objects. An empty object is returned for uncloneable values such\r\n * as error objects, functions, DOM nodes, and WeakMaps.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to clone.\r\n * @returns {*} Returns the cloned value.\r\n * @see _.cloneDeep\r\n * @example\r\n *\r\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\r\n *\r\n * var shallow = _.clone(objects);\r\n * console.log(shallow[0] === objects[0]);\r\n * // => true\r\n */\r\n function clone(value) {\r\n return baseClone(value, CLONE_SYMBOLS_FLAG);\r\n }\r\n\r\n /**\r\n * This method is like `_.clone` except that it recursively clones `value`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 1.0.0\r\n * @category Lang\r\n * @param {*} value The value to recursively clone.\r\n * @returns {*} Returns the deep cloned value.\r\n * @see _.clone\r\n * @example\r\n *\r\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\r\n *\r\n * var deep = _.cloneDeep(objects);\r\n * console.log(deep[0] === objects[0]);\r\n * // => false\r\n */\r\n function cloneDeep(value) {\r\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\r\n }\r\n\r\n /**\r\n * Performs a\r\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\r\n * comparison between two values to determine if they are equivalent.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to compare.\r\n * @param {*} other The other value to compare.\r\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\r\n * @example\r\n *\r\n * var object = { 'a': 1 };\r\n * var other = { 'a': 1 };\r\n *\r\n * _.eq(object, object);\r\n * // => true\r\n *\r\n * _.eq(object, other);\r\n * // => false\r\n *\r\n * _.eq('a', 'a');\r\n * // => true\r\n *\r\n * _.eq('a', Object('a'));\r\n * // => false\r\n *\r\n * _.eq(NaN, NaN);\r\n * // => true\r\n */\r\n function eq(value, other) {\r\n return value === other || (value !== value && other !== other);\r\n }\r\n\r\n /**\r\n * Checks if `value` is likely an `arguments` object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\r\n * else `false`.\r\n * @example\r\n *\r\n * _.isArguments(function() { return arguments; }());\r\n * // => true\r\n *\r\n * _.isArguments([1, 2, 3]);\r\n * // => false\r\n */\r\n var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\r\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\r\n !propertyIsEnumerable.call(value, 'callee');\r\n };\r\n\r\n /**\r\n * Checks if `value` is classified as an `Array` object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\r\n * @example\r\n *\r\n * _.isArray([1, 2, 3]);\r\n * // => true\r\n *\r\n * _.isArray(document.body.children);\r\n * // => false\r\n *\r\n * _.isArray('abc');\r\n * // => false\r\n *\r\n * _.isArray(_.noop);\r\n * // => false\r\n */\r\n var isArray = Array.isArray;\r\n\r\n /**\r\n * Checks if `value` is array-like. A value is considered array-like if it's\r\n * not a function and has a `value.length` that's an integer greater than or\r\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\r\n * @example\r\n *\r\n * _.isArrayLike([1, 2, 3]);\r\n * // => true\r\n *\r\n * _.isArrayLike(document.body.children);\r\n * // => true\r\n *\r\n * _.isArrayLike('abc');\r\n * // => true\r\n *\r\n * _.isArrayLike(_.noop);\r\n * // => false\r\n */\r\n function isArrayLike(value) {\r\n return value != null && isLength(value.length) && !isFunction(value);\r\n }\r\n\r\n /**\r\n * This method is like `_.isArrayLike` except that it also checks if `value`\r\n * is an object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is an array-like object,\r\n * else `false`.\r\n * @example\r\n *\r\n * _.isArrayLikeObject([1, 2, 3]);\r\n * // => true\r\n *\r\n * _.isArrayLikeObject(document.body.children);\r\n * // => true\r\n *\r\n * _.isArrayLikeObject('abc');\r\n * // => false\r\n *\r\n * _.isArrayLikeObject(_.noop);\r\n * // => false\r\n */\r\n function isArrayLikeObject(value) {\r\n return isObjectLike(value) && isArrayLike(value);\r\n }\r\n\r\n /**\r\n * Checks if `value` is classified as a boolean primitive or object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a boolean, else `false`.\r\n * @example\r\n *\r\n * _.isBoolean(false);\r\n * // => true\r\n *\r\n * _.isBoolean(null);\r\n * // => false\r\n */\r\n function isBoolean(value) {\r\n return value === true || value === false ||\r\n (isObjectLike(value) && baseGetTag(value) == boolTag);\r\n }\r\n\r\n /**\r\n * Checks if `value` is a buffer.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.3.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\r\n * @example\r\n *\r\n * _.isBuffer(new Buffer(2));\r\n * // => true\r\n *\r\n * _.isBuffer(new Uint8Array(2));\r\n * // => false\r\n */\r\n var isBuffer = nativeIsBuffer || stubFalse;\r\n\r\n /**\r\n * Checks if `value` is classified as a `Date` object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\r\n * @example\r\n *\r\n * _.isDate(new Date);\r\n * // => true\r\n *\r\n * _.isDate('Mon April 23 2012');\r\n * // => false\r\n */\r\n var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate;\r\n\r\n /**\r\n * Checks if `value` is an empty object, collection, map, or set.\r\n *\r\n * Objects are considered empty if they have no own enumerable string keyed\r\n * properties.\r\n *\r\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\r\n * jQuery-like collections are considered empty if they have a `length` of `0`.\r\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\r\n * @example\r\n *\r\n * _.isEmpty(null);\r\n * // => true\r\n *\r\n * _.isEmpty(true);\r\n * // => true\r\n *\r\n * _.isEmpty(1);\r\n * // => true\r\n *\r\n * _.isEmpty([1, 2, 3]);\r\n * // => false\r\n *\r\n * _.isEmpty({ 'a': 1 });\r\n * // => false\r\n */\r\n function isEmpty(value) {\r\n if (value == null) {\r\n return true;\r\n }\r\n if (isArrayLike(value) &&\r\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\r\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\r\n return !value.length;\r\n }\r\n var tag = getTag(value);\r\n if (tag == mapTag || tag == setTag) {\r\n return !value.size;\r\n }\r\n if (isPrototype(value)) {\r\n return !baseKeys(value).length;\r\n }\r\n for (var key in value) {\r\n if (hasOwnProperty.call(value, key)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n }\r\n\r\n /**\r\n * Performs a deep comparison between two values to determine if they are\r\n * equivalent.\r\n *\r\n * **Note:** This method supports comparing arrays, array buffers, booleans,\r\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\r\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\r\n * by their own, not inherited, enumerable properties. Functions and DOM\r\n * nodes are compared by strict equality, i.e. `===`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to compare.\r\n * @param {*} other The other value to compare.\r\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\r\n * @example\r\n *\r\n * var object = { 'a': 1 };\r\n * var other = { 'a': 1 };\r\n *\r\n * _.isEqual(object, other);\r\n * // => true\r\n *\r\n * object === other;\r\n * // => false\r\n */\r\n function isEqual(value, other) {\r\n return baseIsEqual(value, other);\r\n }\r\n\r\n /**\r\n * Checks if `value` is a finite primitive number.\r\n *\r\n * **Note:** This method is based on\r\n * [`Number.isFinite`](https://mdn.io/Number/isFinite).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a finite number, else `false`.\r\n * @example\r\n *\r\n * _.isFinite(3);\r\n * // => true\r\n *\r\n * _.isFinite(Number.MIN_VALUE);\r\n * // => true\r\n *\r\n * _.isFinite(Infinity);\r\n * // => false\r\n *\r\n * _.isFinite('3');\r\n * // => false\r\n */\r\n function isFinite(value) {\r\n return typeof value == 'number' && nativeIsFinite(value);\r\n }\r\n\r\n /**\r\n * Checks if `value` is classified as a `Function` object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\r\n * @example\r\n *\r\n * _.isFunction(_);\r\n * // => true\r\n *\r\n * _.isFunction(/abc/);\r\n * // => false\r\n */\r\n function isFunction(value) {\r\n if (!isObject(value)) {\r\n return false;\r\n }\r\n // The use of `Object#toString` avoids issues with the `typeof` operator\r\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\r\n var tag = baseGetTag(value);\r\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\r\n }\r\n\r\n /**\r\n * Checks if `value` is a valid array-like length.\r\n *\r\n * **Note:** This method is loosely based on\r\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\r\n * @example\r\n *\r\n * _.isLength(3);\r\n * // => true\r\n *\r\n * _.isLength(Number.MIN_VALUE);\r\n * // => false\r\n *\r\n * _.isLength(Infinity);\r\n * // => false\r\n *\r\n * _.isLength('3');\r\n * // => false\r\n */\r\n function isLength(value) {\r\n return typeof value == 'number' &&\r\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\r\n }\r\n\r\n /**\r\n * Checks if `value` is the\r\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\r\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\r\n * @example\r\n *\r\n * _.isObject({});\r\n * // => true\r\n *\r\n * _.isObject([1, 2, 3]);\r\n * // => true\r\n *\r\n * _.isObject(_.noop);\r\n * // => true\r\n *\r\n * _.isObject(null);\r\n * // => false\r\n */\r\n function isObject(value) {\r\n var type = typeof value;\r\n return value != null && (type == 'object' || type == 'function');\r\n }\r\n\r\n /**\r\n * Checks if `value` is object-like. A value is object-like if it's not `null`\r\n * and has a `typeof` result of \"object\".\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\r\n * @example\r\n *\r\n * _.isObjectLike({});\r\n * // => true\r\n *\r\n * _.isObjectLike([1, 2, 3]);\r\n * // => true\r\n *\r\n * _.isObjectLike(_.noop);\r\n * // => false\r\n *\r\n * _.isObjectLike(null);\r\n * // => false\r\n */\r\n function isObjectLike(value) {\r\n return value != null && typeof value == 'object';\r\n }\r\n\r\n /**\r\n * Checks if `value` is classified as a `Map` object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.3.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\r\n * @example\r\n *\r\n * _.isMap(new Map);\r\n * // => true\r\n *\r\n * _.isMap(new WeakMap);\r\n * // => false\r\n */\r\n var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\r\n\r\n /**\r\n * Checks if `value` is `NaN`.\r\n *\r\n * **Note:** This method is based on\r\n * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as\r\n * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for\r\n * `undefined` and other non-number values.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\r\n * @example\r\n *\r\n * _.isNaN(NaN);\r\n * // => true\r\n *\r\n * _.isNaN(new Number(NaN));\r\n * // => true\r\n *\r\n * isNaN(undefined);\r\n * // => true\r\n *\r\n * _.isNaN(undefined);\r\n * // => false\r\n */\r\n function isNaN(value) {\r\n // An `NaN` primitive is the only value that is not equal to itself.\r\n // Perform the `toStringTag` check first to avoid errors with some\r\n // ActiveX objects in IE.\r\n return isNumber(value) && value != +value;\r\n }\r\n\r\n /**\r\n * Checks if `value` is `null`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is `null`, else `false`.\r\n * @example\r\n *\r\n * _.isNull(null);\r\n * // => true\r\n *\r\n * _.isNull(void 0);\r\n * // => false\r\n */\r\n function isNull(value) {\r\n return value === null;\r\n }\r\n\r\n /**\r\n * Checks if `value` is classified as a `Number` primitive or object.\r\n *\r\n * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are\r\n * classified as numbers, use the `_.isFinite` method.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a number, else `false`.\r\n * @example\r\n *\r\n * _.isNumber(3);\r\n * // => true\r\n *\r\n * _.isNumber(Number.MIN_VALUE);\r\n * // => true\r\n *\r\n * _.isNumber(Infinity);\r\n * // => true\r\n *\r\n * _.isNumber('3');\r\n * // => false\r\n */\r\n function isNumber(value) {\r\n return typeof value == 'number' ||\r\n (isObjectLike(value) && baseGetTag(value) == numberTag);\r\n }\r\n\r\n /**\r\n * Checks if `value` is a plain object, that is, an object created by the\r\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.8.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\r\n * @example\r\n *\r\n * function Foo() {\r\n * this.a = 1;\r\n * }\r\n *\r\n * _.isPlainObject(new Foo);\r\n * // => false\r\n *\r\n * _.isPlainObject([1, 2, 3]);\r\n * // => false\r\n *\r\n * _.isPlainObject({ 'x': 0, 'y': 0 });\r\n * // => true\r\n *\r\n * _.isPlainObject(Object.create(null));\r\n * // => true\r\n */\r\n function isPlainObject(value) {\r\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\r\n return false;\r\n }\r\n var proto = getPrototype(value);\r\n if (proto === null) {\r\n return true;\r\n }\r\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\r\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\r\n funcToString.call(Ctor) == objectCtorString;\r\n }\r\n\r\n /**\r\n * Checks if `value` is classified as a `RegExp` object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.1.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\r\n * @example\r\n *\r\n * _.isRegExp(/abc/);\r\n * // => true\r\n *\r\n * _.isRegExp('/abc/');\r\n * // => false\r\n */\r\n var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp;\r\n\r\n /**\r\n * Checks if `value` is classified as a `Set` object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.3.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\r\n * @example\r\n *\r\n * _.isSet(new Set);\r\n * // => true\r\n *\r\n * _.isSet(new WeakSet);\r\n * // => false\r\n */\r\n var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\r\n\r\n /**\r\n * Checks if `value` is classified as a `String` primitive or object.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\r\n * @example\r\n *\r\n * _.isString('abc');\r\n * // => true\r\n *\r\n * _.isString(1);\r\n * // => false\r\n */\r\n function isString(value) {\r\n return typeof value == 'string' ||\r\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\r\n }\r\n\r\n /**\r\n * Checks if `value` is classified as a `Symbol` primitive or object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\r\n * @example\r\n *\r\n * _.isSymbol(Symbol.iterator);\r\n * // => true\r\n *\r\n * _.isSymbol('abc');\r\n * // => false\r\n */\r\n function isSymbol(value) {\r\n return typeof value == 'symbol' ||\r\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\r\n }\r\n\r\n /**\r\n * Checks if `value` is classified as a typed array.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\r\n * @example\r\n *\r\n * _.isTypedArray(new Uint8Array);\r\n * // => true\r\n *\r\n * _.isTypedArray([]);\r\n * // => false\r\n */\r\n var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\r\n\r\n /**\r\n * Checks if `value` is `undefined`.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Lang\r\n * @param {*} value The value to check.\r\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\r\n * @example\r\n *\r\n * _.isUndefined(void 0);\r\n * // => true\r\n *\r\n * _.isUndefined(null);\r\n * // => false\r\n */\r\n function isUndefined(value) {\r\n return value === undefined;\r\n }\r\n\r\n /**\r\n * Converts `value` to an array.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Lang\r\n * @param {*} value The value to convert.\r\n * @returns {Array} Returns the converted array.\r\n * @example\r\n *\r\n * _.toArray({ 'a': 1, 'b': 2 });\r\n * // => [1, 2]\r\n *\r\n * _.toArray('abc');\r\n * // => ['a', 'b', 'c']\r\n *\r\n * _.toArray(1);\r\n * // => []\r\n *\r\n * _.toArray(null);\r\n * // => []\r\n */\r\n function toArray(value) {\r\n if (!value) {\r\n return [];\r\n }\r\n if (isArrayLike(value)) {\r\n return isString(value) ? stringToArray(value) : copyArray(value);\r\n }\r\n if (symIterator && value[symIterator]) {\r\n return iteratorToArray(value[symIterator]());\r\n }\r\n var tag = getTag(value),\r\n func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values);\r\n\r\n return func(value);\r\n }\r\n\r\n /**\r\n * Converts `value` to a finite number.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.12.0\r\n * @category Lang\r\n * @param {*} value The value to convert.\r\n * @returns {number} Returns the converted number.\r\n * @example\r\n *\r\n * _.toFinite(3.2);\r\n * // => 3.2\r\n *\r\n * _.toFinite(Number.MIN_VALUE);\r\n * // => 5e-324\r\n *\r\n * _.toFinite(Infinity);\r\n * // => 1.7976931348623157e+308\r\n *\r\n * _.toFinite('3.2');\r\n * // => 3.2\r\n */\r\n function toFinite(value) {\r\n if (!value) {\r\n return value === 0 ? value : 0;\r\n }\r\n value = toNumber(value);\r\n if (value === INFINITY || value === -INFINITY) {\r\n var sign = (value < 0 ? -1 : 1);\r\n return sign * MAX_INTEGER;\r\n }\r\n return value === value ? value : 0;\r\n }\r\n\r\n /**\r\n * Converts `value` to an integer.\r\n *\r\n * **Note:** This method is loosely based on\r\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to convert.\r\n * @returns {number} Returns the converted integer.\r\n * @example\r\n *\r\n * _.toInteger(3.2);\r\n * // => 3\r\n *\r\n * _.toInteger(Number.MIN_VALUE);\r\n * // => 0\r\n *\r\n * _.toInteger(Infinity);\r\n * // => 1.7976931348623157e+308\r\n *\r\n * _.toInteger('3.2');\r\n * // => 3\r\n */\r\n function toInteger(value) {\r\n var result = toFinite(value),\r\n remainder = result % 1;\r\n\r\n return result === result ? (remainder ? result - remainder : result) : 0;\r\n }\r\n\r\n /**\r\n * Converts `value` to a number.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to process.\r\n * @returns {number} Returns the number.\r\n * @example\r\n *\r\n * _.toNumber(3.2);\r\n * // => 3.2\r\n *\r\n * _.toNumber(Number.MIN_VALUE);\r\n * // => 5e-324\r\n *\r\n * _.toNumber(Infinity);\r\n * // => Infinity\r\n *\r\n * _.toNumber('3.2');\r\n * // => 3.2\r\n */\r\n function toNumber(value) {\r\n if (typeof value == 'number') {\r\n return value;\r\n }\r\n if (isSymbol(value)) {\r\n return NAN;\r\n }\r\n if (isObject(value)) {\r\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\r\n value = isObject(other) ? (other + '') : other;\r\n }\r\n if (typeof value != 'string') {\r\n return value === 0 ? value : +value;\r\n }\r\n value = value.replace(reTrim, '');\r\n var isBinary = reIsBinary.test(value);\r\n return (isBinary || reIsOctal.test(value))\r\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\r\n : (reIsBadHex.test(value) ? NAN : +value);\r\n }\r\n\r\n /**\r\n * Converts `value` to a plain object flattening inherited enumerable string\r\n * keyed properties of `value` to own properties of the plain object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Lang\r\n * @param {*} value The value to convert.\r\n * @returns {Object} Returns the converted plain object.\r\n * @example\r\n *\r\n * function Foo() {\r\n * this.b = 2;\r\n * }\r\n *\r\n * Foo.prototype.c = 3;\r\n *\r\n * _.assign({ 'a': 1 }, new Foo);\r\n * // => { 'a': 1, 'b': 2 }\r\n *\r\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\r\n * // => { 'a': 1, 'b': 2, 'c': 3 }\r\n */\r\n function toPlainObject(value) {\r\n return copyObject(value, keysIn(value));\r\n }\r\n\r\n /**\r\n * Converts `value` to a string. An empty string is returned for `null`\r\n * and `undefined` values. The sign of `-0` is preserved.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Lang\r\n * @param {*} value The value to convert.\r\n * @returns {string} Returns the converted string.\r\n * @example\r\n *\r\n * _.toString(null);\r\n * // => ''\r\n *\r\n * _.toString(-0);\r\n * // => '-0'\r\n *\r\n * _.toString([1, 2, 3]);\r\n * // => '1,2,3'\r\n */\r\n function toString(value) {\r\n return value == null ? '' : baseToString(value);\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * This method is like `_.assign` except that it iterates over own and\r\n * inherited source properties.\r\n *\r\n * **Note:** This method mutates `object`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @alias extend\r\n * @category Object\r\n * @param {Object} object The destination object.\r\n * @param {...Object} [sources] The source objects.\r\n * @returns {Object} Returns `object`.\r\n * @see _.assign\r\n * @example\r\n *\r\n * function Foo() {\r\n * this.a = 1;\r\n * }\r\n *\r\n * function Bar() {\r\n * this.c = 3;\r\n * }\r\n *\r\n * Foo.prototype.b = 2;\r\n * Bar.prototype.d = 4;\r\n *\r\n * _.assignIn({ 'a': 0 }, new Foo, new Bar);\r\n * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }\r\n */\r\n var assignIn = createAssigner(function(object, source) {\r\n copyObject(source, keysIn(source), object);\r\n });\r\n\r\n /**\r\n * Creates an object that inherits from the `prototype` object. If a\r\n * `properties` object is given, its own enumerable string keyed properties\r\n * are assigned to the created object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 2.3.0\r\n * @category Object\r\n * @param {Object} prototype The object to inherit from.\r\n * @param {Object} [properties] The properties to assign to the object.\r\n * @returns {Object} Returns the new object.\r\n * @example\r\n *\r\n * function Shape() {\r\n * this.x = 0;\r\n * this.y = 0;\r\n * }\r\n *\r\n * function Circle() {\r\n * Shape.call(this);\r\n * }\r\n *\r\n * Circle.prototype = _.create(Shape.prototype, {\r\n * 'constructor': Circle\r\n * });\r\n *\r\n * var circle = new Circle;\r\n * circle instanceof Circle;\r\n * // => true\r\n *\r\n * circle instanceof Shape;\r\n * // => true\r\n */\r\n function create(prototype, properties) {\r\n var result = baseCreate(prototype);\r\n return properties == null ? result : baseAssign(result, properties);\r\n }\r\n\r\n /**\r\n * Assigns own and inherited enumerable string keyed properties of source\r\n * objects to the destination object for all destination properties that\r\n * resolve to `undefined`. Source objects are applied from left to right.\r\n * Once a property is set, additional values of the same property are ignored.\r\n *\r\n * **Note:** This method mutates `object`.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Object\r\n * @param {Object} object The destination object.\r\n * @param {...Object} [sources] The source objects.\r\n * @returns {Object} Returns `object`.\r\n * @see _.defaultsDeep\r\n * @example\r\n *\r\n * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\r\n * // => { 'a': 1, 'b': 2 }\r\n */\r\n var defaults = baseRest(function(object, sources) {\r\n object = Object(object);\r\n\r\n var index = -1;\r\n var length = sources.length;\r\n var guard = length > 2 ? sources[2] : undefined;\r\n\r\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\r\n length = 1;\r\n }\r\n\r\n while (++index < length) {\r\n var source = sources[index];\r\n var props = keysIn(source);\r\n var propsIndex = -1;\r\n var propsLength = props.length;\r\n\r\n while (++propsIndex < propsLength) {\r\n var key = props[propsIndex];\r\n var value = object[key];\r\n\r\n if (value === undefined ||\r\n (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) {\r\n object[key] = source[key];\r\n }\r\n }\r\n }\r\n\r\n return object;\r\n });\r\n\r\n /**\r\n * This method is like `_.defaults` except that it recursively assigns\r\n * default properties.\r\n *\r\n * **Note:** This method mutates `object`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.10.0\r\n * @category Object\r\n * @param {Object} object The destination object.\r\n * @param {...Object} [sources] The source objects.\r\n * @returns {Object} Returns `object`.\r\n * @see _.defaults\r\n * @example\r\n *\r\n * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } });\r\n * // => { 'a': { 'b': 2, 'c': 3 } }\r\n */\r\n var defaultsDeep = baseRest(function(args) {\r\n args.push(undefined, customDefaultsMerge);\r\n return apply(mergeWith, undefined, args);\r\n });\r\n\r\n /**\r\n * This method is like `_.find` except that it returns the key of the first\r\n * element `predicate` returns truthy for instead of the element itself.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 1.1.0\r\n * @category Object\r\n * @param {Object} object The object to inspect.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @returns {string|undefined} Returns the key of the matched element,\r\n * else `undefined`.\r\n * @example\r\n *\r\n * var users = {\r\n * 'barney': { 'age': 36, 'active': true },\r\n * 'fred': { 'age': 40, 'active': false },\r\n * 'pebbles': { 'age': 1, 'active': true }\r\n * };\r\n *\r\n * _.findKey(users, function(o) { return o.age < 40; });\r\n * // => 'barney' (iteration order is not guaranteed)\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.findKey(users, { 'age': 1, 'active': true });\r\n * // => 'pebbles'\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.findKey(users, ['active', false]);\r\n * // => 'fred'\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.findKey(users, 'active');\r\n * // => 'barney'\r\n */\r\n function findKey(object, predicate) {\r\n return baseFindKey(object, baseIteratee(predicate, 3), baseForOwn);\r\n }\r\n\r\n /**\r\n * This method is like `_.findKey` except that it iterates over elements of\r\n * a collection in the opposite order.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 2.0.0\r\n * @category Object\r\n * @param {Object} object The object to inspect.\r\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\r\n * @returns {string|undefined} Returns the key of the matched element,\r\n * else `undefined`.\r\n * @example\r\n *\r\n * var users = {\r\n * 'barney': { 'age': 36, 'active': true },\r\n * 'fred': { 'age': 40, 'active': false },\r\n * 'pebbles': { 'age': 1, 'active': true }\r\n * };\r\n *\r\n * _.findLastKey(users, function(o) { return o.age < 40; });\r\n * // => returns 'pebbles' assuming `_.findKey` returns 'barney'\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.findLastKey(users, { 'age': 36, 'active': true });\r\n * // => 'barney'\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.findLastKey(users, ['active', false]);\r\n * // => 'fred'\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.findLastKey(users, 'active');\r\n * // => 'pebbles'\r\n */\r\n function findLastKey(object, predicate) {\r\n return baseFindKey(object, baseIteratee(predicate, 3), baseForOwnRight);\r\n }\r\n\r\n /**\r\n * Gets the value at `path` of `object`. If the resolved value is\r\n * `undefined`, the `defaultValue` is returned in its place.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.7.0\r\n * @category Object\r\n * @param {Object} object The object to query.\r\n * @param {Array|string} path The path of the property to get.\r\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\r\n * @returns {*} Returns the resolved value.\r\n * @example\r\n *\r\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\r\n *\r\n * _.get(object, 'a[0].b.c');\r\n * // => 3\r\n *\r\n * _.get(object, ['a', '0', 'b', 'c']);\r\n * // => 3\r\n *\r\n * _.get(object, 'a.b.c', 'default');\r\n * // => 'default'\r\n */\r\n function get(object, path, defaultValue) {\r\n var result = object == null ? undefined : baseGet(object, path);\r\n return result === undefined ? defaultValue : result;\r\n }\r\n\r\n /**\r\n * Checks if `path` is a direct property of `object`.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Object\r\n * @param {Object} object The object to query.\r\n * @param {Array|string} path The path to check.\r\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\r\n * @example\r\n *\r\n * var object = { 'a': { 'b': 2 } };\r\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\r\n *\r\n * _.has(object, 'a');\r\n * // => true\r\n *\r\n * _.has(object, 'a.b');\r\n * // => true\r\n *\r\n * _.has(object, ['a', 'b']);\r\n * // => true\r\n *\r\n * _.has(other, 'a');\r\n * // => false\r\n */\r\n function has(object, path) {\r\n return object != null && hasPath(object, path, baseHas);\r\n }\r\n\r\n /**\r\n * Checks if `path` is a direct or inherited property of `object`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Object\r\n * @param {Object} object The object to query.\r\n * @param {Array|string} path The path to check.\r\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\r\n * @example\r\n *\r\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\r\n *\r\n * _.hasIn(object, 'a');\r\n * // => true\r\n *\r\n * _.hasIn(object, 'a.b');\r\n * // => true\r\n *\r\n * _.hasIn(object, ['a', 'b']);\r\n * // => true\r\n *\r\n * _.hasIn(object, 'b');\r\n * // => false\r\n */\r\n function hasIn(object, path) {\r\n return object != null && hasPath(object, path, baseHasIn);\r\n }\r\n\r\n /**\r\n * Creates an object composed of the inverted keys and values of `object`.\r\n * If `object` contains duplicate values, subsequent values overwrite\r\n * property assignments of previous values.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.7.0\r\n * @category Object\r\n * @param {Object} object The object to invert.\r\n * @returns {Object} Returns the new inverted object.\r\n * @example\r\n *\r\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\r\n *\r\n * _.invert(object);\r\n * // => { '1': 'c', '2': 'b' }\r\n */\r\n var invert = createInverter(function(result, value, key) {\r\n if (value != null &&\r\n typeof value.toString != 'function') {\r\n value = nativeObjectToString.call(value);\r\n }\r\n\r\n result[value] = key;\r\n }, constant(identity));\r\n\r\n /**\r\n * This method is like `_.invert` except that the inverted object is generated\r\n * from the results of running each element of `object` thru `iteratee`. The\r\n * corresponding inverted value of each inverted key is an array of keys\r\n * responsible for generating the inverted value. The iteratee is invoked\r\n * with one argument: (value).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.1.0\r\n * @category Object\r\n * @param {Object} object The object to invert.\r\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\r\n * @returns {Object} Returns the new inverted object.\r\n * @example\r\n *\r\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\r\n *\r\n * _.invertBy(object);\r\n * // => { '1': ['a', 'c'], '2': ['b'] }\r\n *\r\n * _.invertBy(object, function(value) {\r\n * return 'group' + value;\r\n * });\r\n * // => { 'group1': ['a', 'c'], 'group2': ['b'] }\r\n */\r\n var invertBy = createInverter(function(result, value, key) {\r\n if (value != null &&\r\n typeof value.toString != 'function') {\r\n value = nativeObjectToString.call(value);\r\n }\r\n\r\n if (hasOwnProperty.call(result, value)) {\r\n result[value].push(key);\r\n } else {\r\n result[value] = [key];\r\n }\r\n }, baseIteratee);\r\n\r\n /**\r\n * Creates an array of the own enumerable property names of `object`.\r\n *\r\n * **Note:** Non-object values are coerced to objects. See the\r\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\r\n * for more details.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Object\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of property names.\r\n * @example\r\n *\r\n * function Foo() {\r\n * this.a = 1;\r\n * this.b = 2;\r\n * }\r\n *\r\n * Foo.prototype.c = 3;\r\n *\r\n * _.keys(new Foo);\r\n * // => ['a', 'b'] (iteration order is not guaranteed)\r\n *\r\n * _.keys('hi');\r\n * // => ['0', '1']\r\n */\r\n function keys(object) {\r\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\r\n }\r\n\r\n /**\r\n * Creates an array of the own and inherited enumerable property names of `object`.\r\n *\r\n * **Note:** Non-object values are coerced to objects.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Object\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of property names.\r\n * @example\r\n *\r\n * function Foo() {\r\n * this.a = 1;\r\n * this.b = 2;\r\n * }\r\n *\r\n * Foo.prototype.c = 3;\r\n *\r\n * _.keysIn(new Foo);\r\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\r\n */\r\n function keysIn(object) {\r\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\r\n }\r\n\r\n /**\r\n * This method is like `_.assign` except that it recursively merges own and\r\n * inherited enumerable string keyed properties of source objects into the\r\n * destination object. Source properties that resolve to `undefined` are\r\n * skipped if a destination value exists. Array and plain object properties\r\n * are merged recursively. Other objects and value types are overridden by\r\n * assignment. Source objects are applied from left to right. Subsequent\r\n * sources overwrite property assignments of previous sources.\r\n *\r\n * **Note:** This method mutates `object`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.5.0\r\n * @category Object\r\n * @param {Object} object The destination object.\r\n * @param {...Object} [sources] The source objects.\r\n * @returns {Object} Returns `object`.\r\n * @example\r\n *\r\n * var object = {\r\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\r\n * };\r\n *\r\n * var other = {\r\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\r\n * };\r\n *\r\n * _.merge(object, other);\r\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\r\n */\r\n var merge = createAssigner(function(object, source, srcIndex) {\r\n baseMerge(object, source, srcIndex);\r\n });\r\n\r\n /**\r\n * This method is like `_.merge` except that it accepts `customizer` which\r\n * is invoked to produce the merged values of the destination and source\r\n * properties. If `customizer` returns `undefined`, merging is handled by the\r\n * method instead. The `customizer` is invoked with six arguments:\r\n * (objValue, srcValue, key, object, source, stack).\r\n *\r\n * **Note:** This method mutates `object`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Object\r\n * @param {Object} object The destination object.\r\n * @param {...Object} sources The source objects.\r\n * @param {Function} customizer The function to customize assigned values.\r\n * @returns {Object} Returns `object`.\r\n * @example\r\n *\r\n * function customizer(objValue, srcValue) {\r\n * if (_.isArray(objValue)) {\r\n * return objValue.concat(srcValue);\r\n * }\r\n * }\r\n *\r\n * var object = { 'a': [1], 'b': [2] };\r\n * var other = { 'a': [3], 'b': [4] };\r\n *\r\n * _.mergeWith(object, other, customizer);\r\n * // => { 'a': [1, 3], 'b': [2, 4] }\r\n */\r\n var mergeWith = createAssigner(function(object, source, srcIndex, customizer) {\r\n baseMerge(object, source, srcIndex, customizer);\r\n });\r\n\r\n /**\r\n * The opposite of `_.pick`; this method creates an object composed of the\r\n * own and inherited enumerable property paths of `object` that are not omitted.\r\n *\r\n * **Note:** This method is considerably slower than `_.pick`.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Object\r\n * @param {Object} object The source object.\r\n * @param {...(string|string[])} [paths] The property paths to omit.\r\n * @returns {Object} Returns the new object.\r\n * @example\r\n *\r\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\r\n *\r\n * _.omit(object, ['a', 'c']);\r\n * // => { 'b': '2' }\r\n */\r\n var omit = flatRest(function(object, paths) {\r\n var result = {};\r\n if (object == null) {\r\n return result;\r\n }\r\n var isDeep = false;\r\n paths = arrayMap(paths, function(path) {\r\n path = castPath(path, object);\r\n isDeep || (isDeep = path.length > 1);\r\n return path;\r\n });\r\n copyObject(object, getAllKeysIn(object), result);\r\n if (isDeep) {\r\n result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);\r\n }\r\n var length = paths.length;\r\n while (length--) {\r\n baseUnset(result, paths[length]);\r\n }\r\n return result;\r\n });\r\n\r\n /**\r\n * The opposite of `_.pickBy`; this method creates an object composed of\r\n * the own and inherited enumerable string keyed properties of `object` that\r\n * `predicate` doesn't return truthy for. The predicate is invoked with two\r\n * arguments: (value, key).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Object\r\n * @param {Object} object The source object.\r\n * @param {Function} [predicate=_.identity] The function invoked per property.\r\n * @returns {Object} Returns the new object.\r\n * @example\r\n *\r\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\r\n *\r\n * _.omitBy(object, _.isNumber);\r\n * // => { 'b': '2' }\r\n */\r\n function omitBy(object, predicate) {\r\n return pickBy(object, negate(baseIteratee(predicate)));\r\n }\r\n\r\n /**\r\n * Creates an object composed of the picked `object` properties.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Object\r\n * @param {Object} object The source object.\r\n * @param {...(string|string[])} [paths] The property paths to pick.\r\n * @returns {Object} Returns the new object.\r\n * @example\r\n *\r\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\r\n *\r\n * _.pick(object, ['a', 'c']);\r\n * // => { 'a': 1, 'c': 3 }\r\n */\r\n var pick = flatRest(function(object, paths) {\r\n return object == null ? {} : basePick(object, paths);\r\n });\r\n\r\n /**\r\n * Creates an object composed of the `object` properties `predicate` returns\r\n * truthy for. The predicate is invoked with two arguments: (value, key).\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Object\r\n * @param {Object} object The source object.\r\n * @param {Function} [predicate=_.identity] The function invoked per property.\r\n * @returns {Object} Returns the new object.\r\n * @example\r\n *\r\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\r\n *\r\n * _.pickBy(object, _.isNumber);\r\n * // => { 'a': 1, 'c': 3 }\r\n */\r\n function pickBy(object, predicate) {\r\n if (object == null) {\r\n return {};\r\n }\r\n var props = arrayMap(getAllKeysIn(object), function(prop) {\r\n return [prop];\r\n });\r\n predicate = baseIteratee(predicate);\r\n return basePickBy(object, props, function(value, path) {\r\n return predicate(value, path[0]);\r\n });\r\n }\r\n\r\n /**\r\n * This method is like `_.get` except that if the resolved value is a\r\n * function it's invoked with the `this` binding of its parent object and\r\n * its result is returned.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Object\r\n * @param {Object} object The object to query.\r\n * @param {Array|string} path The path of the property to resolve.\r\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\r\n * @returns {*} Returns the resolved value.\r\n * @example\r\n *\r\n * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] };\r\n *\r\n * _.result(object, 'a[0].b.c1');\r\n * // => 3\r\n *\r\n * _.result(object, 'a[0].b.c2');\r\n * // => 4\r\n *\r\n * _.result(object, 'a[0].b.c3', 'default');\r\n * // => 'default'\r\n *\r\n * _.result(object, 'a[0].b.c3', _.constant('default'));\r\n * // => 'default'\r\n */\r\n function result(object, path, defaultValue) {\r\n path = castPath(path, object);\r\n\r\n var index = -1,\r\n length = path.length;\r\n\r\n // Ensure the loop is entered when path is empty.\r\n if (!length) {\r\n length = 1;\r\n object = undefined;\r\n }\r\n while (++index < length) {\r\n var value = object == null ? undefined : object[toKey(path[index])];\r\n if (value === undefined) {\r\n index = length;\r\n value = defaultValue;\r\n }\r\n object = isFunction(value) ? value.call(object) : value;\r\n }\r\n return object;\r\n }\r\n\r\n /**\r\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\r\n * it's created. Arrays are created for missing index properties while objects\r\n * are created for all other missing properties. Use `_.setWith` to customize\r\n * `path` creation.\r\n *\r\n * **Note:** This method mutates `object`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.7.0\r\n * @category Object\r\n * @param {Object} object The object to modify.\r\n * @param {Array|string} path The path of the property to set.\r\n * @param {*} value The value to set.\r\n * @returns {Object} Returns `object`.\r\n * @example\r\n *\r\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\r\n *\r\n * _.set(object, 'a[0].b.c', 4);\r\n * console.log(object.a[0].b.c);\r\n * // => 4\r\n *\r\n * _.set(object, ['x', '0', 'y', 'z'], 5);\r\n * console.log(object.x[0].y.z);\r\n * // => 5\r\n */\r\n function set(object, path, value) {\r\n return object == null ? object : baseSet(object, path, value);\r\n }\r\n\r\n /**\r\n * Creates an array of the own enumerable string keyed property values of `object`.\r\n *\r\n * **Note:** Non-object values are coerced to objects.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Object\r\n * @param {Object} object The object to query.\r\n * @returns {Array} Returns the array of property values.\r\n * @example\r\n *\r\n * function Foo() {\r\n * this.a = 1;\r\n * this.b = 2;\r\n * }\r\n *\r\n * Foo.prototype.c = 3;\r\n *\r\n * _.values(new Foo);\r\n * // => [1, 2] (iteration order is not guaranteed)\r\n *\r\n * _.values('hi');\r\n * // => ['h', 'i']\r\n */\r\n function values(object) {\r\n return object == null ? [] : baseValues(object, keys(object));\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Clamps `number` within the inclusive `lower` and `upper` bounds.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.0.0\r\n * @category Number\r\n * @param {number} number The number to clamp.\r\n * @param {number} [lower] The lower bound.\r\n * @param {number} upper The upper bound.\r\n * @returns {number} Returns the clamped number.\r\n * @example\r\n *\r\n * _.clamp(-10, -5, 5);\r\n * // => -5\r\n *\r\n * _.clamp(10, -5, 5);\r\n * // => 5\r\n */\r\n function clamp(number, lower, upper) {\r\n if (upper === undefined) {\r\n upper = lower;\r\n lower = undefined;\r\n }\r\n if (upper !== undefined) {\r\n upper = toNumber(upper);\r\n upper = upper === upper ? upper : 0;\r\n }\r\n if (lower !== undefined) {\r\n lower = toNumber(lower);\r\n lower = lower === lower ? lower : 0;\r\n }\r\n return baseClamp(toNumber(number), lower, upper);\r\n }\r\n\r\n /**\r\n * Produces a random number between the inclusive `lower` and `upper` bounds.\r\n * If only one argument is provided a number between `0` and the given number\r\n * is returned. If `floating` is `true`, or either `lower` or `upper` are\r\n * floats, a floating-point number is returned instead of an integer.\r\n *\r\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\r\n * floating-point values which can produce unexpected results.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 0.7.0\r\n * @category Number\r\n * @param {number} [lower=0] The lower bound.\r\n * @param {number} [upper=1] The upper bound.\r\n * @param {boolean} [floating] Specify returning a floating-point number.\r\n * @returns {number} Returns the random number.\r\n * @example\r\n *\r\n * _.random(0, 5);\r\n * // => an integer between 0 and 5\r\n *\r\n * _.random(5);\r\n * // => also an integer between 0 and 5\r\n *\r\n * _.random(5, true);\r\n * // => a floating-point number between 0 and 5\r\n *\r\n * _.random(1.2, 5.2);\r\n * // => a floating-point number between 1.2 and 5.2\r\n */\r\n function random(lower, upper, floating) {\r\n if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) {\r\n upper = floating = undefined;\r\n }\r\n if (floating === undefined) {\r\n if (typeof upper == 'boolean') {\r\n floating = upper;\r\n upper = undefined;\r\n }\r\n else if (typeof lower == 'boolean') {\r\n floating = lower;\r\n lower = undefined;\r\n }\r\n }\r\n if (lower === undefined && upper === undefined) {\r\n lower = 0;\r\n upper = 1;\r\n }\r\n else {\r\n lower = toFinite(lower);\r\n if (upper === undefined) {\r\n upper = lower;\r\n lower = 0;\r\n } else {\r\n upper = toFinite(upper);\r\n }\r\n }\r\n if (lower > upper) {\r\n var temp = lower;\r\n lower = upper;\r\n upper = temp;\r\n }\r\n if (floating || lower % 1 || upper % 1) {\r\n var rand = nativeRandom();\r\n return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper);\r\n }\r\n return baseRandom(lower, upper);\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Converts the characters \"&\", \"<\", \">\", '\"', and \"'\" in `string` to their\r\n * corresponding HTML entities.\r\n *\r\n * **Note:** No other characters are escaped. To escape additional\r\n * characters use a third-party library like [_he_](https://mths.be/he).\r\n *\r\n * Though the \">\" character is escaped for symmetry, characters like\r\n * \">\" and \"/\" don't need escaping in HTML and have no special meaning\r\n * unless they're part of a tag or unquoted attribute value. See\r\n * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands)\r\n * (under \"semi-related fun fact\") for more details.\r\n *\r\n * When working with HTML you should always\r\n * [quote attribute values](http://wonko.com/post/html-escaping) to reduce\r\n * XSS vectors.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category String\r\n * @param {string} [string=''] The string to escape.\r\n * @returns {string} Returns the escaped string.\r\n * @example\r\n *\r\n * _.escape('fred, barney, & pebbles');\r\n * // => 'fred, barney, & pebbles'\r\n */\r\n function escape(string) {\r\n string = toString(string);\r\n return (string && reHasUnescapedHtml.test(string))\r\n ? string.replace(reUnescapedHtml, escapeHtmlChar)\r\n : string;\r\n }\r\n\r\n /**\r\n * Removes leading and trailing whitespace or specified characters from `string`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category String\r\n * @param {string} [string=''] The string to trim.\r\n * @param {string} [chars=whitespace] The characters to trim.\r\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\r\n * @returns {string} Returns the trimmed string.\r\n * @example\r\n *\r\n * _.trim(' abc ');\r\n * // => 'abc'\r\n *\r\n * _.trim('-_-abc-_-', '_-');\r\n * // => 'abc'\r\n *\r\n * _.map([' foo ', ' bar '], _.trim);\r\n * // => ['foo', 'bar']\r\n */\r\n function trim(string, chars, guard) {\r\n string = toString(string);\r\n if (string && (guard || chars === undefined)) {\r\n return string.replace(reTrim, '');\r\n }\r\n if (!string || !(chars = baseToString(chars))) {\r\n return string;\r\n }\r\n var strSymbols = stringToArray(string),\r\n chrSymbols = stringToArray(chars),\r\n start = charsStartIndex(strSymbols, chrSymbols),\r\n end = charsEndIndex(strSymbols, chrSymbols) + 1;\r\n\r\n return castSlice(strSymbols, start, end).join('');\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Creates a function that returns `value`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 2.4.0\r\n * @category Util\r\n * @param {*} value The value to return from the new function.\r\n * @returns {Function} Returns the new constant function.\r\n * @example\r\n *\r\n * var objects = _.times(2, _.constant({ 'a': 1 }));\r\n *\r\n * console.log(objects);\r\n * // => [{ 'a': 1 }, { 'a': 1 }]\r\n *\r\n * console.log(objects[0] === objects[1]);\r\n * // => true\r\n */\r\n function constant(value) {\r\n return function() {\r\n return value;\r\n };\r\n }\r\n\r\n /**\r\n * This method returns the first argument it receives.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Util\r\n * @param {*} value Any value.\r\n * @returns {*} Returns `value`.\r\n * @example\r\n *\r\n * var object = { 'a': 1 };\r\n *\r\n * console.log(_.identity(object) === object);\r\n * // => true\r\n */\r\n function identity(value) {\r\n return value;\r\n }\r\n\r\n /**\r\n * Creates a function that invokes `func` with the arguments of the created\r\n * function. If `func` is a property name, the created function returns the\r\n * property value for a given element. If `func` is an array or object, the\r\n * created function returns `true` for elements that contain the equivalent\r\n * source properties, otherwise it returns `false`.\r\n *\r\n * @static\r\n * @since 4.0.0\r\n * @memberOf _\r\n * @category Util\r\n * @param {*} [func=_.identity] The value to convert to a callback.\r\n * @returns {Function} Returns the callback.\r\n * @example\r\n *\r\n * var users = [\r\n * { 'user': 'barney', 'age': 36, 'active': true },\r\n * { 'user': 'fred', 'age': 40, 'active': false }\r\n * ];\r\n *\r\n * // The `_.matches` iteratee shorthand.\r\n * _.filter(users, _.iteratee({ 'user': 'barney', 'active': true }));\r\n * // => [{ 'user': 'barney', 'age': 36, 'active': true }]\r\n *\r\n * // The `_.matchesProperty` iteratee shorthand.\r\n * _.filter(users, _.iteratee(['user', 'fred']));\r\n * // => [{ 'user': 'fred', 'age': 40 }]\r\n *\r\n * // The `_.property` iteratee shorthand.\r\n * _.map(users, _.iteratee('user'));\r\n * // => ['barney', 'fred']\r\n *\r\n * // Create custom iteratee shorthands.\r\n * _.iteratee = _.wrap(_.iteratee, function(iteratee, func) {\r\n * return !_.isRegExp(func) ? iteratee(func) : function(string) {\r\n * return func.test(string);\r\n * };\r\n * });\r\n *\r\n * _.filter(['abc', 'def'], /ef/);\r\n * // => ['def']\r\n */\r\n function iteratee(func) {\r\n return baseIteratee(typeof func == 'function' ? func : baseClone(func, CLONE_DEEP_FLAG));\r\n }\r\n\r\n /**\r\n * Creates a function that performs a partial deep comparison between a given\r\n * object and `source`, returning `true` if the given object has equivalent\r\n * property values, else `false`.\r\n *\r\n * **Note:** The created function is equivalent to `_.isMatch` with `source`\r\n * partially applied.\r\n *\r\n * Partial comparisons will match empty array and empty object `source`\r\n * values against any array or object value, respectively. See `_.isEqual`\r\n * for a list of supported value comparisons.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 3.0.0\r\n * @category Util\r\n * @param {Object} source The object of property values to match.\r\n * @returns {Function} Returns the new spec function.\r\n * @example\r\n *\r\n * var objects = [\r\n * { 'a': 1, 'b': 2, 'c': 3 },\r\n * { 'a': 4, 'b': 5, 'c': 6 }\r\n * ];\r\n *\r\n * _.filter(objects, _.matches({ 'a': 4, 'c': 6 }));\r\n * // => [{ 'a': 4, 'b': 5, 'c': 6 }]\r\n */\r\n function matches(source) {\r\n return baseMatches(baseClone(source, CLONE_DEEP_FLAG));\r\n }\r\n\r\n /**\r\n * Adds all own enumerable string keyed function properties of a source\r\n * object to the destination object. If `object` is a function, then methods\r\n * are added to its prototype as well.\r\n *\r\n * **Note:** Use `_.runInContext` to create a pristine `lodash` function to\r\n * avoid conflicts caused by modifying the original.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Util\r\n * @param {Function|Object} [object=lodash] The destination object.\r\n * @param {Object} source The object of functions to add.\r\n * @param {Object} [options={}] The options object.\r\n * @param {boolean} [options.chain=true] Specify whether mixins are chainable.\r\n * @returns {Function|Object} Returns `object`.\r\n * @example\r\n *\r\n * function vowels(string) {\r\n * return _.filter(string, function(v) {\r\n * return /[aeiou]/i.test(v);\r\n * });\r\n * }\r\n *\r\n * _.mixin({ 'vowels': vowels });\r\n * _.vowels('fred');\r\n * // => ['e']\r\n *\r\n * _('fred').vowels().value();\r\n * // => ['e']\r\n *\r\n * _.mixin({ 'vowels': vowels }, { 'chain': false });\r\n * _('fred').vowels();\r\n * // => ['e']\r\n */\r\n function mixin(object, source, options) {\r\n var props = keys(source),\r\n methodNames = baseFunctions(source, props);\r\n\r\n if (options == null &&\r\n !(isObject(source) && (methodNames.length || !props.length))) {\r\n options = source;\r\n source = object;\r\n object = this;\r\n methodNames = baseFunctions(source, keys(source));\r\n }\r\n var chain = !(isObject(options) && 'chain' in options) || !!options.chain,\r\n isFunc = isFunction(object);\r\n\r\n arrayEach(methodNames, function(methodName) {\r\n var func = source[methodName];\r\n object[methodName] = func;\r\n if (isFunc) {\r\n object.prototype[methodName] = function() {\r\n var chainAll = this.__chain__;\r\n if (chain || chainAll) {\r\n var result = object(this.__wrapped__),\r\n actions = result.__actions__ = copyArray(this.__actions__);\r\n\r\n actions.push({ 'func': func, 'args': arguments, 'thisArg': object });\r\n result.__chain__ = chainAll;\r\n return result;\r\n }\r\n return func.apply(object, arrayPush([this.value()], arguments));\r\n };\r\n }\r\n });\r\n\r\n return object;\r\n }\r\n\r\n /**\r\n * Reverts the `_` variable to its previous value and returns a reference to\r\n * the `lodash` function.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Util\r\n * @returns {Function} Returns the `lodash` function.\r\n * @example\r\n *\r\n * var lodash = _.noConflict();\r\n */\r\n function noConflict() {\r\n if (root._ === this) {\r\n root._ = oldDash;\r\n }\r\n return this;\r\n }\r\n\r\n /**\r\n * This method returns `undefined`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 2.3.0\r\n * @category Util\r\n * @example\r\n *\r\n * _.times(2, _.noop);\r\n * // => [undefined, undefined]\r\n */\r\n function noop() {\r\n // No operation performed.\r\n }\r\n\r\n /**\r\n * Creates a function that returns the value at `path` of a given object.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 2.4.0\r\n * @category Util\r\n * @param {Array|string} path The path of the property to get.\r\n * @returns {Function} Returns the new accessor function.\r\n * @example\r\n *\r\n * var objects = [\r\n * { 'a': { 'b': 2 } },\r\n * { 'a': { 'b': 1 } }\r\n * ];\r\n *\r\n * _.map(objects, _.property('a.b'));\r\n * // => [2, 1]\r\n *\r\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\r\n * // => [1, 2]\r\n */\r\n function property(path) {\r\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\r\n }\r\n\r\n /**\r\n * Creates an array of numbers (positive and/or negative) progressing from\r\n * `start` up to, but not including, `end`. A step of `-1` is used if a negative\r\n * `start` is specified without an `end` or `step`. If `end` is not specified,\r\n * it's set to `start` with `start` then set to `0`.\r\n *\r\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\r\n * floating-point values which can produce unexpected results.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Util\r\n * @param {number} [start=0] The start of the range.\r\n * @param {number} end The end of the range.\r\n * @param {number} [step=1] The value to increment or decrement by.\r\n * @returns {Array} Returns the range of numbers.\r\n * @see _.inRange, _.rangeRight\r\n * @example\r\n *\r\n * _.range(4);\r\n * // => [0, 1, 2, 3]\r\n *\r\n * _.range(-4);\r\n * // => [0, -1, -2, -3]\r\n *\r\n * _.range(1, 5);\r\n * // => [1, 2, 3, 4]\r\n *\r\n * _.range(0, 20, 5);\r\n * // => [0, 5, 10, 15]\r\n *\r\n * _.range(0, -4, -1);\r\n * // => [0, -1, -2, -3]\r\n *\r\n * _.range(1, 4, 0);\r\n * // => [1, 1, 1]\r\n *\r\n * _.range(0);\r\n * // => []\r\n */\r\n var range = createRange();\r\n\r\n /**\r\n * This method returns a new empty array.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.13.0\r\n * @category Util\r\n * @returns {Array} Returns the new empty array.\r\n * @example\r\n *\r\n * var arrays = _.times(2, _.stubArray);\r\n *\r\n * console.log(arrays);\r\n * // => [[], []]\r\n *\r\n * console.log(arrays[0] === arrays[1]);\r\n * // => false\r\n */\r\n function stubArray() {\r\n return [];\r\n }\r\n\r\n /**\r\n * This method returns `false`.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @since 4.13.0\r\n * @category Util\r\n * @returns {boolean} Returns `false`.\r\n * @example\r\n *\r\n * _.times(2, _.stubFalse);\r\n * // => [false, false]\r\n */\r\n function stubFalse() {\r\n return false;\r\n }\r\n\r\n /**\r\n * Generates a unique ID. If `prefix` is given, the ID is appended to it.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Util\r\n * @param {string} [prefix=''] The value to prefix the ID with.\r\n * @returns {string} Returns the unique ID.\r\n * @example\r\n *\r\n * _.uniqueId('contact_');\r\n * // => 'contact_104'\r\n *\r\n * _.uniqueId();\r\n * // => '105'\r\n */\r\n function uniqueId(prefix) {\r\n var id = ++idCounter;\r\n return toString(prefix) + id;\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * Computes the maximum value of `array`. If `array` is empty or falsey,\r\n * `undefined` is returned.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Math\r\n * @param {Array} array The array to iterate over.\r\n * @returns {*} Returns the maximum value.\r\n * @example\r\n *\r\n * _.max([4, 2, 8, 6]);\r\n * // => 8\r\n *\r\n * _.max([]);\r\n * // => undefined\r\n */\r\n function max(array) {\r\n return (array && array.length)\r\n ? baseExtremum(array, identity, baseGt)\r\n : undefined;\r\n }\r\n\r\n /**\r\n * Computes the minimum value of `array`. If `array` is empty or falsey,\r\n * `undefined` is returned.\r\n *\r\n * @static\r\n * @since 0.1.0\r\n * @memberOf _\r\n * @category Math\r\n * @param {Array} array The array to iterate over.\r\n * @returns {*} Returns the minimum value.\r\n * @example\r\n *\r\n * _.min([4, 2, 8, 6]);\r\n * // => 2\r\n *\r\n * _.min([]);\r\n * // => undefined\r\n */\r\n function min(array) {\r\n return (array && array.length)\r\n ? baseExtremum(array, identity, baseLt)\r\n : undefined;\r\n }\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n // Add methods that return wrapped values in chain sequences.\r\n lodash.after = after;\r\n lodash.assignIn = assignIn;\r\n lodash.before = before;\r\n lodash.bind = bind;\r\n lodash.chain = chain;\r\n lodash.compact = compact;\r\n lodash.concat = concat;\r\n lodash.countBy = countBy;\r\n lodash.create = create;\r\n lodash.debounce = debounce;\r\n lodash.defaults = defaults;\r\n lodash.defaultsDeep = defaultsDeep;\r\n lodash.defer = defer;\r\n lodash.delay = delay;\r\n lodash.difference = difference;\r\n lodash.drop = drop;\r\n lodash.filter = filter;\r\n lodash.flatten = flatten;\r\n lodash.flattenDeep = flattenDeep;\r\n lodash.groupBy = groupBy;\r\n lodash.initial = initial;\r\n lodash.intersection = intersection;\r\n lodash.invert = invert;\r\n lodash.invertBy = invertBy;\r\n lodash.iteratee = iteratee;\r\n lodash.keys = keys;\r\n lodash.map = map;\r\n lodash.matches = matches;\r\n lodash.merge = merge;\r\n lodash.mixin = mixin;\r\n lodash.negate = negate;\r\n lodash.omit = omit;\r\n lodash.omitBy = omitBy;\r\n lodash.once = once;\r\n lodash.pick = pick;\r\n lodash.range = range;\r\n lodash.reject = reject;\r\n lodash.rest = rest;\r\n lodash.set = set;\r\n lodash.slice = slice;\r\n lodash.sortBy = sortBy;\r\n lodash.take = take;\r\n lodash.takeRight = takeRight;\r\n lodash.tap = tap;\r\n lodash.throttle = throttle;\r\n lodash.thru = thru;\r\n lodash.toArray = toArray;\r\n lodash.union = union;\r\n lodash.uniq = uniq;\r\n lodash.uniqBy = uniqBy;\r\n lodash.unzip = unzip;\r\n lodash.values = values;\r\n lodash.without = without;\r\n lodash.zip = zip;\r\n lodash.zipObject = zipObject;\r\n\r\n // Add aliases.\r\n lodash.extend = assignIn;\r\n\r\n // Add methods to `lodash.prototype`.\r\n mixin(lodash, lodash);\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n // Add methods that return unwrapped values in chain sequences.\r\n lodash.clamp = clamp;\r\n lodash.clone = clone;\r\n lodash.cloneDeep = cloneDeep;\r\n lodash.escape = escape;\r\n lodash.every = every;\r\n lodash.find = find;\r\n lodash.findIndex = findIndex;\r\n lodash.findKey = findKey;\r\n lodash.findLastIndex = findLastIndex;\r\n lodash.findLastKey = findLastKey;\r\n lodash.forEach = forEach;\r\n lodash.get = get;\r\n lodash.has = has;\r\n lodash.head = head;\r\n lodash.identity = identity;\r\n lodash.indexOf = indexOf;\r\n lodash.isArguments = isArguments;\r\n lodash.isArray = isArray;\r\n lodash.isArrayLike = isArrayLike;\r\n lodash.isBoolean = isBoolean;\r\n lodash.isDate = isDate;\r\n lodash.isEmpty = isEmpty;\r\n lodash.isEqual = isEqual;\r\n lodash.isFinite = isFinite;\r\n lodash.isFunction = isFunction;\r\n lodash.isNaN = isNaN;\r\n lodash.isNull = isNull;\r\n lodash.isNumber = isNumber;\r\n lodash.isObject = isObject;\r\n lodash.isPlainObject = isPlainObject;\r\n lodash.isRegExp = isRegExp;\r\n lodash.isString = isString;\r\n lodash.isUndefined = isUndefined;\r\n lodash.last = last;\r\n lodash.max = max;\r\n lodash.min = min;\r\n lodash.noConflict = noConflict;\r\n lodash.noop = noop;\r\n lodash.random = random;\r\n lodash.reduce = reduce;\r\n lodash.result = result;\r\n lodash.size = size;\r\n lodash.some = some;\r\n lodash.trim = trim;\r\n lodash.uniqueId = uniqueId;\r\n\r\n // Add aliases.\r\n lodash.each = forEach;\r\n lodash.first = head;\r\n\r\n mixin(lodash, (function() {\r\n var source = {};\r\n baseForOwn(lodash, function(func, methodName) {\r\n if (!hasOwnProperty.call(lodash.prototype, methodName)) {\r\n source[methodName] = func;\r\n }\r\n });\r\n return source;\r\n }()), { 'chain': false });\r\n\r\n /*------------------------------------------------------------------------*/\r\n\r\n /**\r\n * The semantic version number.\r\n *\r\n * @static\r\n * @memberOf _\r\n * @type {string}\r\n */\r\n lodash.VERSION = VERSION;\r\n\r\n // Add `LazyWrapper` methods for `_.drop` and `_.take` variants.\r\n arrayEach(['drop', 'take'], function(methodName, index) {\r\n LazyWrapper.prototype[methodName] = function(n) {\r\n n = n === undefined ? 1 : nativeMax(toInteger(n), 0);\r\n\r\n var result = (this.__filtered__ && !index)\r\n ? new LazyWrapper(this)\r\n : this.clone();\r\n\r\n if (result.__filtered__) {\r\n result.__takeCount__ = nativeMin(n, result.__takeCount__);\r\n } else {\r\n result.__views__.push({\r\n 'size': nativeMin(n, MAX_ARRAY_LENGTH),\r\n 'type': methodName + (result.__dir__ < 0 ? 'Right' : '')\r\n });\r\n }\r\n return result;\r\n };\r\n\r\n LazyWrapper.prototype[methodName + 'Right'] = function(n) {\r\n return this.reverse()[methodName](n).reverse();\r\n };\r\n });\r\n\r\n // Add `LazyWrapper` methods that accept an `iteratee` value.\r\n arrayEach(['filter', 'map', 'takeWhile'], function(methodName, index) {\r\n var type = index + 1,\r\n isFilter = type == LAZY_FILTER_FLAG || type == LAZY_WHILE_FLAG;\r\n\r\n LazyWrapper.prototype[methodName] = function(iteratee) {\r\n var result = this.clone();\r\n result.__iteratees__.push({\r\n 'iteratee': getIteratee(iteratee, 3),\r\n 'type': type\r\n });\r\n result.__filtered__ = result.__filtered__ || isFilter;\r\n return result;\r\n };\r\n });\r\n\r\n // Add `LazyWrapper` methods for `_.head` and `_.last`.\r\n arrayEach(['head', 'last'], function(methodName, index) {\r\n var takeName = 'take' + (index ? 'Right' : '');\r\n\r\n LazyWrapper.prototype[methodName] = function() {\r\n return this[takeName](1).value()[0];\r\n };\r\n });\r\n\r\n // Add `LazyWrapper` methods for `_.initial` and `_.tail`.\r\n arrayEach(['initial', 'tail'], function(methodName, index) {\r\n var dropName = 'drop' + (index ? '' : 'Right');\r\n\r\n LazyWrapper.prototype[methodName] = function() {\r\n return this.__filtered__ ? new LazyWrapper(this) : this[dropName](1);\r\n };\r\n });\r\n\r\n LazyWrapper.prototype.compact = function() {\r\n return this.filter(identity);\r\n };\r\n\r\n LazyWrapper.prototype.find = function(predicate) {\r\n return this.filter(predicate).head();\r\n };\r\n\r\n LazyWrapper.prototype.findLast = function(predicate) {\r\n return this.reverse().find(predicate);\r\n };\r\n\r\n LazyWrapper.prototype.invokeMap = baseRest(function(path, args) {\r\n if (typeof path == 'function') {\r\n return new LazyWrapper(this);\r\n }\r\n return this.map(function(value) {\r\n return baseInvoke(value, path, args);\r\n });\r\n });\r\n\r\n LazyWrapper.prototype.reject = function(predicate) {\r\n return this.filter(negate(getIteratee(predicate)));\r\n };\r\n\r\n LazyWrapper.prototype.slice = function(start, end) {\r\n start = toInteger(start);\r\n\r\n var result = this;\r\n if (result.__filtered__ && (start > 0 || end < 0)) {\r\n return new LazyWrapper(result);\r\n }\r\n if (start < 0) {\r\n result = result.takeRight(-start);\r\n } else if (start) {\r\n result = result.drop(start);\r\n }\r\n if (end !== undefined) {\r\n end = toInteger(end);\r\n result = end < 0 ? result.dropRight(-end) : result.take(end - start);\r\n }\r\n return result;\r\n };\r\n\r\n LazyWrapper.prototype.takeRightWhile = function(predicate) {\r\n return this.reverse().takeWhile(predicate).reverse();\r\n };\r\n\r\n LazyWrapper.prototype.toArray = function() {\r\n return this.take(MAX_ARRAY_LENGTH);\r\n };\r\n\r\n // Add `LazyWrapper` methods to `lodash.prototype`.\r\n baseForOwn(LazyWrapper.prototype, function(func, methodName) {\r\n var checkIteratee = /^(?:filter|find|map|reject)|While$/.test(methodName),\r\n isTaker = /^(?:head|last)$/.test(methodName),\r\n lodashFunc = lodash[isTaker ? ('take' + (methodName == 'last' ? 'Right' : '')) : methodName],\r\n retUnwrapped = isTaker || /^find/.test(methodName);\r\n\r\n if (!lodashFunc) {\r\n return;\r\n }\r\n lodash.prototype[methodName] = function() {\r\n var value = this.__wrapped__,\r\n args = isTaker ? [1] : arguments,\r\n isLazy = value instanceof LazyWrapper,\r\n iteratee = args[0],\r\n useLazy = isLazy || isArray(value);\r\n\r\n var interceptor = function(value) {\r\n var result = lodashFunc.apply(lodash, arrayPush([value], args));\r\n return (isTaker && chainAll) ? result[0] : result;\r\n };\r\n\r\n if (useLazy && checkIteratee && typeof iteratee == 'function' && iteratee.length != 1) {\r\n // Avoid lazy use if the iteratee has a \"length\" value other than `1`.\r\n isLazy = useLazy = false;\r\n }\r\n var chainAll = this.__chain__,\r\n isHybrid = !!this.__actions__.length,\r\n isUnwrapped = retUnwrapped && !chainAll,\r\n onlyLazy = isLazy && !isHybrid;\r\n\r\n if (!retUnwrapped && useLazy) {\r\n value = onlyLazy ? value : new LazyWrapper(this);\r\n var result = func.apply(value, args);\r\n result.__actions__.push({ 'func': thru, 'args': [interceptor], 'thisArg': undefined });\r\n return new LodashWrapper(result, chainAll);\r\n }\r\n if (isUnwrapped && onlyLazy) {\r\n return func.apply(this, args);\r\n }\r\n result = this.thru(interceptor);\r\n return isUnwrapped ? (isTaker ? result.value()[0] : result.value()) : result;\r\n };\r\n });\r\n\r\n // Add `Array` methods to `lodash.prototype`.\r\n arrayEach(['pop', 'push', 'shift', 'sort', 'splice', 'unshift'], function(methodName) {\r\n var func = arrayProto[methodName],\r\n chainName = /^(?:push|sort|unshift)$/.test(methodName) ? 'tap' : 'thru',\r\n retUnwrapped = /^(?:pop|shift)$/.test(methodName);\r\n\r\n lodash.prototype[methodName] = function() {\r\n var args = arguments;\r\n if (retUnwrapped && !this.__chain__) {\r\n var value = this.value();\r\n return func.apply(isArray(value) ? value : [], args);\r\n }\r\n return this[chainName](function(value) {\r\n return func.apply(isArray(value) ? value : [], args);\r\n });\r\n };\r\n });\r\n\r\n // Map minified method names to their real names.\r\n baseForOwn(LazyWrapper.prototype, function(func, methodName) {\r\n var lodashFunc = lodash[methodName];\r\n if (lodashFunc) {\r\n var key = (lodashFunc.name + ''),\r\n names = realNames[key] || (realNames[key] = []);\r\n\r\n names.push({ 'name': methodName, 'func': lodashFunc });\r\n }\r\n });\r\n\r\n realNames[createHybrid(undefined, WRAP_BIND_KEY_FLAG).name] = [{\r\n 'name': 'wrapper',\r\n 'func': undefined\r\n }];\r\n\r\n // Add methods to `LazyWrapper`.\r\n LazyWrapper.prototype.clone = lazyClone;\r\n LazyWrapper.prototype.reverse = lazyReverse;\r\n LazyWrapper.prototype.value = lazyValue;\r\n\r\n // Add lazy aliases.\r\n lodash.prototype.first = lodash.prototype.head;\r\n\r\n if (symIterator) {\r\n lodash.prototype[symIterator] = wrapperToIterator;\r\n }\r\n\r\n /*--------------------------------------------------------------------------*/\r\n\r\n // Some AMD build optimizers, like r.js, check for condition patterns like:\r\n if (typeof define == 'function' && typeof define.amd == 'object' && define.amd) {\r\n // Expose Lodash on the global object to prevent errors when Lodash is\r\n // loaded by a script tag in the presence of an AMD loader.\r\n // See http://requirejs.org/docs/errors.html#mismatch for more details.\r\n // Use `_.noConflict` to remove Lodash from the global object.\r\n root._ = lodash;\r\n\r\n // Define as an anonymous module so, through path mapping, it can be\r\n // referenced as the \"underscore\" module.\r\n define(function() {\r\n return lodash;\r\n });\r\n }\r\n // Check for `exports` after `define` in case a build optimizer adds it.\r\n else if (freeModule) {\r\n // Export for Node.js.\r\n (freeModule.exports = lodash)._ = lodash;\r\n // Export for CommonJS support.\r\n freeExports._ = lodash;\r\n }\r\n else {\r\n // Export to the global object.\r\n root._ = lodash;\r\n }\r\n}.call(this));\r\n"},function(e,t,n){(function(e,t){function n(){u=!1;for(var e=l.slice(0),t=l.length=0;t(2147483646-e.charAt(n).charCodeAt(0)+"A".charCodeAt(0))/26)return 0;return t},int2Abc:function(e){var t=["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"],n=e,i="";if(0===e)return"";for(;0!==n;){var r=n%26;0===r&&(r=26),i=t[r-1]+i,n=(n-r)/26}return i}}),_.each(["first","initial","last","rest","compact","flatten","without","union","intersection","difference","zip","unzip","object","indexOf","lastIndexOf","sortedIndex","range","take","takeRight","uniqBy"],function(e){BI[e]=p(e)}),_.each(["findIndex","findLastIndex"],function(e){BI[e]=d(e)}),_.extend(BI,{makeArray:function(e,t){for(var n=[],i=0;ir[0]?a=["y",1]:e>=i[0]&&e<=r[0]&&(e==i[0]&&(tr[1]?a=["m",1]:t==r[1]&&n>r[2]&&(a=["d",1]))),a},checkDateLegal:function(e){var t=e.match(/\d+/g),n=0|t[0],i=0|t[1],r=0|t[2];if(t.length<=1)return!0;if(t.length<=2)return 1<=i&&i<=12;var a=BI.Date._MD.slice(0);return a[1]=BI.isLeapYear(n)?29:28,1<=i&&i<=12&&r<=a[i-1]},parseDateTime:function(e,t){var n=BI.getDate(),i=0,r=0,a=1,o=e.split(/\W+/);"%y%x"!=t.toLowerCase()&&"%y%x%d"!=t.toLowerCase()||(o[0]=e.substring(0,4),o[1]=e.substring(4,6),o[2]=e.substring(6,8));for(var s=t.match(/%./g),l=0,u=0,c=0,h=0,p=0,l=0;l>>2]>>>24-a%4*8&255;t[i+a>>>2]|=o<<24-(i+a)%4*8}else if(65535>>2]=n[a>>>2];else t.push.apply(t,n);return this.sigBytes+=r,this},clamp:function(){var e=this.words,t=this.sigBytes;e[t>>>2]&=4294967295<<32-t%4*8,e.length=c.ceil(t/4)},clone:function(){var e=n.clone.call(this);return e.words=this.words.slice(0),e},random:function(e){for(var t=[],n=0;n>>2]>>>24-r%4*8&255;i.push((a>>>4).toString(16)),i.push((15&a).toString(16))}return i.join("")},parse:function(e){for(var t=e.length,n=[],i=0;i>>3]|=parseInt(e.substr(i,2),16)<<24-i%8*4;return new h.init(n,t/2)}},a=i.Latin1={stringify:function(e){for(var t=e.words,n=e.sigBytes,i=[],r=0;r>>2]>>>24-r%4*8&255;i.push(String.fromCharCode(a))}return i.join("")},parse:function(e){for(var t=e.length,n=[],i=0;i>>2]|=(255&e.charCodeAt(i))<<24-i%4*8;return new h.init(n,t)}},o=i.Utf8={stringify:function(e){try{return decodeURIComponent(escape(a.stringify(e)))}catch(t){throw new Error("Malformed UTF-8 data")}},parse:function(e){return a.parse(unescape(encodeURIComponent(e)))}},s=t.BufferedBlockAlgorithm=n.extend({reset:function(){this._data=new h.init,this._nDataBytes=0},_append:function(e){"string"==typeof e&&(e=o.parse(e)),this._data.concat(e),this._nDataBytes+=e.sigBytes},_process:function(e){var t=this._data,n=t.words,i=t.sigBytes,r=this.blockSize,a=i/(4*r),o=(a=e?c.ceil(a):c.max((0|a)-this._minBufferSize,0))*r,s=c.min(4*o,i);if(o){for(var l=0;l>>2]>>>24-a%4*8&255)<<16|(t[a+1>>>2]>>>24-(a+1)%4*8&255)<<8|t[a+2>>>2]>>>24-(a+2)%4*8&255,s=0;s<4&&a+.75*s>>6*(3-s)&63));var l=i.charAt(64);if(l)for(;r.length%4;)r.push(l);return r.join("")},parse:function(e){var t,n=e.length,i=this._map,r=i.charAt(64);!r||-1!=(t=e.indexOf(r))&&(n=t);for(var a,o,s=[],l=0,u=0;u>>6-u%4*2,s[l>>>2]|=(a|o)<<24-l%4*8,l++)}return p.create(s,l)},_map:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="},function(c){var e=b,t=e.lib,n=t.WordArray,i=t.Hasher,r=e.algo,N=[];!function(){for(var e=0;e<64;e++)N[e]=4294967296*c.abs(c.sin(e+1))|0}();var a=r.MD5=i.extend({_doReset:function(){this._hash=new n.init([1732584193,4023233417,2562383102,271733878])},_doProcessBlock:function(e,t){for(var n=0;n<16;n++){var i=t+n,r=e[i];e[i]=16711935&(r<<8|r>>>24)|4278255360&(r<<24|r>>>8)}var a=this._hash.words,o=e[t+0],s=e[t+1],l=e[t+2],u=e[t+3],c=e[t+4],h=e[t+5],p=e[t+6],d=e[t+7],f=e[t+8],g=e[t+9],m=e[t+10],I=e[t+11],B=e[t+12],_=e[t+13],E=e[t+14],b=e[t+15],y=V(y=a[0],C=a[1],T=a[2],v=a[3],o,7,N[0]),v=V(v,y,C,T,s,12,N[1]),T=V(T,v,y,C,l,17,N[2]),C=V(C,T,v,y,u,22,N[3]);y=V(y,C,T,v,c,7,N[4]),v=V(v,y,C,T,h,12,N[5]),T=V(T,v,y,C,p,17,N[6]),C=V(C,T,v,y,d,22,N[7]),y=V(y,C,T,v,f,7,N[8]),v=V(v,y,C,T,g,12,N[9]),T=V(T,v,y,C,m,17,N[10]),C=V(C,T,v,y,I,22,N[11]),y=V(y,C,T,v,B,7,N[12]),v=V(v,y,C,T,_,12,N[13]),T=V(T,v,y,C,E,17,N[14]),y=S(y,C=V(C,T,v,y,b,22,N[15]),T,v,s,5,N[16]),v=S(v,y,C,T,p,9,N[17]),T=S(T,v,y,C,I,14,N[18]),C=S(C,T,v,y,o,20,N[19]),y=S(y,C,T,v,h,5,N[20]),v=S(v,y,C,T,m,9,N[21]),T=S(T,v,y,C,b,14,N[22]),C=S(C,T,v,y,c,20,N[23]),y=S(y,C,T,v,g,5,N[24]),v=S(v,y,C,T,E,9,N[25]),T=S(T,v,y,C,u,14,N[26]),C=S(C,T,v,y,f,20,N[27]),y=S(y,C,T,v,_,5,N[28]),v=S(v,y,C,T,l,9,N[29]),T=S(T,v,y,C,d,14,N[30]),y=x(y,C=S(C,T,v,y,B,20,N[31]),T,v,h,4,N[32]),v=x(v,y,C,T,f,11,N[33]),T=x(T,v,y,C,I,16,N[34]),C=x(C,T,v,y,E,23,N[35]),y=x(y,C,T,v,s,4,N[36]),v=x(v,y,C,T,c,11,N[37]),T=x(T,v,y,C,d,16,N[38]),C=x(C,T,v,y,m,23,N[39]),y=x(y,C,T,v,_,4,N[40]),v=x(v,y,C,T,o,11,N[41]),T=x(T,v,y,C,u,16,N[42]),C=x(C,T,v,y,p,23,N[43]),y=x(y,C,T,v,g,4,N[44]),v=x(v,y,C,T,B,11,N[45]),T=x(T,v,y,C,b,16,N[46]),y=w(y,C=x(C,T,v,y,l,23,N[47]),T,v,o,6,N[48]),v=w(v,y,C,T,d,10,N[49]),T=w(T,v,y,C,E,15,N[50]),C=w(C,T,v,y,h,21,N[51]),y=w(y,C,T,v,B,6,N[52]),v=w(v,y,C,T,u,10,N[53]),T=w(T,v,y,C,m,15,N[54]),C=w(C,T,v,y,s,21,N[55]),y=w(y,C,T,v,f,6,N[56]),v=w(v,y,C,T,b,10,N[57]),T=w(T,v,y,C,p,15,N[58]),C=w(C,T,v,y,_,21,N[59]),y=w(y,C,T,v,c,6,N[60]),v=w(v,y,C,T,I,10,N[61]),T=w(T,v,y,C,l,15,N[62]),C=w(C,T,v,y,g,21,N[63]),a[0]=a[0]+y|0,a[1]=a[1]+C|0,a[2]=a[2]+T|0,a[3]=a[3]+v|0},_doFinalize:function(){var e=this._data,t=e.words,n=8*this._nDataBytes,i=8*e.sigBytes;t[i>>>5]|=128<<24-i%32;var r=c.floor(n/4294967296),a=n;t[15+(64+i>>>9<<4)]=16711935&(r<<8|r>>>24)|4278255360&(r<<24|r>>>8),t[14+(64+i>>>9<<4)]=16711935&(a<<8|a>>>24)|4278255360&(a<<24|a>>>8),e.sigBytes=4*(t.length+1),this._process();for(var o=this._hash,s=o.words,l=0;l<4;l++){var u=s[l];s[l]=16711935&(u<<8|u>>>24)|4278255360&(u<<24|u>>>8)}return o},clone:function(){var e=i.clone.call(this);return e._hash=this._hash.clone(),e}});function V(e,t,n,i,r,a,o){var s=e+(t&n|~t&i)+r+o;return(s<>>32-a)+t}function S(e,t,n,i,r,a,o){var s=e+(t&i|n&~i)+r+o;return(s<>>32-a)+t}function x(e,t,n,i,r,a,o){var s=e+(t^n^i)+r+o;return(s<>>32-a)+t}function w(e,t,n,i,r,a,o){var s=e+(n^(t|~i))+r+o;return(s<>>32-a)+t}e.MD5=i._createHelper(a),e.HmacMD5=i._createHmacHelper(a)}(Math),d=(u=b).lib,f=d.Base,g=d.WordArray,m=u.algo,I=m.MD5,B=m.EvpKDF=f.extend({cfg:f.extend({keySize:4,hasher:I,iterations:1}),init:function(e){this.cfg=this.cfg.extend(e)},compute:function(e,t){for(var n=this.cfg,i=n.hasher.create(),r=g.create(),a=r.words,o=n.keySize,s=n.iterations;a.length>>2];e.sigBytes-=t}},m=(t.BlockCipher=s.extend({cfg:s.cfg.extend({mode:d,padding:g}),reset:function(){s.reset.call(this);var e,t=this.cfg,n=t.iv,i=t.mode;this._xformMode==this._ENC_XFORM_MODE?e=i.createEncryptor:(e=i.createDecryptor,this._minBufferSize=1),this._mode=e.call(i,this,n&&n.words)},_doProcessBlock:function(e,t){this._mode.processBlock(e,t)},_doFinalize:function(){var e,t=this.cfg.padding;return this._xformMode==this._ENC_XFORM_MODE?(t.pad(this._data,this.blockSize),e=this._process(!0)):(e=this._process(!0),t.unpad(e)),e},blockSize:4}),t.CipherParams=n.extend({init:function(e){this.mixIn(e)},toString:function(e){return(e||this.formatter).stringify(this)}})),I=(e.format={}).OpenSSL={stringify:function(e){var t=e.ciphertext,n=e.salt;return(n?l.create([1398893684,1701076831]).concat(n).concat(t):t).toString(a)},parse:function(e){var t,n=a.parse(e),i=n.words;return 1398893684==i[0]&&1701076831==i[1]&&(t=l.create(i.slice(2,4)),i.splice(0,4),n.sigBytes-=16),m.create({ciphertext:n,salt:t})}},B=t.SerializableCipher=n.extend({cfg:n.extend({format:I}),encrypt:function(e,t,n,i){i=this.cfg.extend(i);var r=e.createEncryptor(n,i),a=r.finalize(t),o=r.cfg;return m.create({ciphertext:a,key:n,iv:o.iv,algorithm:e,mode:o.mode,padding:o.padding,blockSize:e.blockSize,formatter:i.format})},decrypt:function(e,t,n,i){return i=this.cfg.extend(i),t=this._parse(t,i.format),e.createDecryptor(n,i).finalize(t.ciphertext)},_parse:function(e,t){return"string"==typeof e?t.parse(e,this):e}}),_=(e.kdf={}).OpenSSL={execute:function(e,t,n,i){i=i||l.random(8);var r=o.create({keySize:t+n}).compute(e,i),a=l.create(r.words.slice(t),4*n);return r.sigBytes=4*t,m.create({key:r,iv:a,salt:i})}},E=t.PasswordBasedCipher=B.extend({cfg:B.cfg.extend({kdf:_}),encrypt:function(e,t,n,i){var r=(i=this.cfg.extend(i)).kdf.execute(n,e.keySize,e.ivSize);i.iv=r.iv;var a=B.encrypt.call(this,e,t,r.key,i);return a.mixIn(r),a},decrypt:function(e,t,n,i){i=this.cfg.extend(i),t=this._parse(t,i.format);var r=i.kdf.execute(n,e.keySize,e.ivSize,t.salt);return i.iv=r.iv,B.decrypt.call(this,e,t,r.key,i)}})}(),b.mode.ECB=((E=b.lib.BlockCipherMode.extend()).Encryptor=E.extend({processBlock:function(e,t){this._cipher.encryptBlock(e,t)}}),E.Decryptor=E.extend({processBlock:function(e,t){this._cipher.decryptBlock(e,t)}}),E),function(){var e=b,t=e.lib.BlockCipher,n=e.algo,u=[],c=[],h=[],p=[],d=[],f=[],g=[],m=[],I=[],B=[];!function(){for(var e=[],t=0;t<256;t++)e[t]=t<128?t<<1:t<<1^283;for(var n=0,i=0,t=0;t<256;t++){var r=(r=i^i<<1^i<<2^i<<3^i<<4)>>>8^255&r^99;u[n]=r;var a=e[c[r]=n],o=e[a],s=e[o],l=257*e[r]^16843008*r;h[n]=l<<24|l>>>8,p[n]=l<<16|l>>>16,d[n]=l<<8|l>>>24,f[n]=l;l=16843009*s^65537*o^257*a^16843008*n;g[r]=l<<24|l>>>8,m[r]=l<<16|l>>>16,I[r]=l<<8|l>>>24,B[r]=l,n?(n=a^e[e[e[s^a]]],i^=e[e[i]]):n=i=1}}();var _=[0,1,2,4,8,16,32,64,128,27,54],i=n.AES=t.extend({_doReset:function(){for(var e=this._key,t=e.words,n=e.sigBytes/4,i=4*(1+(this._nRounds=6+n)),r=this._keySchedule=[],a=0;a>>24]<<24|u[l>>>16&255]<<16|u[l>>>8&255]<<8|u[255&l]):(l=u[(l=l<<8|l>>>24)>>>24]<<24|u[l>>>16&255]<<16|u[l>>>8&255]<<8|u[255&l],l^=_[a/n|0]<<24),r[a]=r[a-n]^l)}for(var o=this._invKeySchedule=[],s=0;s>>24]]^m[u[l>>>16&255]]^I[u[l>>>8&255]]^B[u[255&l]]}},encryptBlock:function(e,t){this._doCryptBlock(e,t,this._keySchedule,h,p,d,f,u)},decryptBlock:function(e,t){var n=e[t+1];e[t+1]=e[t+3],e[t+3]=n,this._doCryptBlock(e,t,this._invKeySchedule,g,m,I,B,c);n=e[t+1];e[t+1]=e[t+3],e[t+3]=n},_doCryptBlock:function(e,t,n,i,r,a,o,s){for(var l=this._nRounds,u=e[t]^n[0],c=e[t+1]^n[1],h=e[t+2]^n[2],p=e[t+3]^n[3],d=4,f=1;f>>24]^r[c>>>16&255]^a[h>>>8&255]^o[255&p]^n[d++],m=i[c>>>24]^r[h>>>16&255]^a[p>>>8&255]^o[255&u]^n[d++],I=i[h>>>24]^r[p>>>16&255]^a[u>>>8&255]^o[255&c]^n[d++],B=i[p>>>24]^r[u>>>16&255]^a[c>>>8&255]^o[255&h]^n[d++],u=g,c=m,h=I,p=B;g=(s[u>>>24]<<24|s[c>>>16&255]<<16|s[h>>>8&255]<<8|s[255&p])^n[d++],m=(s[c>>>24]<<24|s[h>>>16&255]<<16|s[p>>>8&255]<<8|s[255&u])^n[d++],I=(s[h>>>24]<<24|s[p>>>16&255]<<16|s[u>>>8&255]<<8|s[255&c])^n[d++],B=(s[p>>>24]<<24|s[u>>>16&255]<<16|s[c>>>8&255]<<8|s[255&h])^n[d++];e[t]=g,e[t+1]=m,e[t+2]=I,e[t+3]=B},keySize:8});e.AES=t._createHelper(i)}(),_.extend(BI,{aesEncrypt:function(e,t){return t=b.enc.Utf8.parse(t),b.AES.encrypt(e,t,{mode:b.mode.ECB,padding:b.pad.Pkcs7}).ciphertext.toString(b.enc.Base64)},aesDecrypt:function(e,t){t=b.enc.Utf8.parse(t);var n=b.AES.decrypt(e,t,{mode:b.mode.ECB,padding:b.pad.Pkcs7});return b.enc.Utf8.stringify(n)}})}()},function(e,t){function n(o){return function(e,t,n){var l,i=e[t];i&&i.target==e||((l=e[t]=function(){for(var e,t=l.before,n=arguments,i=t.length;i--;){if(!1===(e=t[i].advice.apply(this,n)))return!1;n=e||n}for(var r=l.method.apply(this,n),a=l.after,o=0,s=a.length;o>6|192):(t+=String.fromCharCode(i>>12|224),t+=String.fromCharCode(i>>6&63|128)),t+=String.fromCharCode(63&i|128))}return t}(e);u>2,a=(3&t)<<4|(n=e.charCodeAt(u++))>>4,o=(15&n)<<2|(i=e.charCodeAt(u++))>>6,s=63&i,isNaN(n)?o=s=64:isNaN(i)&&(s=64),l=l+c.charAt(r)+c.charAt(a)+c.charAt(o)+c.charAt(s);return l},decode:function(e){var t,n,i,r,a,o,s="",l=0;for(e=e.replace(/[^A-Za-z0-9\+\/\=]/g,"");l>4,n=(15&r)<<4|(a=c.indexOf(e.charAt(l++)))>>2,i=(3&a)<<6|(o=c.indexOf(e.charAt(l++))),s+=String.fromCharCode(t),64!=a&&(s+=String.fromCharCode(n)),64!=o&&(s+=String.fromCharCode(i));return s=function(e){for(var t,n,i="",r=0,a=0;r=e?this._binarySearch(n,0,e):this._exponentialSearch(n,e)}}},BI.ScalingCellSizeAndPositionManager=function(e,t,n,i){this._cellSizeAndPositionManager=new BI.CellSizeAndPositionManager(e,t,n),this._maxScrollSize=i||1e7},BI.ScalingCellSizeAndPositionManager.prototype={constructor:BI.ScalingCellSizeAndPositionManager,configure:function(){this._cellSizeAndPositionManager.configure.apply(this._cellSizeAndPositionManager,arguments)},getCellCount:function(){return this._cellSizeAndPositionManager.getCellCount()},getEstimatedCellSize:function(){return this._cellSizeAndPositionManager.getEstimatedCellSize()},getLastMeasuredIndex:function(){return this._cellSizeAndPositionManager.getLastMeasuredIndex()},getOffsetAdjustment:function(e,t){var n=this._cellSizeAndPositionManager.getTotalSize(),i=this.getTotalSize(),r=this._getOffsetPercentage(e,t,i);return Math.round(r*(i-n))},getSizeAndPositionOfCell:function(e){return this._cellSizeAndPositionManager.getSizeAndPositionOfCell(e)},getSizeAndPositionOfLastMeasuredCell:function(){return this._cellSizeAndPositionManager.getSizeAndPositionOfLastMeasuredCell()},getTotalSize:function(){return Math.min(this._maxScrollSize,this._cellSizeAndPositionManager.getTotalSize())},getUpdatedOffsetForIndex:function(e,t,n,i){n=this._safeOffsetToOffset(t,n);var r=this._cellSizeAndPositionManager.getUpdatedOffsetForIndex(e,t,n,i);return this._offsetToSafeOffset(t,r)},getVisibleCellRange:function(e,t){return t=this._safeOffsetToOffset(e,t),this._cellSizeAndPositionManager.getVisibleCellRange(e,t)},resetCell:function(e){this._cellSizeAndPositionManager.resetCell(e)},_getOffsetPercentage:function(e,t,n){return n<=e?0:t/(n-e)},_offsetToSafeOffset:function(e,t){var n=this._cellSizeAndPositionManager.getTotalSize(),i=this.getTotalSize();if(n===i)return t;var r=this._getOffsetPercentage(e,t,n);return Math.round(r*(i-e))},_safeOffsetToOffset:function(e,t){var n=this._cellSizeAndPositionManager.getTotalSize(),i=this.getTotalSize();if(n===i)return t;var r=this._getOffsetPercentage(e,t,i);return Math.round(r*(n-e))}}},function(e,t){var l;l={19969:"DZ",19975:"WM",19988:"QJ",20048:"YL",20056:"SC",20060:"NM",20094:"QG",20127:"QJ",20167:"QC",20193:"YG",20250:"KH",20256:"ZC",20282:"SC",20285:"QJG",20291:"TD",20314:"YD",20315:"BF",20340:"NE",20375:"TD",20389:"YJ",20391:"CZ",20415:"PB",20446:"YS",20447:"SQ",20504:"TC",20608:"KG",20854:"QJ",20857:"ZC",20911:"PF",20985:"AW",21032:"PB",21048:"XQ",21049:"SC",21089:"YS",21119:"JC",21242:"SB",21273:"SC",21305:"YP",21306:"QO",21330:"ZC",21333:"SDC",21345:"QK",21378:"CA",21397:"SC",21414:"XS",21442:"SC",21477:"JG",21480:"TD",21484:"ZS",21494:"YX",21505:"YX",21512:"HG",21523:"XH",21537:"PB",21542:"PF",21549:"KH",21571:"E",21574:"DA",21588:"TD",21589:"O",21618:"ZC",21621:"KHA",21632:"ZJ",21654:"KG",21679:"LKG",21683:"KH",21710:"A",21719:"YH",21734:"WOE",21769:"A",21780:"WN",21804:"XH",21834:"A",21899:"ZD",21903:"RN",21908:"WO",21939:"ZC",21956:"SA",21964:"YA",21970:"TD",22003:"A",22031:"JG",22040:"XS",22060:"ZC",22066:"ZC",22079:"MH",22129:"XJ",22179:"XA",22237:"NJ",22244:"TD",22280:"JQ",22300:"YH",22313:"XW",22331:"YQ",22343:"YJ",22351:"PH",22395:"DC",22412:"TD",22484:"PB",22500:"PB",22534:"ZD",22549:"DH",22561:"PB",22612:"TD",22771:"KQ",22831:"HB",22841:"JG",22855:"QJ",22865:"XQ",23013:"ML",23081:"WM",23487:"SX",23558:"QJ",23561:"YW",23586:"YW",23614:"YW",23615:"SN",23631:"PB",23646:"ZS",23663:"ZT",23673:"YG",23762:"TD",23769:"ZS",23780:"QJ",23884:"QK",24055:"XH",24113:"DC",24162:"ZC",24191:"GA",24273:"QJ",24324:"NL",24377:"TD",24378:"QJ",24439:"PF",24554:"ZS",24683:"TD",24694:"WE",24733:"LK",24925:"TN",25094:"ZG",25100:"XQ",25103:"XH",25153:"PB",25170:"PB",25179:"KG",25203:"PB",25240:"ZS",25282:"FB",25303:"NA",25324:"KG",25341:"ZY",25373:"WZ",25375:"XJ",25384:"A",25457:"A",25528:"SD",25530:"SC",25552:"TD",25774:"ZC",25874:"ZC",26044:"YW",26080:"WM",26292:"PB",26333:"PB",26355:"ZY",26366:"CZ",26397:"ZC",26399:"QJ",26415:"ZS",26451:"SB",26526:"ZC",26552:"JG",26561:"TD",26588:"JG",26597:"CZ",26629:"ZS",26638:"YL",26646:"XQ",26653:"KG",26657:"XJ",26727:"HG",26894:"ZC",26937:"ZS",26946:"ZC",26999:"KJ",27099:"KJ",27449:"YQ",27481:"XS",27542:"ZS",27663:"ZS",27748:"TS",27784:"SC",27788:"ZD",27795:"TD",27812:"O",27850:"PB",27852:"MB",27895:"SL",27898:"PL",27973:"QJ",27981:"KH",27986:"HX",27994:"XJ",28044:"YC",28065:"WG",28177:"SM",28267:"QJ",28291:"KH",28337:"ZQ",28463:"TL",28548:"DC",28601:"TD",28689:"PB",28805:"JG",28820:"QG",28846:"PB",28952:"TD",28975:"ZC",29100:"A",29325:"QJ",29575:"SL",29602:"FB",30010:"TD",30044:"CX",30058:"PF",30091:"YSP",30111:"YN",30229:"XJ",30427:"SC",30465:"SX",30631:"YQ",30655:"QJ",30684:"QJG",30707:"SD",30729:"XH",30796:"LG",30917:"PB",31074:"NM",31085:"JZ",31109:"SC",31181:"ZC",31192:"MLB",31293:"JQ",31400:"YX",31584:"YJ",31896:"ZN",31909:"ZY",31995:"XJ",32321:"PF",32327:"ZY",32418:"HG",32420:"XQ",32421:"HG",32438:"LG",32473:"GJ",32488:"TD",32521:"QJ",32527:"PB",32562:"ZSQ",32564:"JZ",32735:"ZD",32793:"PB",33071:"PF",33098:"XL",33100:"YA",33152:"PB",33261:"CX",33324:"BP",33333:"TD",33406:"YA",33426:"WM",33432:"PB",33445:"JG",33486:"ZN",33493:"TS",33507:"QJ",33540:"QJ",33544:"ZC",33564:"XQ",33617:"YT",33632:"QJ",33636:"XH",33637:"YX",33694:"WG",33705:"PF",33728:"YW",33882:"SR",34067:"WM",34074:"YW",34121:"QJ",34255:"ZC",34259:"XL",34425:"JH",34430:"XH",34485:"KH",34503:"YS",34532:"HG",34552:"XS",34558:"YE",34593:"ZL",34660:"YQ",34892:"XH",34928:"SC",34999:"QJ",35048:"PB",35059:"SC",35098:"ZC",35203:"TQ",35265:"JX",35299:"JX",35782:"SZ",35828:"YS",35830:"E",35843:"TD",35895:"YG",35977:"MH",36158:"JG",36228:"QJ",36426:"XQ",36466:"DC",36710:"CJ",36711:"ZYG",36767:"PB",36866:"SK",36951:"YW",37034:"YX",37063:"XH",37218:"ZC",37325:"ZC",38063:"PB",38079:"TD",38085:"QY",38107:"DC",38116:"TD",38123:"YD",38224:"HG",38241:"XTC",38271:"ZC",38415:"YE",38426:"KH",38461:"YD",38463:"AE",38466:"PB",38477:"XJ",38518:"YT",38551:"WK",38585:"ZC",38704:"XS",38739:"LJ",38761:"GJ",38808:"SQ",39048:"JG",39049:"XJ",39052:"HG",39076:"CZ",39271:"XT",39534:"TD",39552:"TD",39584:"PB",39647:"SB",39730:"LG",39748:"TPB",40109:"ZQ",40479:"ND",40516:"HG",40536:"HG",40583:"QJ",40765:"YQ",40784:"QJ",40840:"YK",40863:"QJG"},_.extend(BI,{makeFirstPY:function(e,t){if(t=t||{},"string"!=typeof e)return""+e;for(var n,i,r=[],a=0,o=e.length;athis.capacity&&this.array.shift()},pop:function(){this.array.pop()},shift:function(){this.array.shift()},unshift:function(e){this.array.unshift(e),this.capacity&&this.array.length>this.capacity&&this.array.pop()},remove:function(e){BI.remove(this.array,e)},splice:function(){this.array.splice.apply(this.array,arguments)},slice:function(){this.array.slice.apply(this.array,arguments)},size:function(){return this.array.length},each:function(e,t){t=t||window;if(null!=(e=e||null)&&"function"==typeof e)for(var n=0;n=this.x&&e<=this.x+this.w&&t>=this.y&&t<=this.y+this.h)},getPosition:function(){var e=[];return e.push(this.x+this.w/2),e.push(this.y+this.h/2),e}}},function(module,exports,__webpack_require__){(function(global){!function(){var _global;function isEmpty(e){return""===e||null===e||e===undefined}function isInvalidDate(e){return"Invalid Date"==e||"NaN"==e}function _eFormat(e,t){return function(e,t){var n=e<0?(e*=-1,"-"):"",i="",r=Math[0c?h=h.substr(1):(h=BI.leftPad(h,c,"0"),d.leftPlus=!1),n=n.replace(/^[0-9]+/,h))),d.num=n,d}function _dealWithLeft(e,t){for(var n,i="",r=e.length-1,a=-1,o=-1,s=t.length-1;0<=s;s--){var l,u=t.charAt(s),c=e.charAt(r);switch(u){case"0":isEmpty(c)&&(c="0"),o=-1,i=c+i,r--;break;case"#":o=s,i=c+i,r--;break;case",":isEmpty(c)||((l=t.match(/,[#0]+/))&&(a=l[0].length-1),i=","+i);break;default:i=u+i}}if(-1":">"," ":" "};BI.htmlEncode=function(e){return BI.isNull(e)?"":BI.replaceAll(e+"",'&|"|<|>|\\s',function(e){return SPECIAL_TAGS[e]?SPECIAL_TAGS[e]:" "})},BI.htmlDecode=function(e){return BI.isNull(e)?"":BI.replaceAll(e+"","&|"|<|>| ",function(e){switch(e){case"&":return"&";case""":return'"';case"<":return"<";case">":return">";case" ":default:return" "}})},BI.cjkEncodeDO=function(e){if(BI.isPlainObject(e)){var n={};return _.each(e,function(e,t){"string"!=typeof e&&(e=BI.jsonEncode(e)),t=BI.cjkEncode(t),n[t]=BI.cjkEncode(e)}),n}return e},BI.jsonEncode=function(e){var t,n=!!{}.hasOwnProperty,i={"\b":"\\b","\t":"\\t","\n":"\\n","\f":"\\f","\r":"\\r",'"':'\\"',"\\":"\\\\"};if(null==e)return"null";if(BI.isArray(e))return function(e){for(var t,n,i=["["],r=e.length,a=0;ae.length)&&e.substr(0,t.length)==t},endWith:function(e,t){return!(null==t||""==t||0===e.length||t.length>e.length)&&e.substring(e.length-t.length)==t},getQuery:function(e,t){var n=new RegExp("(^|&)"+t+"=([^&]*)(&|$)"),i=e.substr(e.indexOf("?")+1).match(n);return i?unescape(i[2]):null},appendQuery:function(e,t){if(!t)return e;var n=e;return-1===n.indexOf("?")&&(n+="?"),!1!==BI.endWith(n,"?")||(n+="&"),_.each(t,function(e,t){"string"==typeof t&&(n+=t+"="+e+"&")}),n=n.substr(0,n.length-1)},replaceAll:function(e,t,n){return BI.isString(e)?e.replace(new RegExp(t,"gm"),n):e},perfectStart:function(e,t){return BI.startWith(e,t)?e:t+e},allIndexOf:function(e,t){if("string"!=typeof t)return[];for(var n=[],i=0;0r;)o(i,n=t[r++])&&(~l(a,n)||a.push(n));return a}},function(e,t,n){var o=n(9),s=n(3),l=n(32);e.exports=n(8)?Object.defineProperties:function(e,t){s(e);for(var n,i=l(t),r=i.length,a=0;a>>0||(o.test(i)?16:10))}:r},function(e,t,n){var r=n(1).parseFloat,a=n(40).trim;e.exports=1/r(n(76)+"-0")!=-Infinity?function parseFloat(t){var n=a(String(t),3),i=r(n);return 0===i&&"-"==n.charAt(0)?-0:i}:r},function(e,t,n){var i=n(24);e.exports=function(e,t){if("number"!=typeof e&&"Number"!=i(e))throw TypeError(t);return+e}},function(e,t,n){var i=n(4),r=Math.floor;e.exports=function(e){return!i(e)&&isFinite(e)&&r(e)===e}},function(e,t){e.exports=Math.log1p||function(e){return-1e-8<(e=+e)&&e<1e-8?e-e*e/2:Math.log(1+e)}},function(e,t,n){"use strict";var i=n(34),r=n(29),a=n(39),o={};n(15)(o,n(5)("iterator"),function(){return this}),e.exports=function(e,t,n){e.prototype=i(o,{next:r(1,n)}),a(e,t+" Iterator")}},function(e,t,n){var o=n(3);e.exports=function(e,t,n,i){try{return i?t(o(n)[0],n[1]):t(n)}catch(a){var r=e["return"];throw r!==undefined&&o(r.call(e)),a}}},function(e,t,n){var i=n(857);e.exports=function(e,t){return new(i(e))(t)}},function(e,t,n){var c=n(19),h=n(10),p=n(46),d=n(6);e.exports=function(e,t,n,i,r){c(t);var a=h(e),o=p(a),s=d(a.length),l=r?s-1:0,u=r?-1:1;if(n<2)for(;;){if(l in o){i=o[l],l+=u;break}if(l+=u,r?l<0:s<=l)throw TypeError("Reduce of empty array with no initial value")}for(;r?0<=l:le;)!function(e){var t,n,i,r=c?e.ok:e.fail,a=e.resolve,o=e.reject,s=e.domain;try{r?(c||(2==h._h&&R(h),h._h=1),!0===r?t=u:(s&&s.enter(),t=r(u),s&&(s.exit(),i=!0)),t===e.promise?o(T("Promise-chain cycle")):(n=k(t))?n.call(t,a,o):a(t)):o(u)}catch(l){s&&!i&&s.exit(),o(l)}}(n[e++]);h._c=[],h._n=!1,t&&!h._h&&M(h)}))},M=function(a){I.call(l,function(){var e,t,n,i=a._v,r=P(a);if(r&&(e=E(function(){x?C.emit("unhandledRejection",i,a):(t=l.onunhandledrejection)?t({promise:a,reason:i}):(n=l.console)&&n.error&&n.error("Unhandled promise rejection",i)}),a._h=x||P(a)?2:1),a._a=undefined,r&&e.e)throw e.v})},P=function(e){return 1!==e._h&&0===(e._a||e._c).length},R=function(t){I.call(l,function(){var e;x?C.emit("rejectionHandled",t):(e=l.onrejectionhandled)&&e({promise:t,reason:t._v})})},H=function(e){var t=this;t._d||(t._d=!0,(t=t._w||t)._v=e,t._s=2,t._a||(t._a=t._c.slice()),D(t,!0))},O=function(n){var i,r=this;if(!r._d){r._d=!0,r=r._w||r;try{if(r===n)throw T("Promise can't be resolved itself");(i=k(n))?B(function(){var e={_w:r,_d:!1};try{i.call(n,u(O,e,1),u(H,e,1))}catch(t){H.call(e,t)}}):(r._v=n,r._s=1,D(r,!1))}catch(e){H.call({_w:r,_d:!1},e)}}};L||(S=function Promise(t){f(this,S,v,"_h"),d(t),r.call(this);try{t(u(O,this,1),u(H,this,1))}catch(n){H.call(this,n)}},(r=function Promise(t){this._c=[],this._a=undefined,this._s=0,this._d=!1,this._v=undefined,this._h=0,this._n=!1}).prototype=i(44)(S.prototype,{then:function(e,t){var n=A(m(this,S));return n.ok="function"!=typeof e||e,n.fail="function"==typeof t&&t,n.domain=x?C.domain:undefined,this._c.push(n),this._a&&this._a.push(n),this._s&&D(this,!1),n.promise},"catch":function(e){return this.then(undefined,e)}}),a=function(){var e=new r;this.promise=e,this.resolve=u(O,e,1),this.reject=u(H,e,1)},_.f=A=function(e){return e===S||e===o?new a:n(e)}),h(h.G+h.W+h.F*!L,{Promise:S}),i(39)(S,v),i(42)(v),o=i(7)[v],h(h.S+h.F*!L,v,{reject:function(e){var t=A(this);return(0,t.reject)(e),t.promise}}),h(h.S+h.F*(s||!L),v,{resolve:function(e){return y(s&&this===o?S:this,e)}}),h(h.S+h.F*!(L&&i(57)(function(e){S.all(e)["catch"](w)})),v,{all:function(e){var o=this,t=A(o),s=t.resolve,l=t.reject,n=E(function(){var i=[],r=0,a=1;g(e,!1,function(e){var t=r++,n=!1;i.push(undefined),a++,o.resolve(e).then(function(e){n||(n=!0,i[t]=e,--a||s(i))},l)}),--a||s(i)});return n.e&&l(n.v),t.promise},race:function(e){var t=this,n=A(t),i=n.reject,r=E(function(){g(e,!1,function(e){t.resolve(e).then(n.resolve,i)})});return r.e&&i(r.v),n.promise}})},function(e,t,n){"use strict";var r=n(19);function i(e){var n,i;this.promise=new e(function(e,t){if(n!==undefined||i!==undefined)throw TypeError("Bad Promise constructor");n=e,i=t}),this.resolve=r(n),this.reject=r(i)}e.exports.f=function(e){return new i(e)}},function(e,t,n){var i=n(3),r=n(4),a=n(291);e.exports=function(e,t){if(i(e),r(t)&&t.constructor===e)return t;var n=a.f(e);return(0,n.resolve)(t),n.promise}},function(e,t,n){"use strict";var o=n(9).f,s=n(34),l=n(44),u=n(18),c=n(43),h=n(61),i=n(82),r=n(287),a=n(42),p=n(8),d=n(28).fastKey,f=n(38),g=p?"_s":"size",m=function(e,t){var n,i=d(t);if("F"!==i)return e._i[i];for(n=e._f;n;n=n.n)if(n.k==t)return n};e.exports={getConstructor:function(e,a,n,i){var r=e(function(e,t){c(e,r,a,"_i"),e._t=a,e._i=s(null),e._f=undefined,e._l=undefined,e[g]=0,t!=undefined&&h(t,n,e[i],e)});return l(r.prototype,{clear:function(){for(var e=f(this,a),t=e._i,n=e._f;n;n=n.n)n.r=!0,n.p&&(n.p=n.p.n=undefined),delete t[n.i];e._f=e._l=undefined,e[g]=0},"delete":function(e){var t,n,i=f(this,a),r=m(i,e);return r&&(t=r.n,n=r.p,delete i._i[r.i],r.r=!0,n&&(n.n=t),t&&(t.p=n),i._f==r&&(i._f=t),i._l==r&&(i._l=n),i[g]--),!!r},forEach:function(e){f(this,a);for(var t,n=u(e,1l&&(u=u.slice(0,l)),i?u+r:r+u}},function(e,t,n){var l=n(8),u=n(32),c=n(16),h=n(47).f;e.exports=function(s){return function(e){for(var t,n=c(e),i=u(n),r=i.length,a=0,o=[];athis.options.items.length)){this._addItemAt(e,t);var n=this._addElement(e,t);return 0this.options.items.length-1)return!1;var n=this._children[this._getChildName(e)];return n.shouldUpdate?!0===n.shouldUpdate(this._getOptions(t)):null},updateItemAt:function(e,t){if(!(e<0||e>this.options.items.length-1)){var n;if(n=this._children[this._getChildName(e)].update(this._getOptions(t)))return n;var i=this._children[this._getChildName(e)];delete this._children[this._getChildName(e)],this.options.items.splice(e,1);var r=this._addElement(e,t);this.options.items.splice(e,0,t),this._children[this._getChildName(e)]=r,0BI.Widget._renderEngine.createElement("body").outerWidth()&&(h-=c.element.outerWidth()+15);var d=BI.Widget._renderEngine.createElement("body").outerHeight();return p+c.element.outerHeight()>d||u+c.element.outerHeight()>d?(p-=c.element.outerHeight()+15,a.belowMouse||(p=Math.min(p,s.top-c.element.outerHeight()-5))):a.belowMouse||(p=Math.max(p,u)),c.element.css({left:h<0?0:h+"px",top:p<0?0:p+"px"}),c.element.hover(function(){o.remove(t),r.element.trigger("mouseleave.title"+r.getName())}),this},add:function(e,t){return this.has(e)||this.set(e,t),this},get:function(e){return this.tooltipsManager[e]},set:function(e,t){this.tooltipsManager[e]=t},has:function(e){return null!=this.tooltipsManager[e]},remove:function(e){return this.has(e)&&(this.tooltipsManager[e].destroy(),delete this.tooltipsManager[e]),this}})},function(e,t){_.extend(BI,{Events:{KEYDOWN:"_KEYDOWN",BACKSPACE:"_BACKSPACE",SPACE:"_SPACE",ENTER:"_ENTER",CONFIRM:"_CONFIRM",ERROR:"_ERROR",PAUSE:"_PAUSE",DESTROY:"_DESTROY",MOUNT:"_MOUNT",UNMOUNT:"_UNMOUNT",CLEAR:"_CLEAR",ADD:"_ADD",EDITING:"_EDITING",EMPTY:"_EMPTY",VIEW:"_VIEW",RESIZE:"_RESIZE",BEFOREEDIT:"_BEFOREEDIT",AFTEREDIT:"_AFTEREDIT",STARTEDIT:"_STARTEDIT",STOPEDIT:"_STOPEDIT",CHANGE:"_CHANGE",EXPAND:"_EXPAND",COLLAPSE:"_COLLAPSE",CALLBACK:"_CALLBACK",CLICK:"_CLICK",STATECHANGE:"_STATECHANGE",BEFORESTATECHANGE:"_BEFORESTATECHANGE",INIT:"_INIT",AFTERINIT:"_AFTERINIT",SCROLL:"_SCROLL",STARTLOAD:"_STARTLOAD",AFTERLOAD:"_AFTERLOAD",BS:"beforesubmit",AS:"aftersubmit",SC:"submitcomplete",SF:"submitfailure",SS:"submitsuccess",BVW:"beforeverifywrite",AVW:"afterverifywrite",AV:"afterverify",BW:"beforewrite",AW:"afterwrite",WS:"writesuccess",WF:"writefailure",BA:"beforeappend",AA:"afterappend",BD:"beforedelete",AD:"beforedelete",UC:"unloadcheck",BTOPDF:"beforetopdf",ATOPDF:"aftertopdf",BTOEXCEL:"beforetoexcel",ATOEXCEL:"aftertoexcel",BTOWORD:"beforetoword",ATOWORD:"aftertoword",BTOIMAGE:"beforetoimage",ATOIMAGE:"aftertoimage",BTOHTML:"beforetohtml",ATOHTML:"aftertohtml",BIMEXCEL:"beforeimportexcel",AIMEXCEL:"afterimportexcel",BPDFPRINT:"beforepdfprint",APDFPRINT:"afterpdfprint",BFLASHPRINT:"beforeflashprint",AFLASHPRINT:"afterflashprint",BAPPLETPRINT:"beforeappletprint",AAPPLETPRINT:"afterappletprint",BSEVERPRINT:"beforeserverprint",ASERVERPRINT:"afterserverprint",BEMAIL:"beforeemail",AEMAIL:"afteremail"}})},function(e,t){BI.prepares.push(function(){BI.Date=BI.Date||{},BI.Date._DN=[BI.i18nText("BI-Basic_Sunday"),BI.i18nText("BI-Basic_Monday"),BI.i18nText("BI-Basic_Tuesday"),BI.i18nText("BI-Basic_Wednesday"),BI.i18nText("BI-Basic_Thursday"),BI.i18nText("BI-Basic_Friday"),BI.i18nText("BI-Basic_Saturday"),BI.i18nText("BI-Basic_Sunday")],BI.Date._SDN=[BI.i18nText("BI-Basic_Simple_Sunday"),BI.i18nText("BI-Basic_Simple_Monday"),BI.i18nText("BI-Basic_Simple_Tuesday"),BI.i18nText("BI-Basic_Simple_Wednesday"),BI.i18nText("BI-Basic_Simple_Thursday"),BI.i18nText("BI-Basic_Simple_Friday"),BI.i18nText("BI-Basic_Simple_Saturday"),BI.i18nText("BI-Basic_Simple_Sunday")],BI.Date._FD=1,BI.Date._MN=[BI.i18nText("BI-Basic_January"),BI.i18nText("BI-Basic_February"),BI.i18nText("BI-Basic_March"),BI.i18nText("BI-Basic_April"),BI.i18nText("BI-Basic_May"),BI.i18nText("BI-Basic_June"),BI.i18nText("BI-Basic_July"),BI.i18nText("BI-Basic_August"),BI.i18nText("BI-Basic_September"),BI.i18nText("BI-Basic_October"),BI.i18nText("BI-Basic_November"),BI.i18nText("BI-Basic_December")],BI.Date._SMN=[0,1,2,3,4,5,6,7,8,9,10,11],BI.Date._QN=["",BI.i18nText("BI-Quarter_1"),BI.i18nText("BI-Quarter_2"),BI.i18nText("BI-Quarter_3"),BI.i18nText("BI-Quarter_4")],BI.Date._MD=[31,28,31,30,31,30,31,31,30,31,30,31],BI.Date._OFFSET=[0,-1,-2,-3,-4,-5,-6]})},function(e,t){BI.ShowListener=BI.inherit(BI.OB,{_defaultConfig:function(){return BI.extend(BI.ShowListener.superclass._defaultConfig.apply(this,arguments),{eventObj:BI.createWidget(),cardLayout:null,cardNameCreator:function(e){return e},cardCreator:BI.emptyFn,afterCardCreated:BI.emptyFn,afterCardShow:BI.emptyFn})},_init:function(){BI.ShowListener.superclass._init.apply(this,arguments);var a=this,o=this.options;o.eventObj&&o.eventObj.on(BI.Controller.EVENT_CHANGE,function(e,t,n){if(e===BI.Events.CLICK){if(t=t||o.eventObj.getValue(),t=BI.isArray(t)?1").css({position:"relative",display:"table",width:e.horizontalAlign===BI.HorizontalAlign.Center||e.horizontalAlign===BI.HorizontalAlign.Stretch?"100%":"auto",height:e.verticalAlign===BI.VerticalAlign.Middle||e.verticalAlign===BI.VerticalAlign.Stretch?"100%":"auto","white-space":"nowrap"}),this.populate(this.options.items)},_addElement:function(e,t){var n,i,r=this.options,a=r.columnSize[e]<=1?100*r.columnSize[e]+"%":r.columnSize[e];return this.hasWidget(this._getChildName(e))?(n=this.getWidgetByName(this._getChildName(e))).element.width(a):((i=BI._lazyCreateWidget(t)).element.css({position:"relative",top:"0",left:"0",margin:"0px auto"}),n=BI._lazyCreateWidget({type:"bi.default",width:a,items:[i]}),this.addWidget(this._getChildName(e),n)),n.element.css({"max-width":r.columnSize[e]<=1?a:a+"px"}),0===e&&n.element.addClass("first-element"),n.element.css({position:"relative",display:"table-cell","vertical-align":r.verticalAlign,margin:"0",padding:"0",height:"100%"}),r.vgap+r.tgap+(t.tgap||0)+(t.vgap||0)!==0&&i.element.css({"margin-top":r.vgap+r.tgap+(t.tgap||0)+(t.vgap||0)+"px"}),r.hgap+r.lgap+(t.lgap||0)+(t.hgap||0)!==0&&i.element.css({"margin-left":(0===e?r.hgap:0)+r.lgap+(t.lgap||0)+(t.hgap||0)+"px"}),r.hgap+r.rgap+(t.rgap||0)+(t.hgap||0)!==0&&i.element.css({"margin-right":r.hgap+r.rgap+(t.rgap||0)+(t.hgap||0)+"px"}),r.vgap+r.bgap+(t.bgap||0)+(t.vgap||0)!==0&&i.element.css({"margin-bottom":r.vgap+r.bgap+(t.bgap||0)+(t.vgap||0)+"px"}),n},appendFragment:function(e){this.$table.append(e),this.element.append(this.$table)},resize:function(){},populate:function(e){BI.TableAdaptLayout.superclass.populate.apply(this,arguments),this._mount()}}),BI.shortcut("bi.table_adapt",BI.TableAdaptLayout)},function(e,t){BI.VerticalAdaptLayout=BI.inherit(BI.Layout,{props:{baseCls:"bi-vertical-adapt-layout",horizontalAlign:BI.HorizontalAlign.Left,columnSize:[],scrollx:!1,hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0},render:function(){var t=this,e=this.options;return BI.VerticalAdaptLayout.superclass.render.apply(this,arguments),{type:"bi.horizontal",verticalAlign:BI.VerticalAlign.Middle,horizontalAlign:e.horizontalAlign,columnSize:e.columnSize,items:e.items,scrollx:e.scrollx,scrolly:e.scrolly,scrollable:e.scrollable,ref:function(e){t.layout=e},hgap:e.hgap,vgap:e.vgap,lgap:e.lgap,rgap:e.rgap,tgap:e.tgap,bgap:e.bgap}},resize:function(){},populate:function(e){this.layout.populate.apply(this,arguments)}}),BI.shortcut("bi.vertical_adapt",BI.VerticalAdaptLayout)},function(e,t){BI.HorizontalAutoLayout=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.HorizontalAutoLayout.superclass.props.apply(this,arguments),{baseCls:"bi-horizon-auto-layout",hgap:0,lgap:0,rgap:0,vgap:0,tgap:0,bgap:0})},render:function(){BI.HorizontalAutoLayout.superclass.render.apply(this,arguments),this.populate(this.options.items)},_addElement:function(e,t){var n=this.options,i=BI.HorizontalAutoLayout.superclass._addElement.apply(this,arguments);return i.element.css({position:"relative",margin:"0px auto"}),n.vgap+n.tgap+(t.tgap||0)+(t.vgap||0)!==0&&i.element.css({"margin-top":(0===e?n.vgap:0)+n.tgap+(t.tgap||0)+(t.vgap||0)+"px"}),n.hgap+n.lgap+(t.lgap||0)+(t.hgap||0)!==0&&i.element.css({"margin-left":n.hgap+n.lgap+(t.lgap||0)+(t.hgap||0)+"px"}),n.hgap+n.rgap+(t.rgap||0)+(t.hgap||0)!==0&&i.element.css({"margin-right":n.hgap+n.rgap+(t.rgap||0)+(t.hgap||0)+"px"}),n.vgap+n.bgap+(t.bgap||0)+(t.vgap||0)!==0&&i.element.css({"margin-bottom":n.vgap+n.bgap+(t.bgap||0)+(t.vgap||0)+"px"}),i},resize:function(){},populate:function(e){BI.HorizontalAutoLayout.superclass.populate.apply(this,arguments),this._mount()}}),BI.shortcut("bi.horizontal_auto",BI.HorizontalAutoLayout)},function(e,t){BI.FloatHorizontalLayout=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.FloatHorizontalLayout.superclass.props.apply(this,arguments),{baseCls:"bi-float-horizontal-adapt-layout",items:[],hgap:0,vgap:0,tgap:0,bgap:0,lgap:0,rgap:0})},render:function(){BI.FloatHorizontalLayout.superclass.render.apply(this,arguments),this.populate(this.options.items)},resize:function(){},mounted:function(){var n=this,e=this.left.element.width(),t=this.left.element.height();this.left.element.width(e).height(t).css("float","none"),BI.remove(this._children,function(e,t){t===n.container&&delete n._children[e]}),BI._lazyCreateWidget({type:"bi.horizontal_auto",element:this,items:[this.left]})},_addElement:function(e,t){var n=this.options;return this.left=BI._lazyCreateWidget({type:"bi.vertical",items:[t],hgap:n.hgap,vgap:n.vgap,tgap:n.tgap,bgap:n.bgap,lgap:n.lgap,rgap:n.rgap}),this.container=BI._lazyCreateWidget({type:"bi.left",element:this,items:[this.left]}),this.left},populate:function(e){BI.HorizontalAutoLayout.superclass.populate.apply(this,arguments),this._mount()}}),BI.shortcut("bi.horizontal_float",BI.FloatHorizontalLayout)},function(e,t){BI.InlineCenterAdaptLayout=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.InlineCenterAdaptLayout.superclass.props.apply(this,arguments),{baseCls:"bi-inline-center-adapt-layout",horizontalAlign:BI.HorizontalAlign.Center,verticalAlign:BI.VerticalAlign.Middle,columnSize:[],hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0})},render:function(){BI.InlineCenterAdaptLayout.superclass.render.apply(this,arguments);var e=this.options;this.element.css({whiteSpace:"nowrap",textAlign:e.horizontalAlign}),this.populate(e.items)},_addElement:function(e,t,n){var i=this.options,r=BI.InlineCenterAdaptLayout.superclass._addElement.apply(this,arguments);return r.element.css({width:i.columnSize[e]<=1?100*i.columnSize[e]+"%":i.columnSize[e],position:"relative","vertical-align":i.verticalAlign}),r.element.addClass("inline-center-adapt-item"),i.vgap+i.tgap+(t.tgap||0)+(t.vgap||0)!==0&&r.element.css({"margin-top":i.vgap+i.tgap+(t.tgap||0)+(t.vgap||0)+"px"}),i.hgap+i.lgap+(t.lgap||0)+(t.hgap||0)!==0&&r.element.css({"margin-left":(0===e?i.hgap:0)+i.lgap+(t.lgap||0)+(t.hgap||0)+"px"}),i.hgap+i.rgap+(t.rgap||0)+(t.hgap||0)!==0&&r.element.css({"margin-right":i.hgap+i.rgap+(t.rgap||0)+(t.hgap||0)+"px"}),i.vgap+i.bgap+(t.bgap||0)+(t.vgap||0)!==0&&r.element.css({"margin-bottom":i.vgap+i.bgap+(t.bgap||0)+(t.vgap||0)+"px"}),r},resize:function(){this.stroke(this.options.items)},addItem:function(e){throw new Error("不能添加元素")},stroke:function(n){var i=this;BI.each(n,function(e,t){t&&i._addElement(e,t,n.length)})},populate:function(e){BI.InlineCenterAdaptLayout.superclass.populate.apply(this,arguments),this._mount()}}),BI.shortcut("bi.inline_center_adapt",BI.InlineCenterAdaptLayout)},function(e,t){BI.InlineHorizontalAdaptLayout=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.InlineHorizontalAdaptLayout.superclass.props.apply(this,arguments),{baseCls:"bi-inline-horizontal-adapt-layout",horizontalAlign:BI.HorizontalAlign.Center,verticalAlign:BI.VerticalAlign.Top,columnSize:[],hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0})},render:function(){BI.InlineHorizontalAdaptLayout.superclass.render.apply(this,arguments);var e=this.options;this.element.css({whiteSpace:"nowrap",textAlign:e.horizontalAlign}),this.populate(e.items)},_addElement:function(e,t,n){var i=this.options,r=BI.InlineHorizontalAdaptLayout.superclass._addElement.apply(this,arguments);return r.element.css({width:i.columnSize[e]<=1?100*i.columnSize[e]+"%":i.columnSize[e],position:"relative","vertical-align":i.verticalAlign}),r.element.addClass("inline-horizontal-adapt-item"),i.vgap+i.tgap+(t.tgap||0)+(t.vgap||0)!==0&&r.element.css({"margin-top":i.vgap+i.tgap+(t.tgap||0)+(t.vgap||0)+"px"}),i.hgap+i.lgap+(t.lgap||0)+(t.hgap||0)!==0&&r.element.css({"margin-left":(0===e?i.hgap:0)+i.lgap+(t.lgap||0)+(t.hgap||0)+"px"}),i.hgap+i.rgap+(t.rgap||0)+(t.hgap||0)!==0&&r.element.css({"margin-right":i.hgap+i.rgap+(t.rgap||0)+(t.hgap||0)+"px"}),i.vgap+i.bgap+(t.bgap||0)+(t.vgap||0)!==0&&r.element.css({"margin-bottom":i.vgap+i.bgap+(t.bgap||0)+(t.vgap||0)+"px"}),r},resize:function(){this.stroke(this.options.items)},addItem:function(e){throw new Error("不能添加元素")},stroke:function(n){var i=this;BI.each(n,function(e,t){t&&i._addElement(e,t,n.length)})},populate:function(e){BI.InlineHorizontalAdaptLayout.superclass.populate.apply(this,arguments),this._mount()}}),BI.shortcut("bi.inline_horizontal_adapt",BI.InlineHorizontalAdaptLayout)},function(e,t){BI.InlineVerticalAdaptLayout=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.InlineVerticalAdaptLayout.superclass.props.apply(this,arguments),{baseCls:"bi-inline-vertical-adapt-layout",horizontalAlign:BI.HorizontalAlign.Left,verticalAlign:BI.VerticalAlign.Middle,columnSize:[],hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0})},render:function(){BI.InlineVerticalAdaptLayout.superclass.render.apply(this,arguments);var e=this.options;this.element.css({whiteSpace:"nowrap",textAlign:e.horizontalAlign}),this.populate(e.items)},_addElement:function(e,t){var n=this.options,i=BI.InlineVerticalAdaptLayout.superclass._addElement.apply(this,arguments);return i.element.css({width:n.columnSize[e]<=1?100*n.columnSize[e]+"%":n.columnSize[e],position:"relative","vertical-align":n.verticalAlign}),i.element.addClass("inline-vertical-adapt-item"),n.vgap+n.tgap+(t.tgap||0)+(t.vgap||0)!==0&&i.element.css({"margin-top":n.vgap+n.tgap+(t.tgap||0)+(t.vgap||0)+"px"}),n.hgap+n.lgap+(t.lgap||0)+(t.hgap||0)!==0&&i.element.css({"margin-left":(0===e?n.hgap:0)+n.lgap+(t.lgap||0)+(t.hgap||0)+"px"}),n.hgap+n.rgap+(t.rgap||0)+(t.hgap||0)!==0&&i.element.css({"margin-right":n.hgap+n.rgap+(t.rgap||0)+(t.hgap||0)+"px"}),n.vgap+n.bgap+(t.bgap||0)+(t.vgap||0)!==0&&i.element.css({"margin-bottom":n.vgap+n.bgap+(t.bgap||0)+(t.vgap||0)+"px"}),i},resize:function(){this.stroke(this.options.items)},populate:function(e){BI.InlineVerticalAdaptLayout.superclass.populate.apply(this,arguments),this._mount()}}),BI.shortcut("bi.inline_vertical_adapt",BI.InlineVerticalAdaptLayout)},function(e,t){BI.FlexCenterLayout=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.FlexCenterLayout.superclass.props.apply(this,arguments),{baseCls:"bi-flex-center-adapt-layout",verticalAlign:BI.VerticalAlign.Middle,horizontalAlign:BI.HorizontalAlign.Center,hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0})},render:function(){var t=this,e=this.options;return{type:"bi.flex_horizontal",ref:function(e){t.wrapper=e},horizontalAlign:e.horizontalAlign,verticalAlign:e.verticalAlign,scrollx:e.scrollx,scrolly:e.scrolly,scrollable:e.scrollable,hgap:e.hgap,vgap:e.vgap,tgap:e.tgap,bgap:e.bgap,items:e.items}},resize:function(){},update:function(e){return this.wrapper.update(e)},populate:function(e){this.wrapper.populate(e)}}),BI.shortcut("bi.flex_center_adapt",BI.FlexCenterLayout)},function(e,t){BI.FlexHorizontalCenter=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.FlexHorizontalCenter.superclass.props.apply(this,arguments),{baseCls:"bi-flex-horizontal-center-adapt-layout",verticalAlign:BI.VerticalAlign.Top,rowSize:[],scrolly:!1,hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0})},render:function(){var t=this,e=this.options;return{type:"bi.flex_vertical",ref:function(e){t.wrapper=e},horizontalAlign:BI.HorizontalAlign.Center,verticalAlign:e.verticalAlign,rowSize:e.rowSize,scrollx:e.scrollx,scrolly:e.scrolly,scrollable:e.scrollable,hgap:e.hgap,vgap:e.vgap,tgap:e.tgap,bgap:e.bgap,items:e.items}},resize:function(){},update:function(e){return this.wrapper.update(e)},populate:function(e){this.wrapper.populate(e)}}),BI.shortcut("bi.flex_horizontal_adapt",BI.FlexHorizontalCenter),BI.shortcut("bi.flex_horizontal_center_adapt",BI.FlexHorizontalCenter)},function(e,t){BI.FlexHorizontalLayout=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.FlexHorizontalLayout.superclass.props.apply(this,arguments),{baseCls:"bi-flex-horizontal-layout",verticalAlign:BI.VerticalAlign.Top,horizontalAlign:BI.HorizontalAlign.Left,columnSize:[],scrollx:!0,hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0})},render:function(){BI.FlexHorizontalLayout.superclass.render.apply(this,arguments);var e=this.options;this.element.addClass("v-"+e.verticalAlign).addClass("h-"+e.horizontalAlign),this.populate(this.options.items)},_addElement:function(e,t){var n=this.options,i=BI.FlexHorizontalLayout.superclass._addElement.apply(this,arguments);return i.element.css({position:"relative"}),BI.contains([BI.HorizontalAlign.Left,BI.HorizontalAlign.Right,BI.HorizontalAlign.Center],n.horizontalAlign)&&i.element.css({"flex-shrink":"0"}),0").addClass("flex-scrollable-horizontal-layout-wrapper v-"+e.verticalAlign).addClass("h-"+e.horizontalAlign),this.populate(this.options.items)},_addElement:function(e,t){var n=this.options,i=BI.FlexWrapperHorizontalLayout.superclass._addElement.apply(this,arguments);return i.element.css({position:"relative"}),n.horizontalAlign!==BI.HorizontalAlign.Left&&n.horizontalAlign!==BI.HorizontalAlign.Right||i.element.css({"flex-shrink":"0"}),0").addClass("flex-scrollable-vertical-layout-wrapper h-"+e.horizontalAlign).addClass("v-"+e.verticalAlign),this.populate(this.options.items)},_addElement:function(e,t){var n=this.options,i=BI.FlexWrapperVerticalLayout.superclass._addElement.apply(this,arguments);return i.element.css({position:"relative"}),n.verticalAlign!==BI.VerticalAlign.Top&&n.verticalAlign!==BI.VerticalAlign.Bottom||i.element.css({"flex-shrink":"0"}),0").attr({cellspacing:0,cellpadding:0}).css({position:"relative","white-space":"nowrap",width:e.horizontalAlign===BI.HorizontalAlign.Center||e.horizontalAlign===BI.HorizontalAlign.Stretch?"100%":"auto",height:e.verticalAlign===BI.VerticalAlign.Middle||e.verticalAlign===BI.VerticalAlign.Stretch?"100%":"auto","border-spacing":"0px",border:"none","border-collapse":"separate"}),this.$tr=BI.Widget._renderEngine.createElement(""),this.$tr.appendTo(this.$table),this.populate(this.options.items)},_addElement:function(e,t){var n,i,r=this.options,a=r.columnSize[e]<=1?100*r.columnSize[e]+"%":r.columnSize[e];return this.hasWidget(this._getChildName(e))?(n=this.getWidgetByName(this._getChildName(e))).element.attr("width",a):((i=BI._lazyCreateWidget(t)).element.css({position:"relative",margin:"0px auto"}),n=BI._lazyCreateWidget({type:"bi.default",tagName:"td",attributes:{width:a},items:[i]}),this.addWidget(this._getChildName(e),n)),n.element.css({"max-width":r.columnSize[e]<=1?a:a+"px"}),0===e&&n.element.addClass("first-element"),n.element.css({position:"relative","vertical-align":r.verticalAlign,margin:"0",padding:"0",border:"none"}),r.vgap+r.tgap+(t.tgap||0)+(t.vgap||0)!==0&&i.element.css({"margin-top":r.vgap+r.tgap+(t.tgap||0)+(t.vgap||0)+"px"}),r.hgap+r.lgap+(t.lgap||0)+(t.hgap||0)!==0&&i.element.css({"margin-left":(0===e?r.hgap:0)+r.lgap+(t.lgap||0)+(t.hgap||0)+"px"}),r.hgap+r.rgap+(t.rgap||0)+(t.hgap||0)!==0&&i.element.css({"margin-right":r.hgap+r.rgap+(t.rgap||0)+(t.hgap||0)+"px"}),r.vgap+r.bgap+(t.bgap||0)+(t.vgap||0)!==0&&i.element.css({"margin-bottom":r.vgap+r.bgap+(t.bgap||0)+(t.vgap||0)+"px"}),n},appendFragment:function(e){this.$tr.append(e),this.element.append(this.$table)},resize:function(){},_getWrapper:function(){return this.$tr},populate:function(e){BI.HorizontalLayout.superclass.populate.apply(this,arguments),this._mount()}}),BI.shortcut("bi.horizontal",BI.HorizontalLayout),BI.HorizontalCellLayout=BI.inherit(BI.Layout,{props:function(){return BI.extend(BI.HorizontalCellLayout.superclass.props.apply(this,arguments),{baseCls:"bi-horizontal-cell-layout",scrollable:!0,hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0})},render:function(){BI.HorizontalCellLayout.superclass.render.apply(this,arguments),this.element.css({display:"table","vertical-align":"top"}),this.populate(this.options.items)},_addElement:function(e,t){var n=this.options,i=BI.HorizontalCellLayout.superclass._addElement.apply(this,arguments);return i.element.css({position:"relative",display:"table-cell","vertical-align":"middle"}),0").attr({cellspacing:0,cellpadding:0}).css({position:"relative",width:"100%",height:"100%","border-spacing":"0px",border:"none","border-collapse":"separate"}),this.rows=0,this.populate(this.options.items)},_addElement:function(e,t){var n=this.options;function i(e,t,n){0===t&&e.addClass("first-row"),0===n&&e.addClass("first-col"),e.addClass(BI.isOdd(t+1)?"odd-row":"even-row"),e.addClass(BI.isOdd(n+1)?"odd-col":"even-col"),e.addClass("center-element")}function r(e,t,n){var i="";0===t&&(i+=" first-row"),0===n&&(i+=" first-col"),BI.isOdd(t+1)?i+=" odd-row":i+=" even-row",BI.isOdd(n+1)?i+=" odd-col":i+=" even-col",e.cls=(e.cls||"")+i+" center-element"}for(var a,o,s,l=BI._lazyCreateWidget({type:"bi.default",tagName:"tr"}),u=0;u=this.renderRange.minY&&s<=this.renderRange.maxY&&r>=this.renderRange.minX&&o<=this.renderRange.maxX)return;for(var l=this._cellRenderers(s-a,o-r,r,a),u=[],c={},h={},p={},d={},f=0,g=l.length;f').css({position:"absolute",zIndex:BI.zIndex_tip-2,top:0,left:0,right:0,bottom:0,opacity:.5}).appendTo("body")),l=BI.Widget._renderEngine.createElement('
').css({position:"absolute",zIndex:BI.zIndex_tip-1,top:0,left:0,right:0,bottom:0}).appendTo("body");var r=function(){u[u.length-1].destroy(),u.pop(),0===u.length&&(s.remove(),s=null)},a=[];!0===e&&a.push({el:{type:"bi.button",text:BI.i18nText("BI-Basic_Cancel"),level:"ignore",handler:function(){r(),BI.isFunction(i)&&i.apply(null,[!1])}}}),a.push({el:{type:"bi.button",text:BI.i18nText("BI-Basic_OK"),handler:function(){r(),BI.isFunction(i)&&i.apply(null,[!0])}}});var o={element:l,type:"bi.center_adapt",items:[{type:"bi.border",cls:"bi-card",items:{north:{el:{type:"bi.border",cls:"bi-message-title bi-background",items:{center:{el:{type:"bi.label",cls:"bi-font-bold",text:t||BI.i18nText("BI-Basic_Prompt"),textAlign:"left",hgap:20,height:40}},east:{el:{type:"bi.icon_button",cls:"bi-message-close close-font",handler:function(){r(),BI.isFunction(i)&&i.apply(null,[!1])}},width:60}}},height:40},center:{el:{type:"bi.label",vgap:10,hgap:20,whiteSpace:"normal",text:n}},south:{el:{type:"bi.absolute",items:[{el:{type:"bi.right_vertical_adapt",lgap:10,items:a},top:0,left:20,right:20,bottom:0}]},height:44}},width:450,height:200}]};u[u.length]=BI.createWidget(o)}})},function(e,t){BI.GridView=BI.inherit(BI.Widget,{_defaultConfig:function(){return BI.extend(BI.GridView.superclass._defaultConfig.apply(this,arguments),{baseCls:"bi-grid-view",overflowX:!0,overflowY:!0,overscanColumnCount:0,overscanRowCount:0,rowHeightGetter:BI.emptyFn,columnWidthGetter:BI.emptyFn,scrollLeft:0,scrollTop:0,items:[]})},_init:function(){BI.GridView.superclass._init.apply(this,arguments);var e=this,t=this.options;this.renderedCells=[],this.renderedKeys=[],this.renderRange={},this._scrollLock=!1,this._debounceRelease=BI.debounce(function(){e._scrollLock=!1},1e3/60),this.container=BI._lazyCreateWidget({type:"bi.absolute"}),this.element.scroll(function(){!0!==e._scrollLock&&(t.scrollLeft=e.element.scrollLeft(),t.scrollTop=e.element.scrollTop(),e._calculateChildrenToRender(),e.fireEvent(BI.GridView.EVENT_SCROLL,{scrollLeft:t.scrollLeft,scrollTop:t.scrollTop}))}),BI._lazyCreateWidget({type:"bi.vertical",element:this,scrollable:!0===t.overflowX&&!0===t.overflowY,scrolly:!1===t.overflowX&&!0===t.overflowY,scrollx:!0===t.overflowX&&!1===t.overflowY,items:[this.container]}),0=this.renderRange.minY&&T<=this.renderRange.maxY&&v>=this.renderRange.minX&&C<=this.renderRange.maxX)return;for(var N=[],V={},S={},x=this._getMaxScrollLeft(),w=this._getMaxScrollTop(),A=0,L=0,k=0,D=m;D<=I;D++)for(var M=this._rowSizeAndPositionManager.getSizeAndPositionOfCell(D),P=f;P<=g;P++){var R,H=D+"-"+P,O=this._columnSizeAndPositionManager.getSizeAndPositionOfCell(P),F=this.renderedKeys[H]&&this.renderedKeys[H][2];0<=F?(O.size!==this.renderedCells[F]._width&&(this.renderedCells[F]._width=O.size,this.renderedCells[F].el.setWidth(O.size)),M.size!==this.renderedCells[F]._height&&(this.renderedCells[F]._height=M.size,this.renderedCells[F].el.setHeight(M.size)),this.renderedCells[F]._left!==O.offset+c&&this.renderedCells[F].el.element.css("left",O.offset+c+"px"),this.renderedCells[F]._top!==M.offset+h&&this.renderedCells[F].el.element.css("top",M.offset+h+"px"),R=this.renderedCells[F].el,N.push(this.renderedCells[F])):(R=BI._lazyCreateWidget(BI.extend({type:"bi.label",width:O.size,height:M.size},e.items[D][P],{cls:(e.items[D][P].cls||"")+" grid-cell"+(0===D?" first-row":"")+(0===P?" first-col":""),_rowIndex:D,_columnIndex:P,_left:O.offset+c,_top:M.offset+h}),this),N.push({el:R,left:O.offset+c,top:M.offset+h,_left:O.offset+c,_top:M.offset+h,_width:O.size,_height:M.size})),x=Math.min(x,O.offset+c),A=Math.max(A,O.offset+c+O.size),w=Math.min(w,M.offset+h),L=Math.max(L,M.offset+h+M.size),V[H]=[D,P,k],S[k]=R,k++}var W={},Y={},G=[];BI.each(V,function(e,t){n.renderedKeys[e]?W[e]=t:Y[e]=t}),BI.each(this.renderedKeys,function(e,t){W[e]||Y[e]||G.push(t[2])}),BI.each(G,function(e,t){n.renderedCells[t].el._destroy()});var j=[];BI.each(Y,function(e,t){j.push(N[t[2]])}),this.container.addItems(j,this),this.container._children=S,this.container.attr("items",N),this.renderedCells=N,this.renderedKeys=V,this.renderRange={minX:x,minY:w,maxX:A,maxY:L}}},_getRealMaxScrollLeft:function(){var t=this.options,n=0;return BI.count(0,this.columnCount,function(e){n+=t.columnWidthGetter(e)}),Math.max(0,n-this.options.width+(this.options.overflowX?BI.DOM.getScrollWidth():0))},_getMaxScrollLeft:function(){return Math.max(0,this._columnSizeAndPositionManager.getTotalSize()-this.options.width+(this.options.overflowX?BI.DOM.getScrollWidth():0))},_getMaxScrollTop:function(){return Math.max(0,this._rowSizeAndPositionManager.getTotalSize()-this.options.height+(this.options.overflowY?BI.DOM.getScrollWidth():0))},_populate:function(e){var t=this.options;this._reRange(),this.columnCount=0,this.rowCount=0,e&&e!==this.options.items&&(this.options.items=e),BI.isNumber(t.columnCount)?this.columnCount=t.columnCount:0i.pages?i.pages:e,this.currPage=e),this._populate()},getValue:function(){var e=this.button_group.getValue()[0];switch(e){case"prev":return-1;case"next":return 1;case"first":return BI.MIN;case"last":return BI.MAX;default:return e}},attr:function(e,t){BI.Pager.superclass.attr.apply(this,arguments),"curr"===e&&(this.currPage=BI.result(this.options,"curr"))},populate:function(){this._populate()}}),BI.Pager.EVENT_CHANGE="EVENT_CHANGE",BI.Pager.EVENT_AFTER_POPULATE="EVENT_AFTER_POPULATE",BI.shortcut("bi.pager",BI.Pager)},function(e,t){BI.A=BI.inherit(BI.Text,{_defaultConfig:function(){var e=BI.A.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{baseCls:(e.baseCls||"")+" bi-a display-block",href:"",target:"_blank",el:null,tagName:"a"})},_init:function(){var e=this.options;BI.A.superclass._init.apply(this,arguments),this.element.attr({href:e.href,target:e.target}),e.el&&BI.createWidget(e.el,{element:this})}}),BI.shortcut("bi.a",BI.A)},function(e,t){BI.LoadingBar=BI.inherit(BI.Single,{_defaultConfig:function(){var e=BI.LoadingBar.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{baseCls:(e.baseCls||"")+" bi-loading-bar bi-tips",height:30,handler:BI.emptyFn})},_init:function(){BI.LoadingBar.superclass._init.apply(this,arguments);var t=this;this.loaded=BI.createWidget({type:"bi.text_button",cls:"loading-text bi-list-item-simple",text:BI.i18nText("BI-Load_More"),width:120,handler:this.options.handler}),this.loaded.on(BI.Controller.EVENT_CHANGE,function(e){t.fireEvent(BI.Controller.EVENT_CHANGE,arguments)}),this.loading=BI.createWidget({type:"bi.layout",width:this.options.height,height:this.options.height,cls:"loading-background cursor-default"});var e=BI.createWidget({type:"bi.center_adapt",items:[this.loaded]}),n=BI.createWidget({type:"bi.center_adapt",items:[this.loading]});this.cardLayout=BI.createWidget({type:"bi.card",element:this,items:[{el:e,cardName:"loaded"},{el:n,cardName:"loading"}]}),this.invisible()},_reset:function(){this.visible(),this.loaded.setText(BI.i18nText("BI-Load_More")),this.loaded.enable()},setLoaded:function(){this._reset(),this.cardLayout.showCardByName("loaded")},setEnd:function(){this.setLoaded(),this.loaded.setText(BI.i18nText("BI-No_More_Data")),this.loaded.disable()},setLoading:function(){this._reset(),this.cardLayout.showCardByName("loading")}}),BI.shortcut("bi.loading_bar",BI.LoadingBar)},function(e,t){BI.IconButton=BI.inherit(BI.BasicButton,{_defaultConfig:function(){var e=BI.IconButton.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{_baseCls:(e._baseCls||"")+" bi-icon-button horizon-center",iconWidth:null,iconHeight:null})},_init:function(){BI.IconButton.superclass._init.apply(this,arguments);var e=this.options;this.element.css({textAlign:"center"}),this.icon=BI.createWidget({type:"bi.icon",width:e.iconWidth,height:e.iconHeight}),BI.isNumber(e.height)&&0",root:!0,value:e.value,watermark:e.watermark,validationChecker:e.validationChecker,quitChecker:e.quitChecker,allowBlank:e.allowBlank})),this.editor.element.css({width:"100%",height:"100%",border:"none",outline:"none",padding:"0",margin:"0"});var n=[{el:{type:"bi.absolute",ref:function(e){t.contentWrapper=e},items:[{el:this.editor,left:0,right:0,top:0,bottom:0}]},left:e.hgap+e.lgap,right:e.hgap+e.rgap,top:e.vgap+e.tgap,bottom:e.vgap+e.bgap}];BI.createWidget({type:"bi.absolute",element:this,items:n}),this.setWaterMark(this.options.watermark),this.editor.on(BI.Controller.EVENT_CHANGE,function(){t.fireEvent(BI.Controller.EVENT_CHANGE,arguments)}),this.editor.on(BI.Input.EVENT_FOCUS,function(){t._checkError(),t.element.addClass("bi-editor-focus"),t.fireEvent(BI.Editor.EVENT_FOCUS,arguments)}),this.editor.on(BI.Input.EVENT_BLUR,function(){t._setErrorVisible(!1),t.element.removeClass("bi-editor-focus"),t.fireEvent(BI.Editor.EVENT_BLUR,arguments)}),this.editor.on(BI.Input.EVENT_CLICK,function(){t.fireEvent(BI.Editor.EVENT_CLICK,arguments)}),this.editor.on(BI.Input.EVENT_CHANGE,function(){t.fireEvent(BI.Editor.EVENT_CHANGE,arguments)}),this.editor.on(BI.Input.EVENT_KEY_DOWN,function(e){t.fireEvent(BI.Editor.EVENT_KEY_DOWN,arguments)}),this.editor.on(BI.Input.EVENT_QUICK_DOWN,function(e){e.keyCode!==BI.KeyCode.TAB&&t.watermark&&t.watermark.invisible()}),this.editor.on(BI.Input.EVENT_VALID,function(){t._checkWaterMark(),t._setErrorVisible(!1),t.fireEvent(BI.Editor.EVENT_VALID,arguments)}),this.editor.on(BI.Input.EVENT_ERROR,function(){t._checkWaterMark(),t.fireEvent(BI.Editor.EVENT_ERROR,arguments),t._setErrorVisible(t.isEditing())}),this.editor.on(BI.Input.EVENT_RESTRICT,function(){t._checkWaterMark();var e=t._setErrorVisible(!0);e&&e.element.fadeOut(100,function(){e.element.fadeIn(100)}),t.fireEvent(BI.Editor.EVENT_RESTRICT,arguments)}),this.editor.on(BI.Input.EVENT_EMPTY,function(){t._checkWaterMark(),t.fireEvent(BI.Editor.EVENT_EMPTY,arguments)}),this.editor.on(BI.Input.EVENT_ENTER,function(){t.fireEvent(BI.Editor.EVENT_ENTER,arguments)}),this.editor.on(BI.Input.EVENT_SPACE,function(){t.fireEvent(BI.Editor.EVENT_SPACE,arguments)}),this.editor.on(BI.Input.EVENT_BACKSPACE,function(){t.fireEvent(BI.Editor.EVENT_BACKSPACE,arguments)}),this.editor.on(BI.Input.EVENT_REMOVE,function(){t.fireEvent(BI.Editor.EVENT_REMOVE,arguments)}),this.editor.on(BI.Input.EVENT_START,function(){t.fireEvent(BI.Editor.EVENT_START,arguments)}),this.editor.on(BI.Input.EVENT_PAUSE,function(){t.fireEvent(BI.Editor.EVENT_PAUSE,arguments)}),this.editor.on(BI.Input.EVENT_STOP,function(){t.fireEvent(BI.Editor.EVENT_STOP,arguments)}),this.editor.on(BI.Input.EVENT_CONFIRM,function(){t.fireEvent(BI.Editor.EVENT_CONFIRM,arguments)}),this.editor.on(BI.Input.EVENT_CHANGE_CONFIRM,function(){t.fireEvent(BI.Editor.EVENT_CHANGE_CONFIRM,arguments)}),this.element.click(function(e){return e.stopPropagation(),!1}),(BI.isKey(this.options.value)||BI.isEmptyString(this.options.value))&&this._checkError(),this._checkWaterMark()},_checkToolTip:function(){var e=this.options.errorText;BI.isFunction(e)&&(e=e(this.editor.getValue())),BI.isKey(e)&&(!this.isEnabled()||this.isValid()||BI.Bubbles.has(this.getName())&&BI.Bubbles.get(this.getName()).isVisible()?this.setTitle(""):this.setTitle(e))},_assertWaterMark:function(){var t=this,e=this.options;BI.isNull(this.watermark)&&(this.watermark=BI.createWidget({type:"bi.label",cls:"bi-water-mark",text:this.options.watermark,height:e.height-2*e.vgap-e.tgap,whiteSpace:"nowrap",textAlign:"left"}),this.watermark.element.bind({mousedown:function(e){t.isEnabled()?t.editor.isEditing()||t.editor.focus():t.editor.isEditing()&&t.editor.blur(),e.stopEvent()}}),this.watermark.element.bind("click",function(e){t.isEnabled()?t.editor.isEditing()||t.editor.focus():t.editor.isEditing()&&t.editor.blur(),e.stopEvent()}))},_checkError:function(){this._setErrorVisible(this.isEnabled()&&!this.isValid()),this._checkToolTip()},_checkWaterMark:function(){var e=this.options;!this.disabledWaterMark&&""===this.editor.getValue()&&BI.isKey(e.watermark)?this.watermark&&this.watermark.visible():this.watermark&&this.watermark.invisible()},setErrorText:function(e){this.options.errorText=e},getErrorText:function(){return this.options.errorText},setWaterMark:function(e){BI.isKey(e)&&(this.options.watermark=e,BI.isNull(this.watermark)&&(this._assertWaterMark(),BI.createWidget({type:"bi.absolute",element:this.contentWrapper,items:[{el:this.watermark,left:3,right:3,top:0,bottom:0}]})),this.watermark.setText(e))},_setErrorVisible:function(e){var t=this.options.errorText;if(BI.isFunction(t)&&(t=t(BI.trim(this.editor.getValue()))),!this.disabledError&&BI.isKey(t))return BI.Bubbles[e?"show":"hide"](this.getName(),t,this,{adjustYOffset:2}),this._checkToolTip(),BI.Bubbles.get(this.getName())},disableError:function(){this.disabledError=!0,this._checkError()},enableError:function(){this.disabledError=!1,this._checkError()},disableWaterMark:function(){this.disabledWaterMark=!0,this._checkWaterMark()},enableWaterMark:function(){this.disabledWaterMark=!1,this._checkWaterMark()},focus:function(){this.element.addClass("text-editor-focus"),this.editor.focus()},blur:function(){this.element.removeClass("text-editor-focus"),this.editor.blur()},selectAll:function(){this.editor.selectAll()},onKeyDown:function(e){this.editor.onKeyDown(e)},setValue:function(e){BI.Editor.superclass.setValue.apply(this,arguments),this.editor.setValue(e),this._checkError(),this._checkWaterMark()},getLastValidValue:function(){return this.editor.getLastValidValue()},getLastChangedValue:function(){return this.editor.getLastChangedValue()},getValue:function(){return this.isValid()?BI.trim(this.editor.getValue()):BI.trim(this.editor.getLastValidValue())},isEditing:function(){return this.editor.isEditing()},isValid:function(){return this.editor.isValid()},destroyed:function(){BI.Bubbles.remove(this.getName())}}),BI.Editor.EVENT_CHANGE="EVENT_CHANGE",BI.Editor.EVENT_FOCUS="EVENT_FOCUS",BI.Editor.EVENT_BLUR="EVENT_BLUR",BI.Editor.EVENT_CLICK="EVENT_CLICK",BI.Editor.EVENT_KEY_DOWN="EVENT_KEY_DOWN",BI.Editor.EVENT_SPACE="EVENT_SPACE",BI.Editor.EVENT_BACKSPACE="EVENT_BACKSPACE",BI.Editor.EVENT_START="EVENT_START",BI.Editor.EVENT_PAUSE="EVENT_PAUSE",BI.Editor.EVENT_STOP="EVENT_STOP",BI.Editor.EVENT_CONFIRM="EVENT_CONFIRM",BI.Editor.EVENT_CHANGE_CONFIRM="EVENT_CHANGE_CONFIRM",BI.Editor.EVENT_VALID="EVENT_VALID",BI.Editor.EVENT_ERROR="EVENT_ERROR",BI.Editor.EVENT_ENTER="EVENT_ENTER",BI.Editor.EVENT_RESTRICT="EVENT_RESTRICT",BI.Editor.EVENT_REMOVE="EVENT_REMOVE",BI.Editor.EVENT_EMPTY="EVENT_EMPTY",BI.shortcut("bi.editor",BI.Editor)},function(e,t){BI.MultifileEditor=BI.inherit(BI.Widget,{_defaultConfig:function(){var e=BI.MultifileEditor.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{baseCls:(e.baseCls||"")+" bi-multifile-editor",multiple:!1,maxSize:-1,accept:"",url:""})},_init:function(){var e=this,t=this.options;BI.MultifileEditor.superclass._init.apply(this,arguments),this.file=BI.createWidget({type:"bi.file",cls:"multifile-editor",width:"100%",height:"100%",name:t.name,url:t.url,multiple:t.multiple,accept:t.accept,maxSize:t.maxSize,title:t.title}),this.file.on(BI.File.EVENT_CHANGE,function(){e.fireEvent(BI.MultifileEditor.EVENT_CHANGE,arguments)}),this.file.on(BI.File.EVENT_UPLOADSTART,function(){e.fireEvent(BI.MultifileEditor.EVENT_UPLOADSTART,arguments)}),this.file.on(BI.File.EVENT_ERROR,function(){e.fireEvent(BI.MultifileEditor.EVENT_ERROR,arguments)}),this.file.on(BI.File.EVENT_PROGRESS,function(){e.fireEvent(BI.MultifileEditor.EVENT_PROGRESS,arguments)}),this.file.on(BI.File.EVENT_UPLOADED,function(){e.fireEvent(BI.MultifileEditor.EVENT_UPLOADED,arguments)}),BI.createWidget({type:"bi.absolute",element:this,items:[{el:{type:"bi.adaptive",scrollable:!1,items:[this.file]},top:0,right:0,left:0,bottom:0}]})},_reset:function(){this.file.reset()},select:function(){this.file.select()},getValue:function(){return this.file.getValue()},upload:function(){this._reset(),this.file.upload()},reset:function(){this._reset()}}),BI.MultifileEditor.EVENT_CHANGE="EVENT_CHANGE",BI.MultifileEditor.EVENT_UPLOADSTART="EVENT_UPLOADSTART",BI.MultifileEditor.EVENT_ERROR="EVENT_ERROR",BI.MultifileEditor.EVENT_PROGRESS="EVENT_PROGRESS",BI.MultifileEditor.EVENT_UPLOADED="EVENT_UPLOADED",BI.shortcut("bi.multifile_editor",BI.MultifileEditor)},function(e,t){BI.TextAreaEditor=BI.inherit(BI.Single,{_defaultConfig:function(){return BI.extend(BI.TextAreaEditor.superclass._defaultConfig.apply(),{baseCls:"bi-textarea-editor",value:"",errorText:"",validationChecker:function(){return!0}})},render:function(){var e=this.options,t=this;this.content=BI.createWidget({type:"bi.layout",tagName:"textarea",width:"100%",height:"100%",cls:"bi-textarea textarea-editor-content display-block"}),this.content.element.css({resize:"none"}),BI.createWidget({type:"bi.absolute",element:this,items:[{el:{type:"bi.adaptive",items:[this.content]},left:4,right:4,top:4,bottom:4}]}),this.content.element.on("input propertychange",function(e){t._checkError(),t._checkWaterMark(),t.fireEvent(BI.TextAreaEditor.EVENT_CHANGE)}),this.content.element.focus(function(){t._checkError(),t._focus(),t.fireEvent(BI.TextAreaEditor.EVENT_FOCUS),BI.Widget._renderEngine.createElement(document).bind("mousedown."+t.getName(),function(e){BI.DOM.isExist(t)&&!t.element.__isMouseInBounds__(e)&&(BI.Widget._renderEngine.createElement(document).unbind("mousedown."+t.getName()),t.content.element.blur())})}),this.content.element.blur(function(){t._setErrorVisible(!1),t._blur(),t.fireEvent(BI.TextAreaEditor.EVENT_BLUR),BI.Widget._renderEngine.createElement(document).unbind("mousedown."+t.getName())}),BI.isKey(e.value)&&this.setValue(e.value),BI.isNotNull(e.style)&&this.setStyle(e.style),this._checkWaterMark()},_checkWaterMark:function(){var e=this,t=this.options,n=this.getValue();BI.isNotEmptyString(n)?(this.watermark&&this.watermark.destroy(),this.watermark=null):BI.isNotEmptyString(t.watermark)&&(this.watermark?(this.watermark.setText(t.watermark),this.watermark.setValid(!t.invalid),this.watermark.setEnable(!t.disabled)):(this.watermark=BI.createWidget({type:"bi.text_button",cls:"bi-water-mark cursor-default textarea-watermark",textAlign:"left",whiteSpace:"normal",text:t.watermark,invalid:t.invalid,disabled:t.disabled,hgap:4,vgap:4}),this.watermark.on(BI.TextButton.EVENT_CHANGE,function(){e.focus()}),BI.createWidget({type:"bi.absolute",element:this,items:[{el:this.watermark,left:0,top:0,right:0}]})))},_checkError:function(){this._setErrorVisible(this.isEnabled()&&!this.options.validationChecker(this.getValue()))},_focus:function(){this.content.element.addClass("textarea-editor-focus"),this._checkWaterMark()},_blur:function(){this.content.element.removeClass("textarea-editor-focus"),this._checkWaterMark()},_setErrorVisible:function(e){var t=this.options.errorText;if(BI.isFunction(t)&&(t=t(BI.trim(this.getValue()))),!this.disabledError&&BI.isKey(t))return BI.Bubbles[e?"show":"hide"](this.getName(),t,this,{adjustYOffset:2}),BI.Bubbles.get(this.getName())},focus:function(){this._focus(),this.content.element.focus()},blur:function(){this._blur(),this.content.element.blur()},getValue:function(){return this.content.element.val()},setValue:function(e){this.content.element.val(e),this._checkError(),this._checkWaterMark()},setStyle:function(e){this.style=e,this.element.css(e),this.content.element.css(BI.extend({},e,{color:e.color||BI.DOM.getContrastColor(BI.DOM.isRGBColor(e.backgroundColor)?BI.DOM.rgb2hex(e.backgroundColor):e.backgroundColor)}))},getStyle:function(){return this.style},setWatermark:function(e){this.options.watermark=e,this._checkWaterMark()},_setValid:function(e){BI.TextAreaEditor.superclass._setValid.apply(this,arguments)},_setEnable:function(e){BI.TextAreaEditor.superclass._setEnable.apply(this,[e]),this.content&&(this.content.element[0].disabled=!e)}}),BI.TextAreaEditor.EVENT_CHANGE="EVENT_CHANGE",BI.TextAreaEditor.EVENT_BLUR="EVENT_BLUR",BI.TextAreaEditor.EVENT_FOCUS="EVENT_FOCUS",BI.shortcut("bi.textarea_editor",BI.TextAreaEditor)},function(e,t){BI.Html=BI.inherit(BI.Single,{props:{baseCls:"bi-html",textAlign:"left",whiteSpace:"normal",lineHeight:null,handler:null,hgap:0,vgap:0,lgap:0,rgap:0,tgap:0,bgap:0,text:"",highLight:!1},render:function(){var e=this,t=this.options;0i.pages?i.pages:e,this.currPage=e),this._populate()},getValue:function(){var e=this.button_group.getValue()[0];switch(e){case"prev":return-1;case"next":return 1;case"first":return BI.MIN;case"last":return BI.MAX;default:return e}},attr:function(e,t){BI.DetailPager.superclass.attr.apply(this,arguments),"curr"===e&&(this.currPage=BI.result(this.options,"curr"))},populate:function(){this._populate()}}),BI.DetailPager.EVENT_CHANGE="EVENT_CHANGE",BI.DetailPager.EVENT_AFTER_POPULATE="EVENT_AFTER_POPULATE",BI.shortcut("bi.detail_pager",BI.DetailPager)},function(e,t){BI.SegmentButton=BI.inherit(BI.BasicButton,{_defaultConfig:function(){var e=BI.SegmentButton.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{baseCls:(e.baseCls||"")+" bi-segment-button bi-list-item-select",shadow:!0,readonly:!0,hgap:5})},_init:function(){BI.SegmentButton.superclass._init.apply(this,arguments);var e=this.options;this.text=BI.createWidget({type:"bi.label",element:this,textHeight:e.height,whiteSpace:e.whiteSpace,text:e.text,value:e.value,hgap:e.hgap})},setSelected:function(){BI.SegmentButton.superclass.setSelected.apply(this,arguments)},setText:function(e){BI.SegmentButton.superclass.setText.apply(this,arguments),this.text.setText(e)},destroy:function(){BI.SegmentButton.superclass.destroy.apply(this,arguments)}}),BI.shortcut("bi.segment_button",BI.SegmentButton)},function(e,t){BI.Segment=BI.inherit(BI.Widget,{_defaultConfig:function(){return BI.extend(BI.Segment.superclass._defaultConfig.apply(this,arguments),{baseCls:"bi-segment",items:[],height:24})},_init:function(){BI.Segment.superclass._init.apply(this,arguments);var n=this,e=this.options;this.buttonGroup=BI.createWidget({element:this,type:"bi.button_group",value:e.value,items:BI.createItems(e.items,{type:"bi.segment_button",height:e.height-2,whiteSpace:e.whiteSpace}),layout:[{type:"bi.center"}]}),this.buttonGroup.on(BI.Controller.EVENT_CHANGE,function(){n.fireEvent(BI.Controller.EVENT_CHANGE,arguments)}),this.buttonGroup.on(BI.ButtonGroup.EVENT_CHANGE,function(e,t){n.fireEvent(BI.Segment.EVENT_CHANGE,e,t)})},_setEnable:function(e){BI.Segment.superclass._setEnable.apply(this,arguments),!0===e?this.element.removeClass("base-disabled disabled"):!1===e&&this.element.addClass("base-disabled disabled")},setValue:function(e){this.buttonGroup.setValue(e)},setEnabledValue:function(e){this.buttonGroup.setEnabledValue(e)},getValue:function(){return this.buttonGroup.getValue()}}),BI.Segment.EVENT_CHANGE="EVENT_CHANGE",BI.shortcut("bi.segment",BI.Segment)},function(e,t){BI.MultiSelectBar=BI.inherit(BI.BasicButton,{_defaultConfig:function(){return BI.extend(BI.MultiSelectBar.superclass._defaultConfig.apply(this,arguments),{extraCls:"bi-multi-select-bar",height:25,text:BI.i18nText("BI-Select_All"),isAllCheckedBySelectedValue:BI.emptyFn,disableSelected:!0,isHalfCheckedBySelectedValue:function(e){return 0BI.parseDateTime(e.min,"%Y-%X-%d").getFullYear();return this.left.setEnable(t),t},_checkRightValid:function(){var e=this.options,t=this._year=this.options.min&&t<=this.options.max},_monthCheck:function(e){var t=BI.parseDateTime(e,this._getFormatString()),n=BI.print(t,this._const.compareFormat);return 0<=t.getMonth()&&(BI.print(BI.parseDateTime(e,"%Y-%X"),"%Y-%X")===e||BI.print(BI.parseDateTime(e,"%Y-%x"),"%Y-%x")===e)&&n>=this.options.min&&n<=this.options.max},_setInnerValue:function(e){var t=BI.print(e,this._getFormatString());this.editor.setState(t),this.editor.setValue(t)},_getText:function(e){var t="",n="";return BI.isNotNull(e.year)&&(0!==BI.parseInt(e.year)&&(t+=Math.abs(e.year)+BI.i18nText("BI-Basic_Year")+(e.year<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=i(BI.i18nText("BI-Basic_Year"),e.position)),BI.isNotNull(e.quarter)&&(0!==BI.parseInt(e.quarter)&&(t+=Math.abs(e.quarter)+BI.i18nText("BI-Basic_Single_Quarter")+(e.quarter<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=i(BI.i18nText("BI-Basic_Single_Quarter"),e.position)),BI.isNotNull(e.month)&&(0!==BI.parseInt(e.month)&&(t+=Math.abs(e.month)+BI.i18nText("BI-Basic_Month")+(e.month<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=i(BI.i18nText("BI-Basic_Month"),e.position)),BI.isNotNull(e.week)&&(0!==BI.parseInt(e.week)&&(t+=Math.abs(e.week)+BI.i18nText("BI-Basic_Week")+(e.week<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=i(BI.i18nText("BI-Basic_Week"),e.position)),BI.isNotNull(e.day)&&(0!==BI.parseInt(e.day)&&(t+=Math.abs(e.day)+BI.i18nText("BI-Basic_Day")+(e.day<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=1===BI.size(e)?i(BI.i18nText("BI-Basic_Month"),e.position):""),BI.isNotNull(e.workDay)&&0!==BI.parseInt(e.workDay)&&(t+=Math.abs(e.workDay)+BI.i18nText("BI-Basic_Work_Day")+(e.workDay<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),t+n;function i(e,t){switch(t){case BI.DynamicDateCard.OFFSET.BEGIN:return e+BI.i18nText("BI-Basic_Begin_Start");case BI.DynamicDateCard.OFFSET.END:return e+BI.i18nText("BI-Basic_End_Stop");case BI.DynamicDateCard.OFFSET.CURRENT:default:return BI.i18nText("BI-Basic_Current_Day")}}},setValue:function(e){var t,n,i,r=BI.getDate();switch(this.storeValue=e,BI.isNotNull(e)&&(t=e.type||BI.DynamicDateCombo.Static,n=e.value||e),t){case BI.DynamicDateCombo.Dynamic:var a=this._getText(n),r=BI.DynamicDateHelper.getCalculation(n);this._setInnerValue(r,a);break;case BI.DynamicDateCombo.Static:default:BI.isNull(n)||BI.isNull(n.day)?(this.editor.setState(""),this.editor.setValue("")):(i=BI.print(BI.getDate(n.year,n.month-1,n.day),this._getFormatString()),this.editor.setState(i),this.editor.setValue(i))}},setMinDate:function(e){BI.isNotEmptyString(this.options.min)&&(this.options.min=e)},setMaxDate:function(e){BI.isNotEmptyString(this.options.max)&&(this.options.max=e)},getKey:function(){return this.editor.getValue()},getValue:function(){return this.storeValue}}),BI.DynamicDateTrigger.EVENT_BLUR="EVENT_BLUR",BI.DynamicDateTrigger.EVENT_FOCUS="EVENT_FOCUS",BI.DynamicDateTrigger.EVENT_START="EVENT_START",BI.DynamicDateTrigger.EVENT_STOP="EVENT_STOP",BI.DynamicDateTrigger.EVENT_CONFIRM="EVENT_CONFIRM",BI.DynamicDateTrigger.EVENT_CHANGE="EVENT_CHANGE",BI.DynamicDateTrigger.EVENT_VALID="EVENT_VALID",BI.DynamicDateTrigger.EVENT_ERROR="EVENT_ERROR",BI.DynamicDateTrigger.EVENT_TRIGGER_CLICK="EVENT_TRIGGER_CLICK",BI.DynamicDateTrigger.EVENT_KEY_DOWN="EVENT_KEY_DOWN",BI.shortcut("bi.dynamic_date_trigger",BI.DynamicDateTrigger)},function(e,t){BI.DynamicDateTimeCombo=BI.inherit(BI.Single,{constants:{popupHeight:259,popupWidth:270,comboAdjustHeight:1,border:1},props:{baseCls:"bi-dynamic-date-combo bi-border bi-focus-shadow bi-border-radius",height:22,minDate:"1900-01-01",maxDate:"2099-12-31",format:"",allowEdit:!0},render:function(){var n=this,e=this.options;this.storeTriggerValue="";var t=BI.getDate();return this.storeValue=e.value,{type:"bi.htape",items:[{el:{type:"bi.icon_button",cls:"bi-trigger-icon-button date-change-h-font",width:e.height,height:e.height,ref:function(){n.changeIcon=this}},width:e.height},{type:"bi.absolute",items:[{el:{type:"bi.combo",destroyWhenHide:!0,container:e.container,ref:function(){n.combo=this},toggle:!1,isNeedAdjustHeight:!1,isNeedAdjustWidth:!1,el:{type:"bi.dynamic_date_time_trigger",min:e.minDate,max:e.maxDate,allowEdit:e.allowEdit,watermark:e.watermark,format:e.format,height:e.height,value:e.value,ref:function(){n.trigger=this},listeners:[{eventName:BI.DynamicDateTimeTrigger.EVENT_KEY_DOWN,action:function(){n.combo.isViewVisible()&&n.combo.hideView(),n.fireEvent(BI.DynamicDateTimeCombo.EVENT_KEY_DOWN,arguments)}},{eventName:BI.DynamicDateTimeTrigger.EVENT_STOP,action:function(){n.combo.isViewVisible()||n.combo.showView()}},{eventName:BI.DynamicDateTimeTrigger.EVENT_TRIGGER_CLICK,action:function(){n.combo.toggle()}},{eventName:BI.DynamicDateTimeTrigger.EVENT_FOCUS,action:function(){n.storeTriggerValue=n.trigger.getKey(),n.combo.isViewVisible()||n.combo.showView(),n.fireEvent(BI.DynamicDateTimeCombo.EVENT_FOCUS)}},{eventName:BI.DynamicDateTimeTrigger.EVENT_BLUR,action:function(){n.fireEvent(BI.DynamicDateTimeCombo.EVENT_BLUR)}},{eventName:BI.DynamicDateTimeTrigger.EVENT_ERROR,action:function(){n.storeValue={type:BI.DynamicDateTimeCombo.Static,value:{year:t.getFullYear(),month:t.getMonth()+1}},n.fireEvent(BI.DynamicDateTimeCombo.EVENT_ERROR)}},{eventName:BI.DynamicDateTimeTrigger.EVENT_VALID,action:function(){n.fireEvent(BI.DynamicDateTimeCombo.EVENT_VALID)}},{eventName:BI.DynamicDateTimeTrigger.EVENT_CHANGE,action:function(){n.fireEvent(BI.DynamicDateTimeCombo.EVENT_CHANGE)}},{eventName:BI.DynamicDateTimeTrigger.EVENT_CONFIRM,action:function(){var e,t;n.combo.isViewVisible()||(e=n.storeTriggerValue,t=n.trigger.getKey(),BI.isNotEmptyString(t)&&!BI.isEqual(t,e)?(n.storeValue=n.trigger.getValue(),n.setValue(n.trigger.getValue())):BI.isEmptyString(t)&&(n.storeValue=null,n.trigger.setValue()),n._checkDynamicValue(n.storeValue),n.fireEvent(BI.DynamicDateTimeCombo.EVENT_CONFIRM))}}]},adjustLength:this.constants.comboAdjustHeight,popup:{el:{type:"bi.dynamic_date_time_popup",behaviors:e.behaviors,min:e.minDate,max:e.maxDate,ref:function(){n.popup=this},listeners:[{eventName:BI.DynamicDateTimePopup.BUTTON_CLEAR_EVENT_CHANGE,action:function(){n.setValue(),n.combo.hideView(),n.fireEvent(BI.DynamicDateTimeCombo.EVENT_CONFIRM)}},{eventName:BI.DynamicDateTimePopup.BUTTON_lABEL_EVENT_CHANGE,action:function(){var e=BI.getDate();n.setValue({type:BI.DynamicDateTimeCombo.Static,value:{year:e.getFullYear(),month:e.getMonth()+1,day:e.getDate(),hour:0,minute:0,second:0}}),n.combo.hideView(),n.fireEvent(BI.DynamicDateTimeCombo.EVENT_CONFIRM)}},{eventName:BI.DynamicDateTimePopup.BUTTON_OK_EVENT_CHANGE,action:function(){var e=n.popup.getValue();n._checkValue(e)&&n.setValue(e),n.combo.hideView(),n.fireEvent(BI.DynamicDateTimeCombo.EVENT_CONFIRM)}},{eventName:BI.DynamicDateTimePopup.EVENT_CHANGE,action:function(){n.setValue(n.popup.getValue()),n.combo.hideView(),n.fireEvent(BI.DynamicDateTimeCombo.EVENT_CONFIRM)}}]},stopPropagation:!1},listeners:[{eventName:BI.Combo.EVENT_BEFORE_POPUPVIEW,action:function(){n.popup.setValue(n.storeValue),n.popup.setMinDate(e.minDate),n.popup.setMaxDate(e.maxDate),n.fireEvent(BI.DynamicDateTimeCombo.EVENT_BEFORE_POPUPVIEW)}}],hideChecker:function(e){return 0===n.triggerBtn.element.find(e.target).length}},top:0,left:0,right:0,bottom:0},{el:{type:"bi.icon_button",cls:"bi-trigger-icon-button date-font",width:e.height,height:e.height,listeners:[{eventName:BI.IconButton.EVENT_CHANGE,action:function(){n.combo.isViewVisible()||n.combo.showView()}}],ref:function(){n.triggerBtn=this}},top:0,right:0}]}],ref:function(e){n.comboWrapper=e}}},mounted:function(){this._checkDynamicValue(this.storeValue)},_checkDynamicValue:function(e){var t=this.options,n=null;switch(BI.isNotNull(e)&&(n=e.type),n){case BI.DynamicDateTimeCombo.Dynamic:this.changeIcon.setVisible(!0),this.comboWrapper.attr("items")[0].width=t.height,this.comboWrapper.resize();break;default:this.comboWrapper.attr("items")[0].width=0,this.comboWrapper.resize(),this.changeIcon.setVisible(!1)}},_checkValue:function(e){switch(e.type){case BI.DynamicDateCombo.Dynamic:return BI.isNotEmptyObject(e.value);case BI.DynamicDateCombo.Static:default:return!0}},setMinDate:function(e){this.options.minDate=e,this.trigger.setMinDate(e),this.popup&&this.popup.setMinDate(e)},setMaxDate:function(e){this.options.maxDate=e,this.trigger.setMaxDate(e),this.popup&&this.popup.setMaxDate(e)},setValue:function(e){this.storeValue=e,this.trigger.setValue(e),this._checkDynamicValue(e)},getValue:function(){return this.storeValue},getKey:function(){return this.trigger.getKey()},hidePopupView:function(){this.combo.hideView()},isValid:function(){return this.trigger.isValid()}}),BI.DynamicDateTimeCombo.EVENT_KEY_DOWN="EVENT_KEY_DOWN",BI.DynamicDateTimeCombo.EVENT_CONFIRM="EVENT_CONFIRM",BI.DynamicDateTimeCombo.EVENT_FOCUS="EVENT_FOCUS",BI.DynamicDateTimeCombo.EVENT_BLUR="EVENT_BLUR",BI.DynamicDateTimeCombo.EVENT_CHANGE="EVENT_CHANGE",BI.DynamicDateTimeCombo.EVENT_VALID="EVENT_VALID",BI.DynamicDateTimeCombo.EVENT_ERROR="EVENT_ERROR",BI.DynamicDateTimeCombo.EVENT_BEFORE_POPUPVIEW="EVENT_BEFORE_POPUPVIEW",BI.shortcut("bi.dynamic_date_time_combo",BI.DynamicDateTimeCombo),BI.extend(BI.DynamicDateTimeCombo,{Static:1,Dynamic:2})},function(e,t){BI.DynamicDateTimePopup=BI.inherit(BI.Widget,{constants:{tabHeight:30,buttonHeight:24},props:{baseCls:"bi-dynamic-date-time-popup",width:248,height:385},_init:function(){BI.DynamicDateTimePopup.superclass._init.apply(this,arguments);var e=this,t=this.options,n=this.constants;this.storeValue={type:BI.DynamicDateCombo.Static},BI.createWidget({element:this,type:"bi.vtape",items:[{el:this._getTabJson()},{el:{type:"bi.grid",items:[[{type:"bi.text_button",cls:"bi-high-light bi-split-top",textHeight:n.buttonHeight-1,shadow:!0,text:BI.i18nText("BI-Basic_Clear"),listeners:[{eventName:BI.TextButton.EVENT_CHANGE,action:function(){e.fireEvent(BI.DynamicDateTimePopup.BUTTON_CLEAR_EVENT_CHANGE)}}]},{type:"bi.text_button",cls:"bi-split-left bi-split-right bi-high-light bi-split-top",textHeight:n.buttonHeight-1,shadow:!0,text:BI.i18nText("BI-Multi_Date_Today"),ref:function(){e.textButton=this},listeners:[{eventName:BI.TextButton.EVENT_CHANGE,action:function(){e.fireEvent(BI.DynamicDateTimePopup.BUTTON_lABEL_EVENT_CHANGE)}}]},{type:"bi.text_button",cls:"bi-high-light bi-split-top",textHeight:n.buttonHeight-1,shadow:!0,text:BI.i18nText("BI-Basic_OK"),listeners:[{eventName:BI.TextButton.EVENT_CHANGE,action:function(){e.fireEvent(BI.DynamicDateTimePopup.BUTTON_OK_EVENT_CHANGE)}}]}]]},height:24}]}),this.setValue(t.value)},_getTabJson:function(){var t=this,n=this.options;return{type:"bi.tab",ref:function(){t.dateTab=this},tab:{type:"bi.linear_segment",cls:"bi-split-bottom",height:this.constants.tabHeight,items:BI.createItems([{text:BI.i18nText("BI-Multi_Date_YMD"),value:BI.DynamicDateCombo.Static},{text:BI.i18nText("BI-Basic_Dynamic_Title"),value:BI.DynamicDateCombo.Dynamic}],{textAlign:"center"})},cardCreator:function(e){switch(e){case BI.DynamicDateCombo.Dynamic:return{type:"bi.dynamic_date_card",listeners:[{eventName:"EVENT_CHANGE",action:function(){t._setInnerValue(t.year,e)}}],ref:function(){t.dynamicPane=this}};case BI.DynamicDateCombo.Static:default:return{type:"bi.vtape",items:[{type:"bi.date_calendar_popup",behaviors:n.behaviors,min:t.options.min,max:t.options.max,ref:function(){t.ymd=this}},{el:{type:"bi.dynamic_date_time_select",cls:"bi-split-top",ref:function(){t.timeSelect=this}},height:40}]}}},listeners:[{eventName:BI.Tab.EVENT_CHANGE,action:function(){switch(t.dateTab.getSelect()){case BI.DynamicDateCombo.Static:var e=BI.DynamicDateHelper.getCalculation(t.dynamicPane.getValue());t.ymd.setValue({year:e.getFullYear(),month:e.getMonth()+1,day:e.getDate()}),t.timeSelect.setValue(),t._setInnerValue();break;case BI.DynamicDateCombo.Dynamic:default:t.storeValue&&t.storeValue.type===BI.DynamicDateCombo.Dynamic?t.dynamicPane.setValue(t.storeValue.value):t.dynamicPane.setValue({year:0}),t._setInnerValue()}}}]}},_setInnerValue:function(){var e;this.dateTab.getSelect()===BI.DynamicDateCombo.Static?(this.textButton.setValue(BI.i18nText("BI-Multi_Date_Today")),this.textButton.setEnable(!0)):(e=BI.DynamicDateHelper.getCalculation(this.dynamicPane.getValue()),e=BI.print(e,"%Y-%X-%d"),this.textButton.setValue(e),this.textButton.setEnable(!1))},_checkValueValid:function(e){return BI.isNull(e)||BI.isEmptyObject(e)||BI.isEmptyString(e)},setMinDate:function(e){this.options.min!==e&&(this.options.min=e,this.ymd.setMinDate(e))},setMaxDate:function(e){this.options.max!==e&&(this.options.max=e,this.ymd.setMaxDate(e))},setValue:function(e){this.storeValue=e;var t,n=(e=e||{}).type||BI.DynamicDateCombo.Static,i=e.value||e;switch(this.dateTab.setSelect(n),n){case BI.DynamicDateCombo.Dynamic:this.dynamicPane.setValue(i),this._setInnerValue();break;case BI.DynamicDateCombo.Static:default:this._checkValueValid(i)?(t=BI.getDate(),this.ymd.setValue({year:t.getFullYear(),month:t.getMonth()+1,day:t.getDate()}),this.timeSelect.setValue()):(this.ymd.setValue(i),this.timeSelect.setValue({hour:i.hour,minute:i.minute,second:i.second})),this.textButton.setValue(BI.i18nText("BI-Multi_Date_Today")),this.textButton.setEnable(!0)}},getValue:function(){var e=this.dateTab.getSelect();return{type:e,value:e===BI.DynamicDateTimeCombo.Static?BI.extend(this.ymd.getValue(),this.timeSelect.getValue()):this.dynamicPane.getValue()}}}),BI.DynamicDateTimePopup.EVENT_CHANGE="EVENT_CHANGE",BI.DynamicDateTimePopup.BUTTON_OK_EVENT_CHANGE="BUTTON_OK_EVENT_CHANGE",BI.DynamicDateTimePopup.BUTTON_lABEL_EVENT_CHANGE="BUTTON_lABEL_EVENT_CHANGE",BI.DynamicDateTimePopup.BUTTON_CLEAR_EVENT_CHANGE="BUTTON_CLEAR_EVENT_CHANGE",BI.shortcut("bi.dynamic_date_time_popup",BI.DynamicDateTimePopup)},function(e,t){BI.DynamicDateTimeSelect=BI.inherit(BI.Widget,{props:{baseCls:"bi-date-time-select"},render:function(){var t=this;return{type:"bi.center_adapt",items:[{type:"bi.vertical_adapt",items:[{el:{type:"bi.number_editor",ref:function(){t.hour=this},validationChecker:function(e){return BI.isNaturalNumber(e)&&BI.parseInt(e)<24},errorText:function(e){return BI.isNumeric(e)?BI.i18nText("BI-Basic_Input_From_To_Number",'"00-23"'):BI.i18nText("BI-Numerical_Interval_Input_Data")},listeners:[{eventName:BI.SignEditor.EVENT_CONFIRM,action:function(){var e=this.getValue();t._checkHour(e),this.setValue(t._formatValueToDoubleDigit(e)),t.fireEvent(BI.DynamicDateTimeSelect.EVENT_CONFIRM)}},{eventName:BI.SignEditor.EVENT_CHANGE,action:function(){var e=t._autoSwitch(this.getValue(),BI.DynamicDateTimeSelect.HOUR);this.setValue(e)}}],width:60,height:24}},{type:"bi.label",text:":",width:20},{type:"bi.number_editor",ref:function(){t.minute=this},validationChecker:function(e){return BI.isNaturalNumber(e)&&BI.parseInt(e)<60},errorText:function(e){return BI.isNumeric(e)?BI.i18nText("BI-Basic_Input_From_To_Number",'"00-59"'):BI.i18nText("BI-Numerical_Interval_Input_Data")},listeners:[{eventName:BI.SignEditor.EVENT_CONFIRM,action:function(){var e=this.getValue();t._checkMinute(e),this.setValue(t._formatValueToDoubleDigit(e),BI.DynamicDateTimeSelect.MINUTE),t.fireEvent(BI.DynamicDateTimeSelect.EVENT_CONFIRM)}},{eventName:BI.SignEditor.EVENT_CHANGE,action:function(){var e=t._autoSwitch(this.getValue(),BI.DynamicDateTimeSelect.MINUTE);this.setValue(e)}}],width:60,height:24},{type:"bi.label",text:":",width:20},{type:"bi.number_editor",ref:function(){t.second=this},validationChecker:function(e){return BI.isNaturalNumber(e)&&BI.parseInt(e)<60},errorText:function(e){return BI.isNumeric(e)?BI.i18nText("BI-Basic_Input_From_To_Number",'"00-59"'):BI.i18nText("BI-Numerical_Interval_Input_Data")},listeners:[{eventName:BI.SignEditor.EVENT_CONFIRM,action:function(){var e=this.getValue();t._checkSecond(e),this.setValue(t._formatValueToDoubleDigit(e)),t.fireEvent(BI.DynamicDateTimeSelect.EVENT_CONFIRM)}}],width:60,height:24}]}]}},_checkBorder:function(e){e=e||{},this._checkHour(e.hour),this._checkMinute(e.minute),this._checkSecond(e.second)},_checkHour:function(e){this.hour.setDownEnable(0n&&(i="0"+i),2===i.length)switch(t){case BI.DynamicDateTimeSelect.HOUR:this.hour.isEditing()&&this.minute.focus();break;case BI.DynamicDateTimeSelect.MINUTE:this.minute.isEditing()&&this.second.focus();break;case BI.DynamicDateTimeSelect.SECOND:}return i},_formatValueToDoubleDigit:function(e){(BI.isNull(e)||BI.isEmptyString(e))&&(e=0);var t=BI.parseInt(e);return t<10&&(t="0"+t),t},_assertValue:function(e){return(e=e||{}).hour=this._formatValueToDoubleDigit(e.hour)||"00",e.minute=this._formatValueToDoubleDigit(e.minute)||"00",e.second=this._formatValueToDoubleDigit(e.second)||"00",e},getValue:function(){return{hour:BI.parseInt(this.hour.getValue()),minute:BI.parseInt(this.minute.getValue()),second:BI.parseInt(this.second.getValue())}},setValue:function(e){e=this._assertValue(e),this.hour.setValue(e.hour),this.minute.setValue(e.minute),this.second.setValue(e.second),this._checkBorder(e)}}),BI.DynamicDateTimeSelect.EVENT_CONFIRM="EVENT_CONFIRM",BI.shortcut("bi.dynamic_date_time_select",BI.DynamicDateTimeSelect),BI.extend(BI.DynamicDateTimeSelect,{HOUR:1,MINUTE:2,SECOND:3})},function(e,t){BI.DynamicDateTimeTrigger=BI.inherit(BI.Trigger,{_const:{hgap:4,vgap:2,yearLength:4,yearMonthLength:6,yearFullMonthLength:7,compareFormat:"%Y-%X-%d %H:%M:%S"},props:{extraCls:"bi-date-time-trigger",min:"1900-01-01",max:"2099-12-31",height:24,format:"",allowEdit:!0,watermark:""},_init:function(){BI.DynamicDateTimeTrigger.superclass._init.apply(this,arguments);var i=this,r=this.options,e=this._const;this.storeTriggerValue="",this.editor=BI.createWidget({type:"bi.sign_editor",height:r.height,validationChecker:function(e){var t=i._getStandardDateStr(e),n=t.match(/\d+/g);return BI.isKey(r.format)||i._autoAppend(e,n),i._dateCheck(t)&&BI.checkDateLegal(t)&&i._checkVoid({year:0|n[0],month:0|n[1],day:0|n[2]})},quitChecker:function(){return!1},hgap:e.hgap,vgap:e.vgap,allowBlank:!0,watermark:BI.isKey(r.watermark)?r.watermark:BI.i18nText("BI-Basic_Unrestricted"),errorText:function(){var e="";return BI.isKey(r.format)||(e=i.editor.isEditing()?BI.i18nText("BI-Basic_Date_Time_Error_Text"):BI.i18nText("BI-Year_Trigger_Invalid_Text")),e},title:BI.bind(this._getTitle,this)}),this.editor.on(BI.SignEditor.EVENT_KEY_DOWN,function(){i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_KEY_DOWN,arguments)}),this.editor.on(BI.SignEditor.EVENT_FOCUS,function(){i.storeTriggerValue=i.getKey(),i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_FOCUS)}),this.editor.on(BI.SignEditor.EVENT_BLUR,function(){i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_BLUR)}),this.editor.on(BI.SignEditor.EVENT_STOP,function(){i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_STOP)}),this.editor.on(BI.SignEditor.EVENT_VALID,function(){i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_VALID)}),this.editor.on(BI.SignEditor.EVENT_ERROR,function(){i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_ERROR)}),this.editor.on(BI.SignEditor.EVENT_CONFIRM,function(){var e,t=i.editor.getValue();BI.isNotNull(t)&&i.editor.setState(t),BI.isNotEmptyString(t)&&!BI.isEqual(i.storeTriggerValue,i.getKey())&&(e=i._getStandardDateStr(t).match(/\d+/g),i.storeValue={type:BI.DynamicDateCombo.Static,value:{year:0|e[0],month:0|e[1],day:0|e[2],hour:0|e[3],minute:0|e[4],second:0|e[5]}}),i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_CONFIRM)}),this.editor.on(BI.SignEditor.EVENT_START,function(){i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_START)}),this.editor.on(BI.SignEditor.EVENT_CHANGE,function(){i.fireEvent(BI.DynamicDateTimeTrigger.EVENT_CHANGE)}),BI.createWidget({type:"bi.htape",element:this,items:[{el:this.editor},{el:BI.createWidget(),width:24}]}),r.allowEdit||BI.createWidget({type:"bi.absolute",element:this,items:[{el:{type:"bi.text",title:BI.bind(this._getTitle,this)},left:0,right:24,top:0,bottom:0}]}),this.setValue(r.value)},_getTitle:function(){var e=this.storeValue||{},t=e.type||BI.DynamicDateCombo.Static,n=e.value;switch(t){case BI.DynamicDateCombo.Dynamic:var i=this._getText(n),r=BI.DynamicDateHelper.getCalculation(n),a=BI.print(r,this._getFormatString());return BI.isEmptyString(i)?a:i+":"+a;case BI.DynamicDateCombo.Static:default:return BI.isNull(n)||BI.isNull(n.day)?"":BI.print(BI.getDate(n.year,n.month-1,n.day,n.hour||0,n.minute||0,n.second||0),this._getFormatString())}},_getStandardDateStr:function(e){var t=this._const,n=[],i=!1,r=this._getFormatString().match(/%./g);BI.each(r,function(e,t){switch(t){case"%Y":case"%y":n[0]=e;break;case"%X":case"%x":n[1]=e;break;case"%d":case"%e":n[2]=e;break;case"%S":i=!0}});var a=BI.parseDateTime(e,this._getFormatString());BI.print(a,this._getFormatString())===e&&(e=BI.print(a,t.compareFormat),n=[0,1,2]);var o=e.match(/\d+/g)||[],s=[];BI.each(o.slice(0,3),function(e){s[e]=o[n[e]]});var l=o.slice(3);BI.each(l,function(e,t){BI.isNumeric(t)&&1===t.length&&(l[e]="0"+t)}),2!==l.length||i||l.push("00");var u=l.join(":"),c=s.slice(0,3).join("-");return BI.isNotEmptyString(u)&&(c+=" "+u),c},_getFormatString:function(){return this.options.format||this._const.compareFormat},_dateCheck:function(e){return BI.print(BI.parseDateTime(e,"%Y-%x-%d %H:%M:%S"),"%Y-%x-%d %H:%M:%S")===e||BI.print(BI.parseDateTime(e,"%Y-%X-%d %H:%M:%S"),"%Y-%X-%d %H:%M:%S")===e||BI.print(BI.parseDateTime(e,"%Y-%x-%e %H:%M:%S"),"%Y-%x-%e %H:%M:%S")===e||BI.print(BI.parseDateTime(e,"%Y-%X-%e %H:%M:%S"),"%Y-%X-%e %H:%M:%S")===e||BI.print(BI.parseDateTime(e,"%Y-%x-%d"),"%Y-%x-%d")===e||BI.print(BI.parseDateTime(e,"%Y-%X-%d"),"%Y-%X-%d")===e||BI.print(BI.parseDateTime(e,"%Y-%x-%e"),"%Y-%x-%e")===e||BI.print(BI.parseDateTime(e,"%Y-%X-%e"),"%Y-%X-%e")===e},_checkVoid:function(e){return!BI.checkDateVoid(e.year,e.month,e.day,this.options.min,this.options.max)[0]},_autoAppend:function(e,t){if(BI.isNotNull(t)&&BI.checkDateLegal(e))switch(e.length){case this._const.yearLength:this._yearCheck(e)&&this.editor.setValue(e+"-");break;case this._const.yearMonthLength:case this._const.yearFullMonthLength:var n=e.split("-")[1];(BI.isNotNull(n)&&2===n.length||this._monthCheck(e))&&this.editor.setValue(e+"-")}},_yearCheck:function(e){var t=BI.print(BI.parseDateTime(e,"%Y-%X-%d"),"%Y-%X-%d");return BI.print(BI.parseDateTime(e,"%Y"),"%Y")===e&&t>=this.options.min&&t<=this.options.max},_monthCheck:function(e){var t=BI.parseDateTime(e,"%Y-%X-%d"),n=BI.print(t,"%Y-%X-%d");return 0=this.options.min&&n<=this.options.max},_setInnerValue:function(e){var t=BI.print(e,this._getFormatString());this.editor.setState(t),this.editor.setValue(t)},_getText:function(e){var t="",n="";return BI.isNotNull(e.year)&&(0!==BI.parseInt(e.year)&&(t+=Math.abs(e.year)+BI.i18nText("BI-Basic_Year")+(e.year<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=i(BI.i18nText("BI-Basic_Year"),e.position)),BI.isNotNull(e.quarter)&&(0!==BI.parseInt(e.quarter)&&(t+=Math.abs(e.quarter)+BI.i18nText("BI-Basic_Single_Quarter")+(e.quarter<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=i(BI.i18nText("BI-Basic_Single_Quarter"),e.position)),BI.isNotNull(e.month)&&(0!==BI.parseInt(e.month)&&(t+=Math.abs(e.month)+BI.i18nText("BI-Basic_Month")+(e.month<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=i(BI.i18nText("BI-Basic_Month"),e.position)),BI.isNotNull(e.week)&&(0!==BI.parseInt(e.week)&&(t+=Math.abs(e.week)+BI.i18nText("BI-Basic_Week")+(e.week<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=i(BI.i18nText("BI-Basic_Week"),e.position)),BI.isNotNull(e.day)&&(0!==BI.parseInt(e.day)&&(t+=Math.abs(e.day)+BI.i18nText("BI-Basic_Day")+(e.day<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),n=1===BI.size(e)?i(BI.i18nText("BI-Basic_Month"),e.position):""),BI.isNotNull(e.workDay)&&0!==BI.parseInt(e.workDay)&&(t+=Math.abs(e.workDay)+BI.i18nText("BI-Basic_Work_Day")+(e.workDay<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),t+n;function i(e,t){switch(t){case BI.DynamicDateCard.OFFSET.BEGIN:return e+BI.i18nText("BI-Basic_Begin_Start");case BI.DynamicDateCard.OFFSET.END:return e+BI.i18nText("BI-Basic_End_Stop");case BI.DynamicDateCard.OFFSET.CURRENT:default:return BI.i18nText("BI-Basic_Current_Day")}}},setMinDate:function(e){BI.isNotEmptyString(this.options.min)&&(this.options.min=e)},setMaxDate:function(e){BI.isNotEmptyString(this.options.max)&&(this.options.max=e)},setValue:function(e){var t,n,i,r=BI.getDate();switch(this.storeValue=e,BI.isNotNull(e)&&(t=e.type||BI.DynamicDateCombo.Static,n=e.value||e),t){case BI.DynamicDateCombo.Dynamic:var a=this._getText(n),r=BI.DynamicDateHelper.getCalculation(n);this._setInnerValue(r,a);break;case BI.DynamicDateCombo.Static:default:BI.isNull(n)||BI.isNull(n.day)?(this.editor.setState(""),this.editor.setValue("")):(i=BI.print(BI.getDate(n.year,n.month-1,n.day,n.hour||0,n.minute||0,n.second||0),this._getFormatString()),this.editor.setState(i),this.editor.setValue(i))}},getKey:function(){return this.editor.getValue()},getValue:function(){return this.storeValue},isValid:function(){return this.editor.isValid()}}),BI.DynamicDateTimeTrigger.EVENT_BLUR="EVENT_BLUR",BI.DynamicDateTimeTrigger.EVENT_FOCUS="EVENT_FOCUS",BI.DynamicDateTimeTrigger.EVENT_START="EVENT_START",BI.DynamicDateTimeTrigger.EVENT_STOP="EVENT_STOP",BI.DynamicDateTimeTrigger.EVENT_CONFIRM="EVENT_CONFIRM",BI.DynamicDateTimeTrigger.EVENT_CHANGE="EVENT_CHANGE",BI.DynamicDateTimeTrigger.EVENT_VALID="EVENT_VALID",BI.DynamicDateTimeTrigger.EVENT_ERROR="EVENT_ERROR",BI.DynamicDateTimeTrigger.EVENT_TRIGGER_CLICK="EVENT_TRIGGER_CLICK",BI.DynamicDateTimeTrigger.EVENT_KEY_DOWN="EVENT_KEY_DOWN",BI.shortcut("bi.dynamic_date_time_trigger",BI.DynamicDateTimeTrigger)},function(e,t){BI.SearchEditor=BI.inherit(BI.Widget,{_defaultConfig:function(){var e=BI.SearchEditor.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{baseCls:"bi-search-editor bi-border bi-focus-shadow",height:24,errorText:"",watermark:BI.i18nText("BI-Basic_Search"),validationChecker:BI.emptyFn,quitChecker:BI.emptyFn})},_init:function(){this.options.height-=2,BI.SearchEditor.superclass._init.apply(this,arguments);var t=this,e=this.options;this.editor=BI.createWidget({type:"bi.editor",height:e.height,watermark:e.watermark,allowBlank:!0,hgap:1,errorText:e.errorText,validationChecker:e.validationChecker,quitChecker:e.quitChecker,value:e.value}),this.clear=BI.createWidget({type:"bi.icon_button",stopEvent:!0,cls:"close-font"}),this.clear.on(BI.IconButton.EVENT_CHANGE,function(){t.setValue(""),t.fireEvent(BI.Controller.EVENT_CHANGE,BI.Events.STOPEDIT),t.fireEvent(BI.SearchEditor.EVENT_CHANGE),t.fireEvent(BI.SearchEditor.EVENT_CLEAR)}),BI.createWidget({element:this,type:"bi.htape",items:[{el:{type:"bi.icon_label",cls:"search-font"},width:24},{el:t.editor},{el:this.clear,width:24}]}),this.editor.on(BI.Controller.EVENT_CHANGE,function(){t.fireEvent(BI.Controller.EVENT_CHANGE,arguments)}),this.editor.on(BI.Editor.EVENT_FOCUS,function(){t.fireEvent(BI.SearchEditor.EVENT_FOCUS)}),this.editor.on(BI.Editor.EVENT_BLUR,function(){t.fireEvent(BI.SearchEditor.EVENT_BLUR)}),this.editor.on(BI.Editor.EVENT_CLICK,function(){t.fireEvent(BI.SearchEditor.EVENT_CLICK)}),this.editor.on(BI.Editor.EVENT_CHANGE,function(){t._checkClear(),t.fireEvent(BI.SearchEditor.EVENT_CHANGE)}),this.editor.on(BI.Editor.EVENT_KEY_DOWN,function(e){t.fireEvent(BI.SearchEditor.EVENT_KEY_DOWN,e)}),this.editor.on(BI.Editor.EVENT_SPACE,function(){t.fireEvent(BI.SearchEditor.EVENT_SPACE)}),this.editor.on(BI.Editor.EVENT_BACKSPACE,function(){t.fireEvent(BI.SearchEditor.EVENT_BACKSPACE)}),this.editor.on(BI.Editor.EVENT_VALID,function(){t.fireEvent(BI.SearchEditor.EVENT_VALID)}),this.editor.on(BI.Editor.EVENT_ERROR,function(){t.fireEvent(BI.SearchEditor.EVENT_ERROR)}),this.editor.on(BI.Editor.EVENT_ENTER,function(){t.fireEvent(BI.SearchEditor.EVENT_ENTER)}),this.editor.on(BI.Editor.EVENT_RESTRICT,function(){t.fireEvent(BI.SearchEditor.EVENT_RESTRICT)}),this.editor.on(BI.Editor.EVENT_EMPTY,function(){t._checkClear(),t.fireEvent(BI.SearchEditor.EVENT_EMPTY)}),this.editor.on(BI.Editor.EVENT_REMOVE,function(){t.fireEvent(BI.SearchEditor.EVENT_REMOVE)}),this.editor.on(BI.Editor.EVENT_CONFIRM,function(){t.fireEvent(BI.SearchEditor.EVENT_CONFIRM)}),this.editor.on(BI.Editor.EVENT_CHANGE_CONFIRM,function(){t.fireEvent(BI.SearchEditor.EVENT_CHANGE_CONFIRM)}),this.editor.on(BI.Editor.EVENT_START,function(){t.fireEvent(BI.SearchEditor.EVENT_START)}),this.editor.on(BI.Editor.EVENT_PAUSE,function(){t.fireEvent(BI.SearchEditor.EVENT_PAUSE)}),this.editor.on(BI.Editor.EVENT_STOP,function(){t.fireEvent(BI.SearchEditor.EVENT_STOP)}),this.clear.invisible()},_checkClear:function(){this.getValue()?this.clear.visible():this.clear.invisible()},setWaterMark:function(e){this.options.watermark=e,this.editor.setWaterMark(e)},focus:function(){this.editor.focus()},blur:function(){this.editor.blur()},getValue:function(){if(this.isValid())return this.editor.getValue()},getKeywords:function(){var e=this.editor.getLastChangedValue(),t=e.match(/[\S]+/g);return BI.isEndWithBlank(e)?t.concat([" "]):t},getLastValidValue:function(){return this.editor.getLastValidValue()},getLastChangedValue:function(){return this.editor.getLastChangedValue()},setValue:function(e){this.editor.setValue(e),BI.isKey(e)&&this.clear.visible()},isEditing:function(){return this.editor.isEditing()},isValid:function(){return this.editor.isValid()}}),BI.SearchEditor.EVENT_CHANGE="EVENT_CHANGE",BI.SearchEditor.EVENT_FOCUS="EVENT_FOCUS",BI.SearchEditor.EVENT_BLUR="EVENT_BLUR",BI.SearchEditor.EVENT_CLICK="EVENT_CLICK",BI.SearchEditor.EVENT_KEY_DOWN="EVENT_KEY_DOWN",BI.SearchEditor.EVENT_SPACE="EVENT_SPACE",BI.SearchEditor.EVENT_BACKSPACE="EVENT_BACKSPACE",BI.SearchEditor.EVENT_CLEAR="EVENT_CLEAR",BI.SearchEditor.EVENT_START="EVENT_START",BI.SearchEditor.EVENT_PAUSE="EVENT_PAUSE",BI.SearchEditor.EVENT_STOP="EVENT_STOP",BI.SearchEditor.EVENT_CONFIRM="EVENT_CONFIRM",BI.SearchEditor.EVENT_CHANGE_CONFIRM="EVENT_CHANGE_CONFIRM",BI.SearchEditor.EVENT_VALID="EVENT_VALID",BI.SearchEditor.EVENT_ERROR="EVENT_ERROR",BI.SearchEditor.EVENT_ENTER="EVENT_ENTER",BI.SearchEditor.EVENT_RESTRICT="EVENT_RESTRICT",BI.SearchEditor.EVENT_REMOVE="EVENT_REMOVE",BI.SearchEditor.EVENT_EMPTY="EVENT_EMPTY",BI.shortcut("bi.search_editor",BI.SearchEditor)},function(e,t){BI.SmallSearchEditor=BI.inherit(BI.SearchEditor,{_defaultConfig:function(){var e=BI.SmallSearchEditor.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{baseCls:(e.baseCls||"")+" bi-small-search-editor",height:20})},_init:function(){BI.SmallSearchEditor.superclass._init.apply(this,arguments)}}),BI.shortcut("bi.small_search_editor",BI.SmallSearchEditor)},function(e,t){BI.TextEditor=BI.inherit(BI.Widget,{_defaultConfig:function(){var e=BI.TextEditor.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{extraCls:"bi-text-editor bi-border bi-focus-shadow",hgap:4,vgap:2,lgap:0,rgap:0,tgap:0,bgap:0,validationChecker:BI.emptyFn,quitChecker:BI.emptyFn,allowBlank:!1,watermark:"",errorText:"",height:24})},_init:function(){BI.TextEditor.superclass._init.apply(this,arguments);var t=this,e=this.options;BI.isNumber(e.height)&&this.element.css({height:e.height-2}),BI.isNumber(e.width)&&this.element.css({width:e.width-2}),this.editor=BI.createWidget({type:"bi.editor",height:e.height-2,hgap:e.hgap,vgap:e.vgap,lgap:e.lgap,rgap:e.rgap,tgap:e.tgap,bgap:e.bgap,value:e.value,title:e.title,tipType:e.tipType,validationChecker:e.validationChecker,quitChecker:e.quitChecker,allowBlank:e.allowBlank,watermark:e.watermark,errorText:e.errorText}),this.editor.on(BI.Controller.EVENT_CHANGE,function(){t.fireEvent(BI.Controller.EVENT_CHANGE,arguments)}),this.editor.on(BI.Editor.EVENT_FOCUS,function(){t.fireEvent(BI.TextEditor.EVENT_FOCUS)}),this.editor.on(BI.Editor.EVENT_BLUR,function(){t.fireEvent(BI.TextEditor.EVENT_BLUR)}),this.editor.on(BI.Editor.EVENT_CLICK,function(){t.fireEvent(BI.TextEditor.EVENT_CLICK)}),this.editor.on(BI.Editor.EVENT_CHANGE,function(){t.fireEvent(BI.TextEditor.EVENT_CHANGE)}),this.editor.on(BI.Editor.EVENT_KEY_DOWN,function(e){t.fireEvent(BI.TextEditor.EVENT_KEY_DOWN)}),this.editor.on(BI.Editor.EVENT_SPACE,function(e){t.fireEvent(BI.TextEditor.EVENT_SPACE)}),this.editor.on(BI.Editor.EVENT_BACKSPACE,function(e){t.fireEvent(BI.TextEditor.EVENT_BACKSPACE)}),this.editor.on(BI.Editor.EVENT_VALID,function(){t.fireEvent(BI.TextEditor.EVENT_VALID)}),this.editor.on(BI.Editor.EVENT_CONFIRM,function(){t.fireEvent(BI.TextEditor.EVENT_CONFIRM)}),this.editor.on(BI.Editor.EVENT_CHANGE_CONFIRM,function(){t.fireEvent(BI.TextEditor.EVENT_CHANGE_CONFIRM)}),this.editor.on(BI.Editor.EVENT_REMOVE,function(e){t.fireEvent(BI.TextEditor.EVENT_REMOVE)}),this.editor.on(BI.Editor.EVENT_START,function(){t.fireEvent(BI.TextEditor.EVENT_START)}),this.editor.on(BI.Editor.EVENT_PAUSE,function(){t.fireEvent(BI.TextEditor.EVENT_PAUSE)}),this.editor.on(BI.Editor.EVENT_STOP,function(){t.fireEvent(BI.TextEditor.EVENT_STOP)}),this.editor.on(BI.Editor.EVENT_ERROR,function(){t.fireEvent(BI.TextEditor.EVENT_ERROR,arguments)}),this.editor.on(BI.Editor.EVENT_ENTER,function(){t.fireEvent(BI.TextEditor.EVENT_ENTER)}),this.editor.on(BI.Editor.EVENT_RESTRICT,function(){t.fireEvent(BI.TextEditor.EVENT_RESTRICT)}),this.editor.on(BI.Editor.EVENT_EMPTY,function(){t.fireEvent(BI.TextEditor.EVENT_EMPTY)}),BI.createWidget({type:"bi.vertical",scrolly:!1,element:this,items:[this.editor]})},setWaterMark:function(e){this.options.watermark=e,this.editor.setWaterMark(e)},focus:function(){this.editor.focus()},blur:function(){this.editor.blur()},setErrorText:function(e){this.editor.setErrorText(e)},getErrorText:function(){return this.editor.getErrorText()},isValid:function(){return this.editor.isValid()},setValue:function(e){this.editor.setValue(e)},getValue:function(){return this.editor.getValue()}}),BI.TextEditor.EVENT_CHANGE="EVENT_CHANGE",BI.TextEditor.EVENT_FOCUS="EVENT_FOCUS",BI.TextEditor.EVENT_BLUR="EVENT_BLUR",BI.TextEditor.EVENT_CLICK="EVENT_CLICK",BI.TextEditor.EVENT_KEY_DOWN="EVENT_KEY_DOWN",BI.TextEditor.EVENT_SPACE="EVENT_SPACE",BI.TextEditor.EVENT_BACKSPACE="EVENT_BACKSPACE",BI.TextEditor.EVENT_START="EVENT_START",BI.TextEditor.EVENT_PAUSE="EVENT_PAUSE",BI.TextEditor.EVENT_STOP="EVENT_STOP",BI.TextEditor.EVENT_CONFIRM="EVENT_CONFIRM",BI.TextEditor.EVENT_CHANGE_CONFIRM="EVENT_CHANGE_CONFIRM",BI.TextEditor.EVENT_VALID="EVENT_VALID",BI.TextEditor.EVENT_ERROR="EVENT_ERROR",BI.TextEditor.EVENT_ENTER="EVENT_ENTER",BI.TextEditor.EVENT_RESTRICT="EVENT_RESTRICT",BI.TextEditor.EVENT_REMOVE="EVENT_REMOVE",BI.TextEditor.EVENT_EMPTY="EVENT_EMPTY",BI.shortcut("bi.text_editor",BI.TextEditor)},function(e,t){BI.SmallTextEditor=BI.inherit(BI.TextEditor,{_defaultConfig:function(){var e=BI.SmallTextEditor.superclass._defaultConfig.apply(this,arguments);return BI.extend(e,{baseCls:(e.baseCls||"")+" bi-small-text-editor",height:20})},_init:function(){BI.SmallTextEditor.superclass._init.apply(this,arguments)}}),BI.shortcut("bi.small_text_editor",BI.SmallTextEditor)},function(e,t){BI.IntervalSlider=BI.inherit(BI.Single,{_constant:{EDITOR_WIDTH:58,EDITOR_R_GAP:60,EDITOR_HEIGHT:30,SLIDER_WIDTH_HALF:15,SLIDER_WIDTH:30,SLIDER_HEIGHT:30,TRACK_HEIGHT:24},props:{baseCls:"bi-interval-slider bi-slider-track",digit:!1,unit:""},render:function(){var r=this,e=this._constant;return this.enable=!1,this.valueOne="",this.valueTwo="",this.calculation=new BI.AccurateCalculationModel,this.grayTrack=BI.createWidget({type:"bi.layout",cls:"gray-track",height:6}),this.blueTrack=BI.createWidget({type:"bi.layout",cls:"blue-track bi-high-light-background",height:6}),this.track=this._createTrackWrapper(),this.labelOne=BI.createWidget({type:"bi.sign_text_editor",cls:"slider-editor-button",text:this.options.unit,allowBlank:!1,width:e.EDITOR_WIDTH,validationChecker:function(e){return r._checkValidation(e)}}),this.labelOne.element.hover(function(){r.labelOne.element.removeClass("bi-border").addClass("bi-border")},function(){r.labelOne.element.removeClass("bi-border")}),this.labelOne.on(BI.Editor.EVENT_CONFIRM,function(){var e=r.valueOne,t=BI.parseFloat(this.getValue());r.valueOne=t;var n=r._getPercentByValue(t),i=BI.parseFloat(n.toFixed(1));r._setSliderOnePosition(i),r._setBlueTrack(),r._checkLabelPosition(e,r.valueTwo,r.valueOne,r.valueTwo),r.fireEvent(BI.IntervalSlider.EVENT_CHANGE)}),this.labelTwo=BI.createWidget({type:"bi.sign_text_editor",cls:"slider-editor-button",text:this.options.unit,allowBlank:!1,width:e.EDITOR_WIDTH,validationChecker:function(e){return r._checkValidation(e)}}),this.labelTwo.element.hover(function(){r.labelTwo.element.removeClass("bi-border").addClass("bi-border")},function(){r.labelTwo.element.removeClass("bi-border")}),this.labelTwo.on(BI.Editor.EVENT_CONFIRM,function(){var e=r.valueTwo,t=BI.parseFloat(this.getValue());r.valueTwo=t;var n=r._getPercentByValue(t),i=BI.parseFloat(n.toFixed(1));r._setSliderTwoPosition(i),r._setBlueTrack(),r._checkLabelPosition(r.valueOne,e,r.valueOne,r.valueTwo),r.fireEvent(BI.IntervalSlider.EVENT_CHANGE)}),this.sliderOne=BI.createWidget({type:"bi.single_slider_button"}),this.sliderTwo=BI.createWidget({type:"bi.single_slider_button"}),this._draggable(this.sliderOne,!0),this._draggable(this.sliderTwo,!1),this._setVisible(!1),{type:"bi.absolute",element:this,items:[{el:{type:"bi.vertical",items:[{type:"bi.absolute",items:[{el:this.track,width:"100%",height:e.TRACK_HEIGHT}]}],hgap:7,height:e.TRACK_HEIGHT},top:23,left:0,width:"100%"},this._createLabelWrapper(),this._createSliderWrapper()]}},_rePosBySizeAfterMove:function(e,t){var n=this.options,i=100*e/this._getGrayTrackLength(),r=BI.parseFloat(i.toFixed(1)),a=this._getValueByPercent(r),a=this._assertValue(a);a=!1===n.digit?a:a.toFixed(n.digit);var o=this.valueOne,s=this.valueTwo;t?(this._setSliderOnePosition(r),this.labelOne.setValue(a),this.valueOne=a,this._checkLabelPosition(o,s,a,this.valueTwo)):(this._setSliderTwoPosition(r),this.labelTwo.setValue(a),this.valueTwo=a,this._checkLabelPosition(o,s,this.valueOne,a)),this._setBlueTrack()},_rePosBySizeAfterStop:function(e,t){var n=100*e/this._getGrayTrackLength(),i=BI.parseFloat(n.toFixed(1));t?this._setSliderOnePosition(i):this._setSliderTwoPosition(i)},_draggable:function(t,n){var i=this,r=(this.options,!1),a=0,o=0,s=0,l=new BI.MouseMoveTracker(function(e){l.isDragging()&&(r=!0,a=u(s+(o+=e)),t.element.addClass("dragging"),i._rePosBySizeAfterMove(a,n))},function(){!0===r&&(a=u(a),i._rePosBySizeAfterStop(a,n),o=a=0,s=a,r=!1),t.element.removeClass("dragging"),l.releaseMouseMoves(),i.fireEvent(BI.IntervalSlider.EVENT_CHANGE)},window);function u(e){return BI.clamp(e,0,i._getGrayTrackLength())}t.element.on("mousedown",function(e){t.isEnabled()&&(u(s=this.offsetLeft),l.captureMouseMoves(e))})},_createLabelWrapper:function(){var e=this._constant;return{el:{type:"bi.vertical",items:[{type:"bi.absolute",items:[{el:this.labelOne,top:0,left:"0%"}]},{type:"bi.absolute",items:[{el:this.labelTwo,top:0,left:"100%"}]}],rgap:e.EDITOR_R_GAP,height:e.SLIDER_HEIGHT},top:0,left:0,width:"100%"}},_createSliderWrapper:function(){var e=this._constant;return{el:{type:"bi.vertical",items:[{type:"bi.absolute",items:[{el:this.sliderOne,top:0,left:"0%"}]},{type:"bi.absolute",items:[{el:this.sliderTwo,top:0,left:"100%"}]}],hgap:e.SLIDER_WIDTH_HALF,height:e.SLIDER_HEIGHT},top:20,left:0,width:"100%"}},_createTrackWrapper:function(){return BI.createWidget({type:"bi.absolute",items:[{el:{type:"bi.vertical",items:[{type:"bi.absolute",items:[{el:this.grayTrack,top:0,left:0,width:"100%"},{el:this.blueTrack,top:0,left:0,width:"0%"}]}],hgap:8,height:8},top:8,left:0,width:"100%"}]})},_checkValidation:function(e){var t=this.options,n=!1,i=(e+"").split(".")[1];return BI.isEmptyString(i)||BI.isNumeric(e)&&!(BI.isNull(e)||ethis.max)&&(n=!(!1!==t.digit&&!BI.isInteger(e))||(i||"").length===t.digit),n},_checkOverlap:function(){var e=this.labelOne.element[0].offsetLeft,t=this.labelTwo.element[0].offsetLeft;e<=t?t-e<90?this.labelTwo.element.css({top:40}):this.labelTwo.element.css({top:0}):e-t<90?this.labelTwo.element.css({top:40}):this.labelTwo.element.css({top:0})},_checkLabelPosition:function(e,t,n,i,r){var a;e=BI.parseFloat(e),t=BI.parseFloat(t),n=BI.parseFloat(n),i=BI.parseFloat(i),(e<=t&&i=this.max?this.max:e},_setEnable:function(e){BI.IntervalSlider.superclass._setEnable.apply(this,[e]),e?this.blueTrack.element.removeClass("disabled-blue-track").addClass("blue-track"):this.blueTrack.element.removeClass("blue-track").addClass("disabled-blue-track")},getValue:function(){return this.valueOne<=this.valueTwo?{min:this.valueOne,max:this.valueTwo}:{min:this.valueTwo,max:this.valueOne}},setMinAndMax:function(e){var t=BI.parseFloat(e.min),n=BI.parseFloat(e.max);!isNaN(t)&&!isNaN(n)&&t<=n&&(this.min=t,this.max=n,this.valueOne=t,this.valueTwo=n,this.precision=this._getPrecision(),this.setEnable(!0)),n===t&&this.setEnable(!1)},setValue:function(e){var t=this.options,n=BI.parseFloat(e.min),i=BI.parseFloat(e.max),n=!1===t.digit?n:BI.parseFloat(n.toFixed(t.digit)),i=!1===t.digit?i:BI.parseFloat(i.toFixed(t.digit));isNaN(n)||isNaN(i)||(this._checkValidation(n)&&(this.valueOne=this.valueOne<=this.valueTwo?n:i),this._checkValidation(i)&&(this.valueTwo=this.valueOne<=this.valueTwo?i:n),nthis.max&&(this.valueTwo=this.max))},reset:function(){this._setVisible(!1),this.enable=!1,this.valueOne="",this.valueTwo="",this.min=NaN,this.max=NaN,this._setBlueTrackWidth(0)},populate:function(){var e=this.options;isNaN(this.min)||isNaN(this.max)||(this.enable=!0,this._setVisible(!0),this._setErrorText(),(BI.isNumeric(this.valueOne)||BI.isNotEmptyString(this.valueOne))&&(BI.isNumeric(this.valueTwo)||BI.isNotEmptyString(this.valueTwo))?(this.labelOne.setValue(!1===e.digit?this.valueOne:BI.parseFloat(this.valueOne).toFixed(e.digit)),this.labelTwo.setValue(!1===e.digit?this.valueTwo:BI.parseFloat(this.valueTwo).toFixed(e.digit)),this._setAllPosition(this._getPercentByValue(this.valueOne),this._getPercentByValue(this.valueTwo))):(this.labelOne.setValue(this.min),this.labelTwo.setValue(this.max),this._setAllPosition(0,100)),this._resetLabelPosition(this.valueOne>this.valueTwo))}}),BI.IntervalSlider.EVENT_CHANGE="EVENT_CHANGE",BI.shortcut("bi.interval_slider",BI.IntervalSlider)},function(e,t){BI.AccurateCalculationModel=BI.inherit(BI.Widget,{_defaultConfig:function(){return BI.extend(BI.AccurateCalculationModel.superclass._defaultConfig.apply(this,arguments),{baseCls:""})},_init:function(){BI.AccurateCalculationModel.superclass._init.apply(this,arguments)},_getMagnitude:function(e){for(var t="1",n=0;n=t.numDecimal.length)return e.numDecimal.length;return t.numDecimal.length}(n,i);a=BI.parseInt(n.numDecimal)>=BI.parseInt(i.numDecimal)?l((BI.parseInt(n.numDecimal)-BI.parseInt(i.numDecimal)).toString(),o):(r--,l((this._getMagnitude(o)+BI.parseInt(n.numDecimal)-BI.parseInt(i.numDecimal)).toString(),o));var s=r+"."+a;return BI.parseFloat(s);function l(e,t){for(var n=t-e.length,i=0;it?(n=r.numInteger.slice(0,r.numInteger.length-t),r.numInteger.slice(-t)):(n="0",function(e,t){for(var n=t-e.length,i=0;i=n._count?n.storeValue={type:BI.Selection.Multi,value:[]}:n.storeValue.type===BI.Selection.Multi&&n.storeValue.value.length>=n._count&&(n.storeValue={type:BI.Selection.All,value:[]})}this._count?(i(),t()):e.itemsCreator({type:BI.MultiSelectList.REQ_GET_DATA_LENGTH},function(e){n._count=e.count,i(),t()})},_join:function(e,t){var n=this;this.options;if(this._assertValue(e),this._assertValue(this.storeValue),this.storeValue.type===e.type){var i=this._makeMap(this.storeValue.value);BI.each(e.value,function(e,t){i[t]||(n.storeValue.value.push(t),i[t]=t)});var r=!1;return BI.each(e.assist,function(e,t){BI.isNotNull(i[t])&&(r=!0,delete i[t])}),r&&(this.storeValue.value=BI.values(i)),void n._adjust(t)}this._joinAll(e,t)},_setStartValue:function(e){this._startValue=e,this.adapter.setStartValue(e)},isAllSelected:function(){return this.adapter.isAllSelected()},resize:function(){},setValue:function(e){this.storeValue=e||{},this._assertValue(this.storeValue),this.adapter.setValue(this.storeValue),this.trigger.setValue(this.storeValue)},getValue:function(){return BI.deepClone(this.storeValue)},populate:function(){this.adapter.populate.apply(this.adapter,arguments),this.trigger.populate.apply(this.trigger,arguments)}}),BI.extend(BI.MultiSelectList,{REQ_GET_DATA_LENGTH:1,REQ_GET_ALL_DATA:-1}),BI.MultiSelectList.EVENT_CHANGE="EVENT_CHANGE",BI.shortcut("bi.multi_select_list",BI.MultiSelectList)},function(e,t){BI.MultiSelectTree=BI.inherit(BI.Single,{_constant:{EDITOR_HEIGHT:24},_defaultConfig:function(){return BI.extend(BI.MultiSelectTree.superclass._defaultConfig.apply(this,arguments),{baseCls:"bi-multi-select-tree",itemsCreator:BI.emptyFn})},_init:function(){BI.MultiSelectTree.superclass._init.apply(this,arguments);var n=this,i=this.options;this.storeValue={value:{}},this.adapter=BI.createWidget({type:"bi.multi_select_tree_popup",itemsCreator:i.itemsCreator}),this.adapter.on(BI.MultiSelectTreePopup.EVENT_CHANGE,function(){n.searcher.isSearching()?n.storeValue={value:n.searcherPane.getValue()}:n.storeValue={value:n.adapter.getValue()},n.setSelectedValue(n.storeValue.value),n.fireEvent(BI.MultiSelectTree.EVENT_CHANGE)}),this.searcherPane=BI.createWidget({type:"bi.multi_tree_search_pane",cls:"bi-border-left bi-border-right bi-border-bottom",keywordGetter:function(){return n.searcher.getKeyword()},itemsCreator:function(e,t){e.keyword=n.searcher.getKeyword(),i.itemsCreator(e,t)}}),this.searcherPane.setVisible(!1),this.searcher=BI.createWidget({type:"bi.searcher",isAutoSearch:!1,isAutoSync:!1,onSearch:function(e,t){t({keyword:n.searcher.getKeyword()})},adapter:this.adapter,popup:this.searcherPane,masker:!1,listeners:[{eventName:BI.Searcher.EVENT_START,action:function(){n._showSearcherPane()}},{eventName:BI.Searcher.EVENT_STOP,action:function(){n._showAdapter(),BI.nextTick(function(){n.adapter.populate()})}},{eventName:BI.Searcher.EVENT_CHANGE,action:function(){n.searcher.isSearching()?n.storeValue={value:n.searcherPane.getValue()}:n.storeValue={value:n.adapter.getValue()},n.setSelectedValue(n.storeValue.value),n.fireEvent(BI.MultiSelectTree.EVENT_CHANGE)}},{eventName:BI.Searcher.EVENT_PAUSE,action:function(){n._showAdapter(),BI.nextTick(function(){n.adapter.populate()})}}]}),BI.createWidget({type:"bi.vtape",element:this,items:[{el:this.searcher,height:this._constant.EDITOR_HEIGHT},{el:this.adapter,height:"fill"}]}),BI.createWidget({type:"bi.absolute",element:this,items:[{el:this.searcherPane,top:this._constant.EDITOR_HEIGHT,bottom:0,left:0,right:0}]})},_showAdapter:function(){this.adapter.setVisible(!0),this.searcherPane.setVisible(!1)},_showSearcherPane:function(){this.searcherPane.setVisible(!0),this.adapter.setVisible(!1)},resize:function(){},setSelectedValue:function(e){this.storeValue.value=e||{},this.adapter.setSelectedValue(e),this.searcherPane.setSelectedValue(e),this.searcher.setValue({value:e||{}})},setValue:function(e){this.adapter.setValue(e)},stopSearch:function(){this.searcher.stopSearch()},updateValue:function(e){this.adapter.updateValue(e)},getValue:function(){return this.storeValue.value},populate:function(){this.searcher.populate(),this.adapter.populate()}}),BI.MultiSelectTree.EVENT_CHANGE="EVENT_CHANGE",BI.shortcut("bi.multi_select_tree",BI.MultiSelectTree)},function(e,t){BI.MultiSelectTreePopup=BI.inherit(BI.Widget,{_defaultConfig:function(){return BI.extend(BI.MultiSelectTreePopup.superclass._defaultConfig.apply(this,arguments),{baseCls:"bi-multi-select-tree-popup bi-border-left bi-border-right bi-border-bottom",itemsCreator:BI.emptyFn})},_init:function(){BI.MultiSelectTreePopup.superclass._init.apply(this,arguments);var e=this,t=this.options;this.popup=BI.createWidget({type:"bi.async_tree",element:this,itemsCreator:t.itemsCreator}),this.popup.on(BI.TreeView.EVENT_AFTERINIT,function(){e.fireEvent(BI.MultiSelectTreePopup.EVENT_AFTER_INIT)}),this.popup.on(BI.TreeView.EVENT_CHANGE,function(){e.fireEvent(BI.MultiSelectTreePopup.EVENT_CHANGE)})},hasChecked:function(){return this.popup.hasChecked()},getValue:function(){return this.popup.getValue()},setValue:function(e){e=e||{},this.popup.setValue(e)},setSelectedValue:function(e){e=e||{},this.popup.setSelectedValue(e)},updateValue:function(e){this.popup.updateValue(e),this.popup.refresh()},populate:function(e){this.popup.stroke(e)}}),BI.MultiSelectTreePopup.EVENT_AFTER_INIT="EVENT_AFTER_INIT",BI.MultiSelectTreePopup.EVENT_CHANGE="EVENT_CHANGE",BI.shortcut("bi.multi_select_tree_popup",BI.MultiSelectTreePopup)},function(e,t){BI.MultiTreeCheckPane=BI.inherit(BI.Pane,{constants:{height:25,lgap:10,tgap:5},_defaultConfig:function(){return BI.extend(BI.MultiTreeCheckPane.superclass._defaultConfig.apply(this,arguments),{baseCls:"bi-multi-tree-check-pane bi-background",onClickContinueSelect:BI.emptyFn,el:{type:"bi.display_tree"}})},_init:function(){BI.MultiTreeCheckPane.superclass._init.apply(this,arguments);var e=this,n=this.options;this.selectedValues={};var t=BI.createWidget({type:"bi.text_button",text:BI.i18nText("BI-Continue_Select"),cls:"multi-tree-check-selected"});t.on(BI.TextButton.EVENT_CHANGE,function(){n.onClickContinueSelect(),BI.nextTick(function(){e.empty()})});var i=BI.createWidget({type:"bi.left",cls:"multi-tree-continue-select",items:[{el:{type:"bi.label",text:BI.i18nText("BI-Selected_Data")},lgap:this.constants.lgap,tgap:this.constants.tgap},{el:t,lgap:this.constants.lgap,tgap:this.constants.tgap}]});this.display=BI.createWidget(n.el,{type:"bi.display_tree",cls:"bi-multi-tree-display",itemsCreator:function(e,t){e.type=BI.TreeView.REQ_TYPE_GET_SELECTED_DATA,n.itemsCreator(e,t)},value:(n.value||{}).value}),this.display.on(BI.Events.AFTERINIT,function(){e.fireEvent(BI.Events.AFTERINIT)}),this.display.on(BI.TreeView.EVENT_INIT,function(){i.setVisible(!1)}),this.display.on(BI.TreeView.EVENT_AFTERINIT,function(){i.setVisible(!0)}),BI.createWidget({type:"bi.vtape",element:this,items:[{height:this.constants.height,el:i},{height:"fill",el:this.display}]})},empty:function(){this.display.empty()},populate:function(e){this.display.stroke(e)},setValue:function(e){e=e||{},this.display.setSelectedValue(e.value)},getValue:function(){}}),BI.MultiTreeCheckPane.EVENT_CONTINUE_CLICK="EVENT_CONTINUE_CLICK",BI.shortcut("bi.multi_tree_check_pane",BI.MultiTreeCheckPane)},function(e,t){BI.MultiTreeCombo=BI.inherit(BI.Single,{constants:{offset:{top:0,left:0,right:0,bottom:25}},_defaultConfig:function(){return BI.extend(BI.MultiTreeCombo.superclass._defaultConfig.apply(this,arguments),{baseCls:"bi-multi-tree-combo",itemsCreator:BI.emptyFn,valueFormatter:BI.emptyFn,height:24,allowEdit:!0,isNeedAdjustWidth:!0})},_init:function(){BI.MultiTreeCombo.superclass._init.apply(this,arguments);var n=this,e=this.options,t=!1,i=!1;this.storeValue={value:e.value||{}},this.trigger=BI.createWidget({type:"bi.multi_select_trigger",allowEdit:e.allowEdit,height:e.height,valueFormatter:e.valueFormatter,text:e.text,watermark:e.watermark,masker:{offset:this.constants.offset},searcher:{type:"bi.multi_tree_searcher",itemsCreator:e.itemsCreator},value:{value:e.value||{}}}),this.combo=BI.createWidget({type:"bi.combo",toggle:!e.allowEdit,container:e.container,el:this.trigger,adjustLength:1,popup:{type:"bi.multi_tree_popup_view",ref:function(){n.popup=this,n.trigger.setAdapter(this),n.numberCounter.setAdapter(this)},listeners:[{eventName:BI.MultiTreePopup.EVENT_AFTERINIT,action:function(){n.numberCounter.adjustView(),(t=!0)===i&&l()}},{eventName:BI.MultiTreePopup.EVENT_CHANGE,action:function(){r=!0;var e={type:BI.Selection.Multi,value:this.hasChecked()?this.getValue():{}};n.trigger.getSearcher().setState(e),n.numberCounter.setButtonChecked(e),n.fireEvent(BI.MultiTreeCombo.EVENT_CLICK_ITEM,n.combo.getValue())}},{eventName:BI.MultiTreePopup.EVENT_CLICK_CONFIRM,action:function(){n.combo.hideView()}},{eventName:BI.MultiTreePopup.EVENT_CLICK_CLEAR,action:function(){a=!0,n.setValue(),n._defaultState()}}],itemsCreator:e.itemsCreator,onLoaded:function(){BI.nextTick(function(){n.numberCounter.adjustView(),n.trigger.getSearcher().adjustView()})},maxWidth:e.isNeedAdjustWidth?"auto":500},isNeedAdjustWidth:e.isNeedAdjustWidth,value:{value:e.value||{}},hideChecker:function(e){return 0===u.element.find(e.target).length&&0===n.numberCounter.element.find(e.target).length}});var r=!1,a=!1,o=function(){return n.trigger.getSearcher().isSearching()},s=function(){return n.combo.isViewVisible()};function l(){o()?n.storeValue={value:n.trigger.getValue()}:s()&&(n.storeValue={value:n.combo.getValue()}),n.trigger.setValue(n.storeValue),n.numberCounter.setValue(n.storeValue)}this.trigger.on(BI.MultiSelectTrigger.EVENT_FOCUS,function(){n.fireEvent(BI.MultiTreeCombo.EVENT_FOCUS)}),this.trigger.on(BI.MultiSelectTrigger.EVENT_BLUR,function(){n.fireEvent(BI.MultiTreeCombo.EVENT_BLUR)}),this.trigger.on(BI.MultiSelectTrigger.EVENT_START,function(){n.storeValue={value:n.combo.getValue()},this.setValue(n.storeValue),n.numberCounter.setValue(n.storeValue)}),this.trigger.on(BI.MultiSelectTrigger.EVENT_STOP,function(){n.storeValue={value:this.getValue()},n.combo.setValue(n.storeValue),n.numberCounter.setValue(n.storeValue),BI.nextTick(function(){s()&&n.combo.populate()}),n.fireEvent(BI.MultiTreeCombo.EVENT_STOP)}),this.trigger.on(BI.MultiSelectTrigger.EVENT_SEARCHING,function(){n.fireEvent(BI.MultiTreeCombo.EVENT_SEARCHING)}),this.trigger.on(BI.MultiSelectTrigger.EVENT_TRIGGER_CLICK,function(){n.combo.toggle()}),this.trigger.on(BI.MultiSelectTrigger.EVENT_COUNTER_CLICK,function(){n.combo.isViewVisible()||n.combo.showView()}),this.trigger.on(BI.MultiSelectTrigger.EVENT_CHANGE,function(){var e=this.getSearcher().hasChecked(),t={type:BI.Selection.Multi,value:e?{1:1}:{}};this.getSearcher().setState(e?BI.Selection.Multi:BI.Selection.None),n.numberCounter.setButtonChecked(t),n.fireEvent(BI.MultiTreeCombo.EVENT_CLICK_ITEM,n.combo.getValue())}),this.combo.on(BI.Combo.EVENT_BEFORE_POPUPVIEW,function(){o()||(!0===r&&(n.storeValue={value:n.combo.getValue()},r=!1),n.combo.setValue(n.storeValue),n.numberCounter.setValue(n.storeValue),n.populate(),n.fireEvent(BI.MultiTreeCombo.EVENT_BEFORE_POPUPVIEW))}),this.combo.on(BI.Combo.EVENT_BEFORE_HIDEVIEW,function(){o()?(n._stopEditing(),n.fireEvent(BI.MultiTreeCombo.EVENT_CONFIRM)):s()&&(n._stopEditing(),n.storeValue={value:n.combo.getValue()},!0===a&&(n.storeValue={value:{}}),n.fireEvent(BI.MultiTreeCombo.EVENT_CONFIRM)),r=a=!1});var u=BI.createWidget({type:"bi.trigger_icon_button",width:e.height,height:e.height,cls:"multi-select-trigger-icon-button"});u.on(BI.TriggerIconButton.EVENT_CHANGE,function(){n.numberCounter.hideView(),n.combo.isViewVisible()?n.combo.hideView():n.combo.showView()}),this.numberCounter=BI.createWidget({type:"bi.multi_select_check_selected_switcher",el:{type:"bi.multi_tree_check_selected_button"},popup:{type:"bi.multi_tree_check_pane"},masker:{offset:this.constants.offset},itemsCreator:e.itemsCreator,valueFormatter:e.valueFormatter,value:{value:e.value||{}}}),this.numberCounter.on(BI.MultiSelectCheckSelectedSwitcher.EVENT_TRIGGER_CHANGE,function(){n.combo.isViewVisible()||n.combo.showView()}),this.numberCounter.on(BI.MultiSelectCheckSelectedSwitcher.EVENT_BEFORE_POPUPVIEW,function(){!1===i&&(i=!0),!0===t&&(i=null,l())}),this.numberCounter.on(BI.Events.VIEW,function(e){BI.nextTick(function(){n.trigger.refreshPlaceHolderWidth(!0===e?n.numberCounter.element.outerWidth()+8:0)})}),this.numberCounter.on(BI.MultiSelectCheckSelectedSwitcher.EVENT_AFTER_HIDEVIEW,function(){BI.nextTick(function(){n.trigger.refreshPlaceHolderWidth(0)})}),this.trigger.element.click(function(e){0=t.min&&BI.parseFloat(e)<=t.max)},_checkAdjustDisabled:function(e){this.options.validationChecker===BI.emptyFn&&(this.bottomBtn.setEnable(BI.parseFloat(e)>this.options.min),this.topBtn.setEnable(BI.parseFloat(e)=n._count?n.storeValue={type:BI.Selection.Multi,value:[]}:n.storeValue.type===BI.Selection.Multi&&n.storeValue.value.length>=n._count&&(n.storeValue={type:BI.Selection.All,value:[]}),n._updateAllValue(),n._checkError(),!0===n.wants2Quit&&(n.fireEvent(BI.SearchMultiTextValueCombo.EVENT_CONFIRM),n.wants2Quit=!1),n.requesting=!1}this._count?(i(),t()):this._itemsCreator({type:BI.SearchMultiTextValueCombo.REQ_GET_DATA_LENGTH},function(e){n._count=e.count,i(),t()})},_join:function(e,t){var n=this;this.options;if(this._assertValue(e),this._assertValue(this.storeValue),this.storeValue.type===e.type){var i=this._makeMap(this.storeValue.value);BI.each(e.value,function(e,t){i[t]||(n.storeValue.value.push(t),BI.remove(n.storeValue.assist,t),i[t]=t)});var r=!1;return BI.each(e.assist,function(e,t){BI.isNotNull(i[t])&&(r=!0,n.storeValue.assist&&n.storeValue.assist.push(i[t]),delete i[t])}),r&&(this.storeValue.value=BI.values(i)),void n._adjust(t)}this._joinAll(e,t)},_setStartValue:function(e){this._startValue=e,this.popup.setStartValue(e)},_getItemsByTimes:function(e,t){for(var n=[],i=100*(t-1);e[i]&&i<100*t;i++)n.push(e[i]);return n},_hasNextByTimes:function(e,t){return 100*tthis.max)&&(n=!1===t.digit||((e+"").split(".")[1]||"").length===t.digit),n},_setBlueTrack:function(e){this.blueTrack.element.css({width:e+"%"})},_setLabelPosition:function(e){},_setSliderPosition:function(e){this.slider.element.css({left:e+"%"})},_setAllPosition:function(e){this._setSliderPosition(e),this._setLabelPosition(e),this._setBlueTrack(e)},_setVisible:function(e){this.slider.setVisible(e),this.label.setVisible(e)},_getGrayTrackLength:function(){return this.grayTrack.element[0].scrollWidth},_getValueByPercent:function(e){var t=BI.parseInt(10*e);return(this.max-this.min)*t/1e3+this.min},_getPercentByValue:function(e){return 100*(e-this.min)/(this.max-this.min)},getValue:function(){return this.value},setValue:function(e){var t=this.options;e=BI.parseFloat(e),e=!1===t.digit?e:e.toFixed(t.digit),isNaN(e)||(this._checkValidation(e)&&(this.value=e),e>this.max&&(this.value=this.max),ethis.max)},_setBlueTrack:function(e){this.blueTrack.element.css({width:e+"%"})},_setLabelPosition:function(e){},_setSliderPosition:function(e){this.slider.element.css({left:e+"%"})},_setAllPosition:function(e){this._setSliderPosition(e),this._setLabelPosition(e),this._setBlueTrack(e)},_setVisible:function(e){this.slider.setVisible(e),this.label.setVisible(e)},_getGrayTrackLength:function(){return this.grayTrack.element[0].scrollWidth},_getValueByPercent:function(e){var t=BI.parseInt(10*e);return(this.max-this.min)*t/1e3+this.min},_getPercentByValue:function(e){return 100*(e-this.min)/(this.max-this.min)},_setEnable:function(e){BI.SingleSliderLabel.superclass._setEnable.apply(this,[e]),e?this.blueTrack.element.removeClass("disabled-blue-track").addClass("blue-track"):this.blueTrack.element.removeClass("blue-track").addClass("disabled-blue-track")},getValue:function(){return this.value},setValue:function(e){var t=this.options;e=BI.parseFloat(e),e=!1===t.digit?e:e.toFixed(t.digit),isNaN(e)||(this._checkValidation(e)&&(this.value=e),e>this.max&&(this.value=this.max),ethis.max)},_setBlueTrack:function(e){this.blueTrack.element.css({width:e+"%"})},_setSliderPosition:function(e){this.slider.element.css({left:e+"%"})},_setAllPosition:function(e){this._setSliderPosition(e),this._setBlueTrack(e)},_setVisible:function(e){this.slider.setVisible(e)},_getGrayTrackLength:function(){return this.grayTrack.element[0].scrollWidth},_getValueByPercent:function(e){var t=BI.parseInt(10*e);return(this.max-this.min)*t/1e3+this.min},_getPercentByValue:function(e){return 100*(e-this.min)/(this.max-this.min)},_setEnable:function(e){BI.SingleSliderNormal.superclass._setEnable.apply(this,[e]),e?this.blueTrack.element.removeClass("disabled-blue-track").addClass("blue-track"):this.blueTrack.element.removeClass("blue-track").addClass("disabled-blue-track")},getValue:function(){return this.value},setValue:function(e){var t=BI.parseFloat(e);isNaN(t)||(this._checkValidation(t)&&(this.value=t),t>this.max&&(this.value=this.max),t=this.options.min&&t<=this.options.max},_autoSwitch:function(e){var t=e.getValue();BI.isNotEmptyString(t)&&BI.checkDateLegal(t)&&4===t.length&&this._yearCheck(t)&&(this._doEditorConfirm(e),this.fireEvent(BI.DynamicYearMonthTrigger.EVENT_CONFIRM),this.monthEditor.focus())},_getText:function(e){var t="";return BI.isNotNull(e.year)&&0!==BI.parseInt(e.year)&&(t+=Math.abs(e.year)+BI.i18nText("BI-Basic_Year")+(e.year<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),BI.isNotNull(e.month)&&0!==BI.parseInt(e.month)&&(t+=Math.abs(e.month)+BI.i18nText("BI-Basic_Month")+(e.month<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),t},_setInnerValue:function(e,t){this.yearEditor.setValue(e.getFullYear()),this.monthEditor.setValue(e.getMonth()+1)},_getStaticTitle:function(e){switch(e=e||{},!(BI.isNull(e.year)||BI.isEmptyString(e.year))<<1|!(BI.isNull(e.month)||BI.isEmptyString(e.month))){case 0:return"";case 1:return e.month;case 2:return e.year;case 3:default:return e.year+"-"+e.month}},setValue:function(e){var t,n,i=BI.getDate();switch(this.storeValue=e,BI.isNotNull(e)&&(t=e.type||BI.DynamicDateCombo.Static,n=e.value||e),t){case BI.DynamicDateCombo.Dynamic:var r=this._getText(n),i=BI.DynamicDateHelper.getCalculation(n);this._setInnerValue(i,r);break;case BI.DynamicDateCombo.Static:default:n=n||{};var a=BI.isNull(n.month)?null:n.month;this.yearEditor.setValue(n.year),this.monthEditor.setValue(a)}},getValue:function(){return this.storeValue},getKey:function(){return this.yearEditor.getValue()+"-"+this.monthEditor.getValue()},isValid:function(){return this.yearEditor.isValid()&&this.monthEditor.isValid()}}),BI.DynamicYearMonthTrigger.EVENT_VALID="EVENT_VALID",BI.DynamicYearMonthTrigger.EVENT_FOCUS="EVENT_FOCUS",BI.DynamicYearMonthTrigger.EVENT_ERROR="EVENT_ERROR",BI.DynamicYearMonthTrigger.EVENT_START="EVENT_START",BI.DynamicYearMonthTrigger.EVENT_CONFIRM="EVENT_CONFIRM",BI.DynamicYearMonthTrigger.EVENT_STOP="EVENT_STOP",BI.DynamicYearMonthTrigger.EVENT_KEY_DOWN="EVENT_KEY_DOWN",BI.shortcut("bi.dynamic_year_month_trigger",BI.DynamicYearMonthTrigger)},function(e,t){BI.YearMonthInterval=BI.inherit(BI.Single,{constants:{height:24,width:25,lgap:15,offset:-15,timeErrorCls:"time-error"},props:{extraCls:"bi-year-month-interval",minDate:"1900-01-01",maxDate:"2099-12-31"},_init:function(){var e=this.options;BI.YearMonthInterval.superclass._init.apply(this,arguments),e.value=e.value||{},this.left=this._createCombo(e.value.start),this.right=this._createCombo(e.value.end),this.label=BI.createWidget({type:"bi.label",height:this.constants.height,width:this.constants.width,text:"-"}),BI.createWidget({element:this,type:"bi.center",hgap:15,height:this.constants.height,items:[{type:"bi.absolute",items:[{el:this.left,left:this.constants.offset,right:0,top:0,bottom:0}]},{type:"bi.absolute",items:[{el:this.right,left:0,right:this.constants.offset,top:0,bottom:0}]}]}),BI.createWidget({type:"bi.horizontal_auto",element:this,items:[this.label]})},_createCombo:function(e){var n=this,t=this.options,i=BI.createWidget({type:"bi.dynamic_year_month_combo",behaviors:t.behaviors,value:e,listeners:[{eventName:BI.DynamicYearMonthCombo.EVENT_BEFORE_POPUPVIEW,action:function(){n.fireEvent(BI.YearMonthInterval.EVENT_BEFORE_POPUPVIEW)}}]});return i.on(BI.DynamicYearMonthCombo.EVENT_ERROR,function(){n._clearTitle(),BI.Bubbles.hide("error"),n.element.removeClass(n.constants.timeErrorCls),n.fireEvent(BI.YearMonthInterval.EVENT_ERROR)}),i.on(BI.DynamicYearMonthCombo.EVENT_VALID,function(){n._checkValid()}),i.on(BI.DynamicYearMonthCombo.EVENT_FOCUS,function(){n._checkValid()}),i.on(BI.DynamicYearMonthCombo.EVENT_BEFORE_POPUPVIEW,function(){n.left.hideView(),n.right.hideView()}),i.on(BI.DynamicYearMonthCombo.EVENT_CONFIRM,function(){BI.Bubbles.hide("error");var e=n.left.getKey(),t=n.right.getKey();n.left.isValid()&&n.right.isValid()&&n._check(e,t)&&n._compare(e,t)?(n._setTitle(BI.i18nText("BI-Time_Interval_Error_Text")),n.element.addClass(n.constants.timeErrorCls),n.fireEvent(BI.YearMonthInterval.EVENT_ERROR)):(n._clearTitle(),n.element.removeClass(n.constants.timeErrorCls),n.fireEvent(BI.YearMonthInterval.EVENT_CHANGE))}),i},_dateCheck:function(e){return BI.print(BI.parseDateTime(e,"%Y-%x"),"%Y-%x")===e||BI.print(BI.parseDateTime(e,"%Y-%X"),"%Y-%X")===e},_checkVoid:function(e){var t=this.options;return!BI.checkDateVoid(e.year,e.month,1,t.minDate,t.maxDate)[0]},_check:function(e,t){var n=e.match(/\d+/g),i=t.match(/\d+/g),r="";BI.isNotNull(n)&&(r=(n[0]||"")+"-"+(n[1]||1));var a="";return BI.isNotNull(i)&&(a=(i[0]||"")+"-"+(i[1]||1)),this._dateCheck(r)&&BI.checkDateLegal(r)&&this._checkVoid({year:n[0],month:n[1]||1,day:1})&&this._dateCheck(a)&&BI.checkDateLegal(a)&&this._checkVoid({year:i[0],month:i[1]||1,day:1})},_compare:function(e,t){return e=BI.print(BI.parseDateTime(e,"%Y-%X"),"%Y-%X"),t=BI.print(BI.parseDateTime(t,"%Y-%X"),"%Y-%X"),BI.isNotNull(e)&&BI.isNotNull(t)&&t=this.options.min&&t<=this.options.max},_autoSwitch:function(e){var t=e.getValue();BI.isNotEmptyString(t)&&BI.checkDateLegal(t)&&4===t.length&&this._yearCheck(t)&&(this._doEditorConfirm(e),this.fireEvent(BI.DynamicYearQuarterTrigger.EVENT_CONFIRM),this.quarterEditor.focus())},_getStaticTitle:function(e){switch(e=e||{},!(BI.isNull(e.year)||BI.isEmptyString(e.year))<<1|!(BI.isNull(e.quarter)||BI.isEmptyString(e.quarter))){case 0:return"";case 1:return e.quarter;case 2:return e.year;case 3:default:return e.year+"-"+e.quarter}},_getText:function(e){var t="";return BI.isNotNull(e.year)&&0!==BI.parseInt(e.year)&&(t+=Math.abs(e.year)+BI.i18nText("BI-Basic_Year")+(e.year<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),BI.isNotNull(e.quarter)&&0!==BI.parseInt(e.quarter)&&(t+=Math.abs(e.quarter)+BI.i18nText("BI-Basic_Single_Quarter")+(e.quarter<0?BI.i18nText("BI-Basic_Front"):BI.i18nText("BI-Basic_Behind"))),t},_setInnerValue:function(e,t){var n=BI.print(e,"%Y-%Q");this.yearEditor.setValue(e.getFullYear()),this.quarterEditor.setValue(BI.getQuarter(e)),this.setTitle(BI.isEmptyString(t)?n:t+":"+n)},setValue:function(e){var t,n,i=BI.getDate();switch(this.storeValue=e,BI.isNotNull(e)&&(t=e.type||BI.DynamicYearQuarterCombo.Static,n=e.value||e),t){case BI.DynamicYearQuarterCombo.Dynamic:var r=this._getText(n),i=BI.DynamicDateHelper.getCalculation(n);this._setInnerValue(i,r);break;case BI.DynamicYearQuarterCombo.Static:default:n=n||{};var a=BI.isNull(n.quarter)?null:n.quarter;this.yearEditor.setValue(n.year),this.yearEditor.setTitle(n.year),this.quarterEditor.setValue(a),this.quarterEditor.setTitle(a),this.setTitle(this._getStaticTitle(n))}},getValue:function(){return this.storeValue},getKey:function(){return this.yearEditor.getValue()+"-"+this.quarterEditor.getValue()}}),BI.DynamicYearQuarterTrigger.EVENT_FOCUS="EVENT_FOCUS",BI.DynamicYearQuarterTrigger.EVENT_ERROR="EVENT_ERROR",BI.DynamicYearQuarterTrigger.EVENT_START="EVENT_START",BI.DynamicYearQuarterTrigger.EVENT_CONFIRM="EVENT_CONFIRM",BI.DynamicYearQuarterTrigger.EVENT_STOP="EVENT_STOP",BI.DynamicYearQuarterTrigger.EVENT_KEY_DOWN="EVENT_KEY_DOWN",BI.shortcut("bi.dynamic_year_quarter_trigger",BI.DynamicYearQuarterTrigger)},function(e,t){BI.AbstractAllValueChooser=BI.inherit(BI.Widget,{_const:{perPage:100},_defaultConfig:function(){return BI.extend(BI.AbstractAllValueChooser.superclass._defaultConfig.apply(this,arguments),{width:200,height:30,items:null,itemsCreator:BI.emptyFn,cache:!0})},_valueFormatter:function(n){var i=n;return BI.isNotNull(this.items)&&BI.some(this.items,function(e,t){if(t.value===n||t.value+""===n)return i=t.text,!0}),i},_itemsCreator:function(t,a){var n=this,e=this.options;function i(i){var e=(t.keywords||[]).slice();t.keyword&&e.push(t.keyword);var n,r=i;BI.isNotEmptyArray(e)&&(r=[],BI.each(e,function(e,t){var n=BI.Func.getSearchResult(i,t);r=r.concat(n.match).concat(n.find)}),r=BI.uniq(r)),t.selectedValues&&(n=BI.makeObject(t.selectedValues,!0),r=BI.filter(r,function(e,t){return!n[t.value]})),t.type!==BI.MultiSelectCombo.REQ_GET_ALL_DATA?t.type!==BI.MultiSelectCombo.REQ_GET_DATA_LENGTH?a({items:r,hasNext:!1}):a({count:r.length}):a({items:r})}e.cache&&this.items?i(this.items):e.itemsCreator({},function(e){i(n.items=e)})},_assertValue:function(e){var t=e=e||{};return BI.isNotNull(this.items)&&0===BI.difference(BI.map(this.items,"value"),e.value).length&&(t={type:BI.Selection.All,value:[]}),t}})},function(e,t){BI.AllValueChooserCombo=BI.inherit(BI.AbstractAllValueChooser,{_defaultConfig:function(){return BI.extend(BI.AllValueChooserCombo.superclass._defaultConfig.apply(this,arguments),{baseCls:"bi-all-value-chooser-combo",width:200,height:24,items:null,itemsCreator:BI.emptyFn,cache:!0})},_init:function(){BI.AllValueChooserCombo.superclass._init.apply(this,arguments);var e=this,t=this.options;BI.isNotNull(t.items)&&(this.items=t.items),this.combo=BI.createWidget({type:"bi.multi_select_combo",text:t.text,element:this,itemsCreator:BI.bind(this._itemsCreator,this),valueFormatter:BI.bind(this._valueFormatter,this),width:t.width,height:t.height,value:this._assertValue({type:BI.Selection.Multi,value:t.value||[]})}),this.combo.on(BI.MultiSelectCombo.EVENT_CONFIRM,function(){e.fireEvent(BI.AllValueChooserCombo.EVENT_CONFIRM)})},setValue:function(e){this.combo.setValue(this._assertValue({type:BI.Selection.Multi,value:e||[]}))},getValue:function(){return this.getAllValue()},getAllValue:function(){var e=this.combo.getValue()||{};return e.type===BI.Selection.Multi?e.value||[]:BI.difference(BI.map(this.items,"value"),e.value||[])},populate:function(e){BI.isNotNull(e)&&(this.items=e),this.combo.populate()}}),BI.AllValueChooserCombo.EVENT_CONFIRM="EVENT_CONFIRM",BI.shortcut("bi.all_value_chooser_combo",BI.AllValueChooserCombo)},function(e,t){BI.AllValueChooserPane=BI.inherit(BI.AbstractAllValueChooser,{_defaultConfig:function(){return BI.extend(BI.AllValueChooserPane.superclass._defaultConfig.apply(this,arguments),{baseCls:"bi-all-value-chooser-pane",width:200,height:30,items:null,itemsCreator:BI.emptyFn,cache:!0})},_init:function(){BI.AllValueChooserPane.superclass._init.apply(this,arguments);var e=this,t=this.options;this.list=BI.createWidget({type:"bi.multi_select_list",element:this,itemsCreator:BI.bind(this._itemsCreator,this),valueFormatter:BI.bind(this._valueFormatter,this),width:t.width,height:t.height}),this.list.on(BI.MultiSelectList.EVENT_CHANGE,function(){e.fireEvent(BI.AllValueChooserPane.EVENT_CHANGE)}),BI.isNotNull(t.items)&&(this.items=t.items,this.list.populate())},setValue:function(e){this.list.setValue({type:BI.Selection.Multi,value:e||[]})},getValue:function(){var e=this.list.getValue()||{};return e.type===BI.Selection.All?e.assist:e.value||[]},populate:function(e){BI.isNotNull(e)&&(this.items=e),this.list.populate()}}),BI.AllValueChooserPane.EVENT_CHANGE="EVENT_CHANGE",BI.shortcut("bi.all_value_chooser_pane",BI.AllValueChooserPane)},function(e,t){BI.AllValueMultiTextValueCombo=BI.inherit(BI.Widget,{props:{baseCls:"bi-all-value-multi-text-value-combo",width:200,height:24,items:[]},render:function(){var e=this,t=this.options,n=this._digestValue(t.value);return{type:"bi.search_multi_text_value_combo",text:t.text,height:t.height,items:t.items,value:n,numOfPage:100,valueFormatter:t.valueFormatter,warningTitle:t.warningTitle,listeners:[{eventName:BI.SearchMultiTextValueCombo.EVENT_CONFIRM,action:function(){e.fireEvent(BI.AllValueMultiTextValueCombo.EVENT_CONFIRM)}}],ref:function(){e.combo=this}}},setValue:function(e){var t=this._digestValue(e);this.combo.setValue(t)},getValue:function(){var n=this.combo.getValue()||{};if(n.value=n.value||[],n.type!==BI.Selection.All)return n.value||[];var i=[];return BI.each(this.options.items,function(e,t){BI.contains(n.value,t.value)||i.push(t.value)}),i},populate:function(e){this.options.items=e,this.combo.populate.apply(this.combo,arguments)},_digestValue:function(e){return{type:BI.Selection.Multi,value:e||[]}}}),BI.AllValueMultiTextValueCombo.EVENT_CONFIRM="EVENT_CONFIRM",BI.shortcut("bi.all_value_multi_text_value_combo",BI.AllValueMultiTextValueCombo)},function(e,t){BI.AbstractTreeValueChooser=BI.inherit(BI.Widget,{_const:{perPage:100},_defaultConfig:function(){return BI.extend(BI.AbstractTreeValueChooser.superclass._defaultConfig.apply(this,arguments),{items:null,itemsCreator:BI.emptyFn,open:!1})},_valueFormatter:function(n){var i=n;return BI.isNotNull(this.items)&&BI.some(this.items,function(e,t){if(t.value===n||t.value+""===n)return i=t.text,!0}),i},_initData:function(e){this.items=e;var t=BI.Tree.treeFormat(e);this.tree=new BI.Tree,this.tree.initTree(t)},_itemsCreator:function(e,t){var n=this,i=this.options;function r(){switch(e.type){case BI.TreeView.REQ_TYPE_INIT_DATA:n._reqInitTreeNode(e,t);break;case BI.TreeView.REQ_TYPE_ADJUST_DATA:n._reqAdjustTreeNode(e,t);break;case BI.TreeView.REQ_TYPE_SELECT_DATA:n._reqSelectedTreeNode(e,t);break;case BI.TreeView.REQ_TYPE_GET_SELECTED_DATA:n._reqDisplayTreeNode(e,t);break;default:n._reqTreeNode(e,t)}}this.items?r():i.itemsCreator({},function(e){n._initData(e),r()})},_reqDisplayTreeNode:function(e,t){var o=this,i=[],n=e.selectedValues;function s(e,t){return null==e?0:BI.isEmpty(e)?o._getChildCount(t):BI.size(e)}function l(e,t,n){i.push({id:e.id,pId:t,text:e.text+(0f._const.perPage)break}{var s;1===l.times&&(s=f._getAddedValueNode([],c),u=BI.concat(BI.filter(s,function(e,t){var n=BI.Func.getSearchResult([t.text||t.value],g);return 0f._const.perPage,items:u,lastSearchValue:BI.last(t)})})},_reqTreeNode:function(e,t){for(var n,c=this,i=this.options,o=[],r=e.times,a=e.checkState||{},s=e.parentValues||[],l=e.selectedValues||{},u=f(s,l),h=this._getChildren(s),p=(r-1)*this._const.perPage;h[p]&&pr*c._const.perPage})})},_getAddedValueNode:function(e,t){var n=this._getChildren(e);return BI.map(BI.difference(BI.keys(t),BI.map(n,"value")),function(e,t){return{id:BI.UUID(),pId:0t.length)return!1;if(a!==t.length||e.value!==n)return e.value!==t[a]||e.getParent()!==o||(a++,void(o=e));if(e.getParent()!==o)return;return i=e,!1}}),i},_getChildren:function(e){var t;return(0u._const.perPage)break}{var s;1===l.times&&(s=u._getAddedValueNode([],p),c=BI.concat(BI.filter(s,function(e,t){var n=BI.Func.getSearchResult([t.text||t.value],h);return 0u._const.perPage,items:c,lastSearchValue:BI.last(t)})})},_reqTreeNode:function(e,t){for(var n,i=this,r=this.options,a=[],o=e.times,s=e.parentValues||[],l=e.selectedValues||[],u=d(s,l),c=this._getChildren(s),h=(o-1)*this._const.perPage;c[h]&&ho*i._const.perPage})})},_getAddedValueNode:function(e,t){var n=this._getChildren(e),i=BI.flatten(BI.filter(t,function(e,t){return 1===t.length}));return BI.map(BI.difference(i,BI.map(n,"value")),function(e,t){return{id:BI.UUID(),pId:0>>0;if(0==r)return-1;var a=0|t;if(r<=a)return-1;for(n=Math.max(0<=a?a:r-Math.abs(a),0);n>>0;if(0==r)return-1;for(t=r-1,1 div, .contract-trigger:before { content: " "; display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden; } .resize-triggers > div { background: #eee; overflow: auto; } .contract-trigger:before { width: 200%; height: 200%; }',i=document.head||document.getElementsByTagName("head")[0],(r=document.createElement("style")).type="text/css",r.styleSheet?r.styleSheet.cssText=n:r.appendChild(document.createTextNode(n)),i.appendChild(r),o=!0),t.__resizeLast__={},t.__resizeListeners__=[],(t.__resizeTriggers__=document.createElement("div")).className="resize-triggers",t.__resizeTriggers__.innerHTML='
',t.appendChild(t.__resizeTriggers__),s(t),t.addEventListener("scroll",l,!0),c&&t.__resizeTriggers__.addEventListener(c,function(e){e.animationName===m&&s(t)})),t.__resizeListeners__.push(e))},E=function(e,t){a?e.detachEvent("onresize",t):(e.__resizeListeners__.splice(e.__resizeListeners__.indexOf(t),1),e.__resizeListeners__.length||(e.removeEventListener("scroll",l),e.__resizeTriggers__=!e.removeChild(e.__resizeTriggers__)))};BI.ResizeDetector={addResizeListener:function(e,t){return _(e.element[0],t),function(){E(e.element[0],t)}},removeResizeListener:function(e,t){E(e.element[0],t)}}}()},function(e,t){BI.DOM=BI.DOM||{},BI.extend(BI.DOM,{ready:function(e){BI.Widget._renderEngine.createElement(document).ready(e)}}),BI.extend(BI.DOM,{patchProps:function(e,i){var t=BI.jQuery._data(e[0]).events;BI.each(t,function(n,e){BI.each(e,function(e,t){i.on(n+(t.namespace?"."+t.namespace:""),t)})});var n=e.children(),r=i.children();if(n.length!==r.length)throw new Error("不匹配");BI.each(n,function(e,t){BI.DOM.patchProps(BI.jQuery(t),BI.jQuery(r[e]))}),BI.each(e.data("__widgets"),function(e,t){t.element=i})},hang:function(e){if(!BI.isEmpty(e)){var n=BI.Widget._renderEngine.createFragment();return BI.each(e,function(e,t){t instanceof BI.Widget&&(t=t.element),t instanceof BI.$&&t[0]&&n.appendChild(t[0])}),n}},isExist:function(e){return 0=e.length&&t()}BI.each(e,function(e,t){i[e]=new Image,i[e].src=t,i[e].onload=function(){r()},i[e].onerror=function(){r()}})},getTextSizeWidth:function(e,t){var n=BI.Widget._renderEngine.createElement("").addClass("text-width-span").appendTo("body");null==t&&(t=12),t+="px",n.css("font-size",t).text(e);var i=n.width();return n.remove(),i},getTextSizeHeight:function(e,t){var n=BI.Widget._renderEngine.createElement("").addClass("text-width-span").appendTo("body");null==t&&(t=12),t+="px",n.css("font-size",t).text(e);var i=n.height();return n.remove(),i},getScrollWidth:function(){var e;return!BI.isNull(this._scrollWidth)&&0!==this._scrollWidth||(e=BI.Widget._renderEngine.createElement("
").width(50).height(50).css({position:"absolute",top:"-9999px",overflow:"scroll"}).appendTo("body"),this._scrollWidth=e[0].offsetWidth-e[0].clientWidth,e.destroy()),this._scrollWidth},getImage:function(e,t,n){var i=document.createElement("canvas");BI.Widget._renderEngine.createElement("body").append(i);var r=i.getContext("2d");r.font="12px Georgia";var a=r.measureText(e).width+4;i.width=2*a,i.height=32,r.font="24px Georgia",r.fillStyle=t||"#3685f2",r.textBaseline="middle",r.fillText(e,4,18),BI.Widget._renderEngine.createElement(i).destroy();var o=n||"rgba(54, 133, 242, 0.1)";return{width:a,height:16,src:i.toDataURL("image/png"),style:"background-color: "+o+";vertical-align: middle; margin: 0 1px; width:"+a+"px;height: 16px; max-width:"+a+"px;max-height: 16px; min-width:"+a+"px;min-height: 16px",param:e}}}),BI.extend(BI.DOM,{isColor:function(e){return e&&(this.isRGBColor(e)||this.isHexColor(e))},isRGBColor:function(e){return!!e&&"rgb"===e.substr(0,3)},isHexColor:function(e){return!!e&&("#"===e[0]&&7===e.length)},isDarkColor:function(e){if(!e||!this.isHexColor(e))return!1;var t=this.rgb2json(this.hex2rgb(e));return Math.round(.299*t.r+.587*t.g+.114*t.b)<192},getContrastColor:function(e){return e&&this.isColor(e)?this.isDarkColor(e)?"#ffffff":"#1a1a1a":""},rgb2hex:function(e){if(!e||"rgb"!=e.substr(0,3))return"";var t=e.match(/\d+(\.\d+)?/g),n=BI.parseInt(t[0]),i=BI.parseInt(t[1]),r=BI.parseInt(t[2]);return"#"+this.int2hex(n)+this.int2hex(i)+this.int2hex(r)},rgb2json:function(e){if(!e)return{};if(!this.isRGBColor(e))return{};var t=e.match(/\d+(\.\d+)?/g);return{r:BI.parseInt(t[0]),g:BI.parseInt(t[1]),b:BI.parseInt(t[2])}},rgba2json:function(e){if(!e)return{};var t=e.match(/\d+(\.\d+)?/g);return{r:BI.parseInt(t[0]),g:BI.parseInt(t[1]),b:BI.parseInt(t[2]),a:BI.parseFloat(t[3])}},json2rgb:function(e){return BI.isKey(e.r)&&BI.isKey(e.g)&&BI.isKey(e.b)?"rgb("+e.r+","+e.g+","+e.b+")":""},json2rgba:function(e){return BI.isKey(e.r)&&BI.isKey(e.g)&&BI.isKey(e.b)?"rgba("+e.r+","+e.g+","+e.b+","+e.a+")":""},int2hex:function(e){var t=["0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"];return t[e>>>4]+""+t[15&e]},hex2rgb:function(e){if(!e)return"";if(!this.isHexColor(e))return e;var t,n="rgb(";return 7===e.length?t=[BI.parseInt("0x"+e.substring(1,3)),BI.parseInt("0x"+e.substring(3,5)),BI.parseInt("0x"+e.substring(5,7))]:4===e.length&&(t=[BI.parseInt("0x"+e.substring(1,2)),BI.parseInt("0x"+e.substring(2,3)),BI.parseInt("0x"+e.substring(3,4))]),n+=t[0]+",",n+=t[1]+",",n+=t[2]+")"},rgba2rgb:function(e,t){if(BI.isNull(t)&&(t=1),"rgba"!=e.substr(0,4))return"";var n=e.match(/\d+(\.\d+)?/g);if(n.length<4)return"";var i=BI.parseFloat(n[0]),r=BI.parseFloat(n[1]),a=BI.parseFloat(n[2]),o=BI.parseFloat(n[3]);return"rgb("+Math.floor(t*(1-o)*255+i*o)+","+Math.floor(t*(1-o)*255+r*o)+","+Math.floor(t*(1-o)*255+a*o)+")"}}),BI.extend(BI.DOM,{getLeftPosition:function(e,t,n){return{left:e.element.offset().left-t.element.outerWidth()-(n||0)}},getInnerLeftPosition:function(e,t,n){return{left:e.element.offset().left+(n||0)}},getRightPosition:function(e,t,n){var i=e.element;return{left:i.offset().left+i.outerWidth()+(n||0)}},getInnerRightPosition:function(e,t,n){var i=e.element,r=t.element.bounds();return{left:i.offset().left+i.outerWidth()-r.width-(n||0)}},getTopPosition:function(e,t,n){return{top:e.element.offset().top-t.element.outerHeight()-(n||0)}},getBottomPosition:function(e,t,n){var i=e.element;return{top:i.offset().top+i.outerHeight()+(n||0)}},isLeftSpaceEnough:function(e,t,n){return 0<=BI.DOM.getLeftPosition(e,t,n).left},isInnerLeftSpaceEnough:function(e,t,n){var i=t.element.bounds(),r=BI.Widget._renderEngine.createElement("body").bounds();return BI.DOM.getInnerLeftPosition(e,t,n).left+i.width<=r.width},isRightSpaceEnough:function(e,t,n){var i=t.element.bounds(),r=BI.Widget._renderEngine.createElement("body").bounds();return BI.DOM.getRightPosition(e,t,n).left+i.width<=r.width},isInnerRightSpaceEnough:function(e,t,n){return 0<=BI.DOM.getInnerRightPosition(e,t,n).left},isTopSpaceEnough:function(e,t,n){return 0<=BI.DOM.getTopPosition(e,t,n).top},isBottomSpaceEnough:function(e,t,n){var i=t.element.bounds(),r=BI.Widget._renderEngine.createElement("body").bounds();return BI.DOM.getBottomPosition(e,t,n).top+i.height<=r.height},isRightSpaceLarger:function(e){return BI.Widget._renderEngine.createElement("body").bounds().width-e.element.offset().left-e.element.bounds().width>=e.element.offset().left},isBottomSpaceLarger:function(e){return BI.Widget._renderEngine.createElement("body").bounds().height-e.element.offset().top-e.element.bounds().height>=e.element.offset().top},getLeftAlignPosition:function(e,t,n){var i=t.element.bounds(),r=BI.Widget._renderEngine.createElement("body").bounds(),a=e.element.offset().left+n;return a+i.width>r.width&&(a=r.width-i.width),a<0&&(a=0),{left:a}},getLeftAdaptPosition:function(e,t,n){return BI.DOM.isLeftSpaceEnough(e,t,n)?BI.DOM.getLeftPosition(e,t,n):{left:0}},getRightAlignPosition:function(e,t,n){var i=e.element.bounds(),r=t.element.bounds(),a=e.element.offset().left+i.width-r.width-n;return a<0&&(a=0),{left:a}},getRightAdaptPosition:function(e,t,n){return BI.DOM.isRightSpaceEnough(e,t,n)?BI.DOM.getRightPosition(e,t,n):{left:BI.Widget._renderEngine.createElement("body").bounds().width-t.element.bounds().width}},getTopAlignPosition:function(e,t,n,i){var r,a,o=e.element.offset(),s=e.element.bounds(),l=t.element.bounds(),u=BI.Widget._renderEngine.createElement("body").bounds();return BI.DOM.isBottomSpaceEnough(e,t,-1*s.height+n)?r=o.top+n:i?(r=o.top+n,a=u.height-r):(r=u.height-l.height)a.height?{top:0,adaptHeight:a.height-n}:{top:0}},getBottomAlignPosition:function(e,t,n,i){var r,a,o=e.element.offset(),s=e.element.bounds(),l=t.element.bounds(),u=BI.Widget._renderEngine.createElement("body").bounds();return BI.DOM.isTopSpaceEnough(e,t,-1*s.height+n)?r=o.top+s.height-l.height-n:i?(r=0,a=o.top+s.height-n):(r=0,l.height+n>u.height&&(a=u.height-n)),r<0&&(r=0),a?{top:r,adaptHeight:a}:{top:r}},getBottomAdaptPosition:function(e,t,n,i){var r=e.element.offset(),a=e.element.bounds(),o=t.element.bounds(),s=BI.Widget._renderEngine.createElement("body").bounds();return BI.DOM.isBottomSpaceEnough(e,t,n)?BI.DOM.getBottomPosition(e,t,n):i?{top:r.top+a.height+n,adaptHeight:s.height-r.top-a.height-n}:o.height+n>s.height?{top:n,adaptHeight:s.height-n}:{top:s.height-o.height-n}},getCenterAdaptPosition:function(e,t){var n=e.element.offset(),i=e.element.bounds(),r=t.element.bounds(),a=BI.Widget._renderEngine.createElement("body").bounds(),o=n.left+i.width/2+r.width/2>a.width?a.width-r.width:n.left+i.width/2-r.width/2;return o<0&&(o=0),{left:o}},getMiddleAdaptPosition:function(e,t){var n=e.element.offset(),i=e.element.bounds(),r=t.element.bounds(),a=BI.Widget._renderEngine.createElement("body").bounds(),o=n.top+i.height/2+r.height/2>a.height?a.height-r.height:n.top+i.height/2-r.height/2;return o<0&&(o=0),{top:o}},getComboPositionByDirections:function(e,t,n,i,r,a){var o;n=n||0,i=i||0;for(var s,l,u,c=[],h=[],p=[],d=!1,f=!1,g=!1,m=a[0],I=0;I)[^>]*|#([\w-]*))$/,b=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,y=/^[\],:{}\s]*$/,C=/(?:^|:|,)(?:\s*\[)+/g,N=/\\(?:["\\\/bfnrt]|u[\da-fA-F]{4})/g,V=/"[^"\\\r\n]*"|true|false|null|-?(?:\d+\.|)\d+(?:[eE][+-]?\d+|)/g,S=/^-ms-/,x=/-([\da-z])/gi,w=function(e,t){return t.toUpperCase()},A=function(e){!m.addEventListener&&"load"!==e.type&&"complete"!==m.readyState||(L(),de.ready())},L=function(){m.addEventListener?(m.removeEventListener("DOMContentLoaded",A,!1),g.removeEventListener("load",A,!1)):(m.detachEvent("onreadystatechange",A),g.detachEvent("onload",A))};function k(e){var t=e.length,n=de.type(e);return!de.isWindow(e)&&(!(1!==e.nodeType||!t)||("array"===n||"function"!==n&&(0===t||"number"==typeof t&&0"===e.charAt(e.length-1)&&3<=e.length?[null,e,null]:E.exec(e))||!i[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(i[1]){if(t=t instanceof de?t[0]:t,de.merge(this,de.parseHTML(i[1],t&&t.nodeType?t.ownerDocument||t:m,!0)),b.test(i[1])&&de.isPlainObject(t))for(i in t)de.isFunction(this[i])?this[i](t[i]):this.attr(i,t[i]);return this}if((r=m.getElementById(i[2]))&&r.parentNode){if(r.id!==i[2])return n.find(e);this.length=1,this[0]=r}return this.context=m,this.selector=e,this},selector:"",length:0,size:function(){return this.length},toArray:function(){return p.call(this)},get:function(e){return null==e?this.toArray():e<0?this[this.length+e]:this[e]},pushStack:function(e){var t=de.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return de.each(this,e,t)},ready:function(e){return de.ready.promise().done(e),this},slice:function(){return this.pushStack(p.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n
a",e=c.getElementsByTagName("*"),t=c.getElementsByTagName("a")[0],!e||!t||!e.length)return{};o=(i=m.createElement("select")).appendChild(m.createElement("option")),n=c.getElementsByTagName("input")[0],t.style.cssText="top:1px;float:left;opacity:.5",a={getSetAttribute:"t"!==c.className,leadingWhitespace:3===c.firstChild.nodeType,tbody:!c.getElementsByTagName("tbody").length,htmlSerialize:!!c.getElementsByTagName("link").length,style:/top/.test(t.getAttribute("style")),hrefNormalized:"/a"===t.getAttribute("href"),opacity:/^0.5/.test(t.style.opacity),cssFloat:!!t.style.cssFloat,checkOn:!!n.value,optSelected:o.selected,enctype:!!m.createElement("form").enctype,html5Clone:"<:nav>"!==m.createElement("nav").cloneNode(!0).outerHTML,boxModel:"CSS1Compat"===m.compatMode,deleteExpando:!0,noCloneEvent:!0,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableMarginRight:!0,boxSizingReliable:!0,pixelPosition:!1},n.checked=!0,a.noCloneChecked=n.cloneNode(!0).checked,i.disabled=!0,a.optDisabled=!o.disabled;try{delete c.test}catch(h){a.deleteExpando=!1}for(u in(n=m.createElement("input")).setAttribute("value",""),a.input=""===n.getAttribute("value"),n.value="t",n.setAttribute("type","radio"),a.radioValue="t"===n.value,n.setAttribute("checked","t"),n.setAttribute("name","t"),(r=m.createDocumentFragment()).appendChild(n),a.appendChecked=n.checked,a.checkClone=r.cloneNode(!0).cloneNode(!0).lastChild.checked,c.attachEvent&&(c.attachEvent("onclick",function(){a.noCloneEvent=!1}),c.cloneNode(!0).click()),{submit:!0,change:!0,focusin:!0})c.setAttribute(s="on"+u,"t"),a[u+"Bubbles"]=s in g||!1===c.attributes[s].expando;return c.style.backgroundClip="content-box",c.cloneNode(!0).style.backgroundClip="",a.clearCloneStyle="content-box"===c.style.backgroundClip,de(function(){var e,t,n,i="padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;",r=m.getElementsByTagName("body")[0];r&&((e=m.createElement("div")).style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",r.appendChild(e).appendChild(c),c.innerHTML="
t
",(n=c.getElementsByTagName("td"))[0].style.cssText="padding:0;margin:0;border:0;display:none",l=0===n[0].offsetHeight,n[0].style.display="",n[1].style.display="none",a.reliableHiddenOffsets=l&&0===n[0].offsetHeight,c.innerHTML="",c.style.cssText="box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;",a.boxSizing=4===c.offsetWidth,a.doesNotIncludeMarginInBodyOffset=1!==r.offsetTop,g.getComputedStyle&&(a.pixelPosition="1%"!==(g.getComputedStyle(c,null)||{}).top,a.boxSizingReliable="4px"===(g.getComputedStyle(c,null)||{width:"4px"}).width,(t=c.appendChild(m.createElement("div"))).style.cssText=c.style.cssText=i,t.style.marginRight=t.style.width="0",c.style.width="1px",a.reliableMarginRight=!parseFloat((g.getComputedStyle(t,null)||{}).marginRight)),typeof c.style.zoom!==I&&(c.innerHTML="",c.style.cssText=i+"width:1px;padding:1px;display:inline;zoom:1",a.inlineBlockNeedsLayout=3===c.offsetWidth,c.style.display="block",c.innerHTML="
",c.firstChild.style.width="5px",a.shrinkWrapBlocks=3!==c.offsetWidth,a.inlineBlockNeedsLayout&&(r.style.zoom=1)),r.removeChild(e),e=c=n=t=null)}),e=i=r=t=n=null,a}();var M=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,P=/([A-Z])/g;function R(e,t,n,i){if(de.acceptData(e)){var r,a,o=de.expando,s="string"==typeof t,l=e.nodeType,u=l?de.cache:e,c=l?e[o]:e[o]&&o;if(c&&u[c]&&(i||u[c].data)||!s||n!==v)return c||(l?e[o]=c=h.pop()||de.guid++:c=o),u[c]||(u[c]={},l||(u[c].toJSON=de.noop)),"object"!=typeof t&&"function"!=typeof t||(i?u[c]=de.extend(u[c],t):u[c].data=de.extend(u[c].data,t)),r=u[c],i||(r.data||(r.data={}),r=r.data),n!==v&&(r[de.camelCase(t)]=n),s?null==(a=r[t])&&(a=r[de.camelCase(t)]):a=r,a}}function H(e,t,n){if(de.acceptData(e)){var i,r,a,o=e.nodeType,s=o?de.cache:e,l=o?e[de.expando]:de.expando;if(s[l]){if(t&&(a=n?s[l]:s[l].data)){for((i=0,r=(t=de.isArray(t)?t.concat(de.map(t,de.camelCase)):t in a||(t=de.camelCase(t))in a?[t]:t.split(" ")).length);i+~])"+L+"*"),F=new RegExp(P),W=new RegExp("^"+D+"$"),Y={ID:new RegExp("^#("+k+")"),CLASS:new RegExp("^\\.("+k+")"),NAME:new RegExp("^\\[name=['\"]?("+k+")['\"]?\\]"),TAG:new RegExp("^("+k.replace("w","w*")+")"),ATTR:new RegExp("^"+M),PSEUDO:new RegExp("^"+P),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+L+"*(even|odd|(([+-]|)(\\d*)n|)"+L+"*(?:([+-]|)"+L+"*(\\d+)|))"+L+"*\\)|)","i"),needsContext:new RegExp("^"+L+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+L+"*((?:-\\d)?\\d*)"+L+"*\\)|)(?=[^-]|$)","i")},G=/[\x20\t\r\n\f]*[+~]/,j=/^[^{]+\{\s*\[native code/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,X=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/'|\\/g,z=/\=[\x20\t\r\n\f]*([^'"\]]*)[\x20\t\r\n\f]*\]/g,U=/\\([\da-fA-F]{1,6}[\x20\t\r\n\f]?|.)/g,Q=function(e,t){var n="0x"+t-65536;return n!=n?t:n<0?String.fromCharCode(65536+n):String.fromCharCode(n>>10|55296,1023&n|56320)};try{w.call(E.documentElement.childNodes,0)[0].nodeType}catch(pe){w=function(e){for(var t,n=[];t=this[e++];)n.push(t);return n}}function q(e){return j.test(e+"")}function $(){var n,i=[];return n=function(e,t){return i.push(e+=" ")>y.cacheLength&&delete n[i.shift()],n[e]=t}}function ee(e){return e[C]=!0,e}function te(e){var t=T.createElement("div");try{return e(t)}catch(pe){return!1}finally{t=null}}function ne(e,t,n,i){var r,a,o,s,l,u,c,h,p,d;if((t?t.ownerDocument||t:E)!==T&&m(t),n=n||[],!e||"string"!=typeof e)return n;if(1!==(s=(t=t||T).nodeType)&&9!==s)return[];if(!I&&!i){if(r=Z.exec(e))if(o=r[1]){if(9===s){if(!(a=t.getElementById(o))||!a.parentNode)return n;if(a.id===o)return n.push(a),n}else if(t.ownerDocument&&(a=t.ownerDocument.getElementById(o))&&_(t,a)&&a.id===o)return n.push(a),n}else{if(r[2])return x.apply(n,w.call(t.getElementsByTagName(e),0)),n;if((o=r[3])&&N.getByClassName&&t.getElementsByClassName)return x.apply(n,w.call(t.getElementsByClassName(o),0)),n}if(N.qsa&&!B.test(e)){if(c=!0,h=C,p=t,d=9===s&&e,1===s&&"object"!==t.nodeName.toLowerCase()){for(u=ae(e),(c=t.getAttribute("id"))?h=c.replace(K,"\\$&"):t.setAttribute("id",h),h="[id='"+h+"'] ",l=u.length;l--;)u[l]=h+oe(u[l]);p=G.test(e)&&t.parentNode||t,d=u.join(",")}if(d)try{return x.apply(n,w.call(p.querySelectorAll(d),0)),n}catch(f){}finally{c||t.removeAttribute("id")}}}return function(e,t,n,i){var r,a,o,s,l,u=ae(e);if(!i&&1===u.length){if(2<(a=u[0]=u[0].slice(0)).length&&"ID"===(o=a[0]).type&&9===t.nodeType&&!I&&y.relative[a[1].type]){if(!(t=y.find.ID(o.matches[0].replace(U,Q),t)[0]))return n;e=e.slice(a.shift().value.length)}for(r=Y.needsContext.test(e)?0:a.length;r--&&(o=a[r],!y.relative[s=o.type]);)if((l=y.find[s])&&(i=l(o.matches[0].replace(U,Q),G.test(a[0].type)&&t.parentNode||t))){if(a.splice(r,1),!(e=i.length&&oe(a)))return x.apply(n,w.call(i,0)),n;break}}return g(e,u)(i,t,I,n,G.test(e)),n}(e.replace(R,"$1"),t,n,i)}function ie(e,t){var n=t&&e,i=n&&(~t.sourceIndex||1<<31)-(~e.sourceIndex||1<<31);if(i)return i;if(n)for(;n=n.nextSibling;)if(n===t)return-1;return e?1:-1}function re(o){return ee(function(a){return a=+a,ee(function(e,t){for(var n,i=o([],e.length,a),r=i.length;r--;)e[n=i[r]]&&(e[n]=!(t[n]=e[n]))})})}for(e in t=ne.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return!!t&&"HTML"!==t.nodeName},m=ne.setDocument=function(e){var l=e?e.ownerDocument||e:E;return l!==T&&9===l.nodeType&&l.documentElement&&(i=(T=l).documentElement,I=t(l),N.tagNameNoComments=te(function(e){return e.appendChild(l.createComment("")),!e.getElementsByTagName("*").length}),N.attributes=te(function(e){e.innerHTML="";var t=typeof e.lastChild.getAttribute("multiple");return"boolean"!=t&&"string"!=t}),N.getByClassName=te(function(e){return e.innerHTML="",!(!e.getElementsByClassName||!e.getElementsByClassName("e").length)&&(e.lastChild.className="e",2===e.getElementsByClassName("e").length)}),N.getByName=te(function(e){e.id=C+0,e.innerHTML="
",i.insertBefore(e,i.firstChild);var t=l.getElementsByName&&l.getElementsByName(C).length===2+l.getElementsByName(C+0).length;return N.getIdNotName=!l.getElementById(C),i.removeChild(e),t}),y.attrHandle=te(function(e){return e.innerHTML="",e.firstChild&&typeof e.firstChild.getAttribute!=d&&"#"===e.firstChild.getAttribute("href")})?{}:{href:function(e){return e.getAttribute("href",2)},type:function(e){return e.getAttribute("type")}},N.getIdNotName?(y.find.ID=function(e,t){if(typeof t.getElementById!=d&&!I){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},y.filter.ID=function(e){var t=e.replace(U,Q);return function(e){return e.getAttribute("id")===t}}):(y.find.ID=function(e,t){if(typeof t.getElementById!=d&&!I){var n=t.getElementById(e);return n?n.id===e||typeof n.getAttributeNode!=d&&n.getAttributeNode("id").value===e?[n]:void 0:[]}},y.filter.ID=function(e){var n=e.replace(U,Q);return function(e){var t=typeof e.getAttributeNode!=d&&e.getAttributeNode("id");return t&&t.value===n}}),y.find.TAG=N.tagNameNoComments?function(e,t){if(typeof t.getElementsByTagName!=d)return t.getElementsByTagName(e)}:function(e,t){var n,i=[],r=0,a=t.getElementsByTagName(e);if("*"!==e)return a;for(;n=a[r++];)1===n.nodeType&&i.push(n);return i},y.find.NAME=N.getByName&&function(e,t){if(typeof t.getElementsByName!=d)return t.getElementsByName(name)},y.find.CLASS=N.getByClassName&&function(e,t){if(typeof t.getElementsByClassName!=d&&!I)return t.getElementsByClassName(e)},r=[],B=[":focus"],(N.qsa=q(l.querySelectorAll))&&(te(function(e){e.innerHTML="",e.querySelectorAll("[selected]").length||B.push("\\["+L+"*(?:checked|disabled|ismap|multiple|readonly|selected|value)"),e.querySelectorAll(":checked").length||B.push(":checked")}),te(function(e){e.innerHTML="",e.querySelectorAll("[i^='']").length&&B.push("[*^$]="+L+"*(?:\"\"|'')"),e.querySelectorAll(":enabled").length||B.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),B.push(",.*:")})),(N.matchesSelector=q(o=i.matchesSelector||i.mozMatchesSelector||i.webkitMatchesSelector||i.oMatchesSelector||i.msMatchesSelector))&&te(function(e){N.disconnectedMatch=o.call(e,"div"),o.call(e,"[s!='']:x"),r.push("!=",P)}),B=new RegExp(B.join("|")),r=new RegExp(r.join("|")),_=q(i.contains)||i.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,i=t&&t.parentNode;return e===i||!(!i||1!==i.nodeType||!(n.contains?n.contains(i):e.compareDocumentPosition&&16&e.compareDocumentPosition(i)))}:function(e,t){if(t)for(;t=t.parentNode;)if(t===e)return!0;return!1},s=i.compareDocumentPosition?function(e,t){var n;return e===t?(u=!0,0):(n=t.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(t))?1&n||e.parentNode&&11===e.parentNode.nodeType?e===l||_(E,e)?-1:t===l||_(E,t)?1:0:4&n?-1:1:e.compareDocumentPosition?-1:1}:function(e,t){var n,i=0,r=e.parentNode,a=t.parentNode,o=[e],s=[t];if(e===t)return u=!0,0;if(!r||!a)return e===l?-1:t===l?1:r?-1:a?1:0;if(r===a)return ie(e,t);for(n=e;n=n.parentNode;)o.unshift(n);for(n=t;n=n.parentNode;)s.unshift(n);for(;o[i]===s[i];)i++;return i?ie(o[i],s[i]):o[i]===E?-1:s[i]===E?1:0},u=!1,[0,0].sort(s),N.detectDuplicates=u),T},ne.matches=function(e,t){return ne(e,null,null,t)},ne.matchesSelector=function(e,t){if((e.ownerDocument||e)!==T&&m(e),t=t.replace(z,"='$1']"),N.matchesSelector&&!I&&(!r||!r.test(t))&&!B.test(t))try{var n=o.call(e,t);if(n||N.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(pe){}return 0":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(U,Q),e[3]=(e[4]||e[5]||"").replace(U,Q),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ne.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ne.error(e[0]),e},PSEUDO:function(e){var t,n=!e[5]&&e[2];return Y.CHILD.test(e[0])?null:(e[4]?e[2]=e[4]:n&&F.test(n)&&(t=ae(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(t){return"*"===t?function(){return!0}:(t=t.replace(U,Q).toLowerCase(),function(e){return e.nodeName&&e.nodeName.toLowerCase()===t})},CLASS:function(e){var t=l[e+" "];return t||(t=new RegExp("(^|"+L+")"+e+"("+L+"|$)"))&&l(e,function(e){return t.test(e.className||typeof e.getAttribute!=d&&e.getAttribute("class")||"")})},ATTR:function(n,i,r){return function(e){var t=ne.attr(e,n);return null==t?"!="===i:!i||(t+="","="===i?t===r:"!="===i?t!==r:"^="===i?r&&0===t.indexOf(r):"*="===i?r&&-1]","i"),me=/^\s+/,Ie=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,Be=/<([\w:]+)/,_e=/\s*$/g,Ve={option:[1,""],legend:[1,"
","
"],area:[1,"",""],param:[1,"",""],thead:[1,"","
"],tr:[2,"","
"],col:[2,"","
"],td:[3,"","
"],_default:de.support.htmlSerialize?[0,"",""]:[1,"X
","
"]},Se=he(m).appendChild(m.createElement("div"));function xe(e){var t=e.getAttributeNode("type");return e.type=(t&&t.specified)+"/"+e.type,e}function we(e){var t=Ce.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function Ae(e,t){for(var n,i=0;null!=(n=e[i]);i++)de._data(n,"globalEval",!t||de._data(t[i],"globalEval"))}function Le(e,t){if(1===t.nodeType&&de.hasData(e)){var n,i,r,a=de._data(e),o=de._data(t,a),s=a.events;if(s)for(n in delete o.handle,o.events={},s)for(i=0,r=s[n].length;i");try{for(;n")?a=e.cloneNode(!0):(Se.innerHTML=e.outerHTML,Se.removeChild(a=Se.firstChild)),!(de.support.noCloneEvent&&de.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||de.isXMLDoc(e)))for(i=ke(a),s=ke(e),o=0;null!=(r=s[o]);++o)i[o]&&function(e,t){var n,i,r;if(1===t.nodeType){if(n=t.nodeName.toLowerCase(),!de.support.noCloneEvent&&t[de.expando]){for(i in(r=de._data(t)).events)de.removeEvent(t,i,r.handle);t.removeAttribute(de.expando)}"script"===n&&t.text!==e.text?(xe(t).text=e.text,we(t)):"object"===n?(t.parentNode&&(t.outerHTML=e.outerHTML),de.support.html5Clone&&e.innerHTML&&!de.trim(t.innerHTML)&&(t.innerHTML=e.innerHTML)):"input"===n&&ye.test(e.type)?(t.defaultChecked=t.checked=e.checked,t.value!==e.value&&(t.value=e.value)):"option"===n?t.defaultSelected=t.selected=e.defaultSelected:"input"!==n&&"textarea"!==n||(t.defaultValue=e.defaultValue)}}(r,i[o]);if(t)if(n)for(s=s||ke(e),i=i||ke(a),o=0;null!=(r=s[o]);o++)Le(r,i[o]);else Le(e,a);return 0<(i=ke(a,"script")).length&&Ae(i,!l&&ke(e,"script")),i=s=r=null,a},buildFragment:function(e,t,n,i){for(var r,a,o,s,l,u,c,h=e.length,p=he(t),d=[],f=0;f")+c[2],r=c[0];r--;)s=s.lastChild;if(!de.support.leadingWhitespace&&me.test(a)&&d.push(t.createTextNode(me.exec(a)[0])),!de.support.tbody)for(r=(a="table"!==l||_e.test(a)?""!==c[1]||_e.test(a)?0:s:s.firstChild)&&a.childNodes.length;r--;)de.nodeName(u=a.childNodes[r],"tbody")&&!u.childNodes.length&&a.removeChild(u);for(de.merge(d,s.childNodes),s.textContent="";s.firstChild;)s.removeChild(s.firstChild);s=p.lastChild}else d.push(t.createTextNode(a));for(s&&p.removeChild(s),de.support.appendChecked||de.grep(ke(d,"input"),De),f=0;a=d[f++];)if((!i||-1===de.inArray(a,i))&&(o=de.contains(a.ownerDocument,a),s=ke(p.appendChild(a),"script"),o&&Ae(s),n))for(r=0;a=s[r++];)Te.test(a.type||"")&&n.push(a);return s=null,p},cleanData:function(e,t){for(var n,i,r,a,o=0,s=de.expando,l=de.cache,u=de.support.deleteExpando,c=de.event.special;null!=(n=e[o]);o++)if((t||de.acceptData(n))&&(a=(r=n[s])&&l[r])){if(a.events)for(i in a.events)c[i]?de.event.remove(n,i):de.removeEvent(n,i,a.handle);l[r]&&(delete l[r],u?delete n[s]:typeof n.removeAttribute!==I?n.removeAttribute(s):n[s]=null,h.push(r))}}});var Me,Pe,Re,He=/alpha\([^)]*\)/i,Oe=/opacity\s*=\s*([^)]*)/,Fe=/^(top|right|bottom|left)$/,We=/^(none|table(?!-c[ea]).+)/,Ye=/^margin/,Ge=new RegExp("^("+d+")(.*)$","i"),je=new RegExp("^("+d+")(?!px)[a-z%]+$","i"),Ze=new RegExp("^([+-])=("+d+")","i"),Xe={BODY:"block"},Je={position:"absolute",visibility:"hidden",display:"block"},Ke={letterSpacing:0,fontWeight:400},ze=["Top","Right","Bottom","Left"],Ue=["Webkit","O","Moz","ms"];function Qe(e,t){if(t in e)return t;for(var n=t.charAt(0).toUpperCase()+t.slice(1),i=t,r=Ue.length;r--;)if((t=Ue[r]+n)in e)return t;return i}function qe(e,t){return e=t||e,"none"===de.css(e,"display")||!de.contains(e.ownerDocument,e)}function $e(e,t){for(var n,i,r,a=[],o=0,s=e.length;o").css("cssText","display:block !important")).appendTo(t.documentElement))[0].contentWindow||Me[0].contentDocument).document).write(""),t.close(),n=rt(e,t),Me.detach()),Xe[e]=n),n}function rt(e,t){var n=de(t.createElement(e)).appendTo(t.body),i=de.css(n[0],"display");return n.remove(),i}de.fn.extend({css:function(e,t){return de.access(this,function(e,t,n){var i,r,a={},o=0;if(de.isArray(t)){for(r=Pe(e),i=t.length;o").append(de.parseHTML(e)).find(i):e)}).complete(n&&function(e,t){o.each(n,r||[e.responseText,t,e])}),this},de.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){de.fn[t]=function(e){return this.on(t,e)}}),de.each(["get","post"],function(e,r){de[r]=function(e,t,n,i){return de.isFunction(t)&&(i=i||n,n=t,t=v),de.ajax({url:e,type:r,dataType:i,data:t,success:n})}}),de.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:ht,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(ct[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":vt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText"},converters:{"* text":g.String,"text html":!0,"text json":de.parseJSON,"text xml":de.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Nt(Nt(e,de.ajaxSettings),t):Nt(de.ajaxSettings,e)},ajaxPrefilter:Tt(bt),ajaxTransport:Tt(yt),ajax:function(e,t){"object"==typeof e&&(t=e,e=v),t=t||{};var n,i,c,h,p,d,f,r,g=de.ajaxSetup({},t),m=g.context||g,I=g.context&&(m.nodeType||m.jquery)?de(m):de.event,B=de.Deferred(),_=de.Callbacks("once memory"),E=g.statusCode||{},a={},o={},b=0,s="canceled",y={readyState:0,getResponseHeader:function(e){var t;if(2===b){if(!r)for(r={};t=mt.exec(h);)r[t[1].toLowerCase()]=t[2];t=r[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return 2===b?h:null},setRequestHeader:function(e,t){var n=e.toLowerCase();return b||(e=o[n]=o[n]||e,a[e]=t),this},overrideMimeType:function(e){return b||(g.mimeType=e),this},statusCode:function(e){var t;if(e)if(b<2)for(t in e)E[t]=[E[t],e[t]];else y.always(e[y.status]);return this},abort:function(e){var t=e||s;return f&&f.abort(t),l(0,t),this}};if(B.promise(y).complete=_.add,y.success=y.done,y.error=y.fail,g.url=((e||g.url||ht)+"").replace(ft,"").replace(Bt,ct[1]+"//"),g.type=t.method||t.type||g.method||g.type,g.dataTypes=de.trim(g.dataType||"*").toLowerCase().match(T)||[""],null==g.crossDomain&&(n=_t.exec(g.url.toLowerCase()),g.crossDomain=!(!n||n[1]===ct[1]&&n[2]===ct[2]&&(n[3]||("http:"===n[1]?80:443))==(ct[3]||("http:"===ct[1]?80:443)))),g.data&&g.processData&&"string"!=typeof g.data&&(g.data=de.param(g.data,g.traditional)),Ct(bt,g,t,y),2===b)return y;for(i in(d=g.global)&&0==de.active++&&de.event.trigger("ajaxStart"),g.type=g.type.toUpperCase(),g.hasContent=!It.test(g.type),c=g.url,g.hasContent||(g.data&&(c=g.url+=(dt.test(c)?"&":"?")+g.data,delete g.data),!1===g.cache&&(g.url=gt.test(c)?c.replace(gt,"$1_="+pt++):c+(dt.test(c)?"&":"?")+"_="+pt++)),g.ifModified&&(de.lastModified[c]&&y.setRequestHeader("If-Modified-Since",de.lastModified[c]),de.etag[c]&&y.setRequestHeader("If-None-Match",de.etag[c])),(g.data&&g.hasContent&&!1!==g.contentType||t.contentType)&&y.setRequestHeader("Content-Type",g.contentType),y.setRequestHeader("Accept",g.dataTypes[0]&&g.accepts[g.dataTypes[0]]?g.accepts[g.dataTypes[0]]+("*"!==g.dataTypes[0]?", "+vt+"; q=0.01":""):g.accepts["*"]),g.headers)y.setRequestHeader(i,g.headers[i]);if(g.beforeSend&&(!1===g.beforeSend.call(m,y,g)||2===b))return y.abort();for(i in s="abort",{success:1,error:1,complete:1})y[i](g[i]);if(f=Ct(yt,g,t,y)){y.readyState=1,d&&I.trigger("ajaxSend",[y,g]),g.async&&0").addClass("bi-keyword-red-mark").html(BI.htmlEncode(i.substr(r,n.length)))),i=i.substr(r+n.length),BI.isNotEmptyString(t)&&(t=BI.map(t.split("​"),function(e,t){return t.slice(r+n.length)}).join("​"));else{if(!(0<=a)){this.append(BI.htmlEncode(i));break}this.append(BI.htmlEncode(i.substr(0,a))),this.append(BI.$("").addClass("bi-keyword-red-mark").html(BI.htmlEncode(i.substr(a,n.length)))),BI.isNotEmptyString(t)&&(t=BI.map(t.split("​"),function(e,t){return t.slice(a+n.length)}).join("​")),i=i.substr(a+n.length)}}return this},getDomHeight:function(e){var t=BI.$(this).clone();t.appendTo(BI.$(e||"body"));var n=t.height();return t.remove(),n},hasVerticalScroll:function(){return 0t.left+n||e.pageYt.top+i)},__hasZIndexMask__:function(e){return e&&null!=this.zIndexMask[e]},__buildZIndexMask__:function(e,t){this.zIndexMask=this.zIndexMask||{},this.indexMask=this.indexMask||[];var n=BI.createWidget({type:"bi.center_adapt",cls:"bi-z-index-mask",items:t});return n.element.css({"z-index":e}),BI.createWidget({type:"bi.absolute",element:this,items:[{el:n,left:0,right:0,top:0,bottom:0}]}),this.indexMask.push(n),e&&(this.zIndexMask[e]=n),n.element},__releaseZIndexMask__:function(e){if(e&&this.zIndexMask[e])return BI.remove(this.indexMask,this.zIndexMask[e]),void this.zIndexMask[e].destroy();this.indexMask=this.indexMask||[];var t=this.indexMask.pop();t&&t.destroy()}}))},function(e,t){var r;_.extend(BI,{$import:(r={},function(n,e,t){var i;!function(n,i){var e=BI.$("head script, body script");BI.$.each(e,function(e,t){-1!=t.src.indexOf(n)&&(r[n]=!0)});var t=BI.$("head link");BI.$.each(t,function(e,t){-1!=t.href.indexOf(n)&&i&&(r[n]=!1,BI.$(t).remove())})}(n,t),!0!==r[n]&&("css"===e?((i=document.createElement("link")).rel="stylesheet",i.type="text/css",i.href=n,document.getElementsByTagName("head")[0].appendChild(i),r[n]=!0):BI.$.ajax({url:n,dataType:"script",async:!1,cache:!0,complete:function(e,t){"success"==t&&(r[n]=!0)}}))})})},function(e,t){!function(){var e={on:function(e,t,n){return h(this,"on",e,[t,n])&&t&&(this._events||(this._events={}),(this._events[e]||(this._events[e]=[])).push({callback:t,context:n,ctx:n||this})),this},once:function(e,t,n){if(!h(this,"once",e,[t,n])||!t)return this;var i=this,r=_.once(function(){i.off(e,r),t.apply(this,arguments)});return r._callback=t,this.on(e,r,n)},off:function(e,t,n){if(!this._events||!h(this,"off",e,[t,n]))return this;if(!e&&!t&&!n)return this._events=void 0,this;for(var i=e?[e]:_.keys(this._events),r=0,a=i.length;r=9?["wheel"]:["mousewheel","DomMouseScroll","MozMousePixelScroll"],d=Array.prototype.slice,f,g;if(p.event.fixHooks){for(var n=e.length;n;){p.event.fixHooks[e[--n]]=p.event.mouseHooks}}var m=p.event.special.mousewheel={version:"3.1.12",setup:function(){if(this.addEventListener){for(var e=t.length;e;){this.addEventListener(t[--e],i,false)}}else{this.onmousewheel=i}},teardown:function(){if(this.removeEventListener){for(var e=t.length;e;){this.removeEventListener(t[--e],i,false)}}else{this.onmousewheel=null}},settings:{adjustOldDeltas:true,normalizeOffset:true}};function i(e){var t=e||_global.event,n=d.call(arguments,1),i=0,r=0,a=0,o=0,s=0,l=0;e=p.event.fix(t);e.type="mousewheel";if("detail"in t){a=t.detail*-1}if("wheelDelta"in t){a=t.wheelDelta}if("wheelDeltaY"in t){a=t.wheelDeltaY}if("wheelDeltaX"in t){r=t.wheelDeltaX*-1}if("axis"in t&&t.axis===t.HORIZONTAL_AXIS){r=a*-1;a=0}i=a===0?r:a;if("deltaY"in t){a=t.deltaY*-1;i=a}if("deltaX"in t){r=t.deltaX;if(a===0){i=r*-1}}if(a===0&&r===0){return}if(t.deltaMode===1){var u=40;i*=u;a*=u;r*=u}else if(t.deltaMode===2){var c=800;i*=c;a*=c;r*=c}o=Math.max(Math.abs(a),Math.abs(r));if(!g||o=1?"floor":"ceil"](i/g);r=Math[r>=1?"floor":"ceil"](r/g);a=Math[a>=1?"floor":"ceil"](a/g);if(m.settings.normalizeOffset&&this.getBoundingClientRect){var h=this.getBoundingClientRect();s=e.clientX-h.left;l=e.clientY-h.top}e.deltaX=r;e.deltaY=a;e.deltaFactor=g;e.offsetX=s;e.offsetY=l;e.deltaMode=0;n.unshift(e,i,r,a);if(f){clearTimeout(f)}f=setTimeout(I,200);return(p.event.dispatch||p.event.handle).apply(this,n)}function I(){g=null}function B(e,t){return m.settings.adjustOldDeltas&&e.type==="mousewheel"&&t%120===0}p.fn.extend({mousewheel:function(e){return e?this.bind("mousewheel",e):this.trigger("mousewheel")},unmousewheel:function(e){return this.unbind("mousewheel",e)}})}(BI.jQuery)},function(e,t){!function(){var e=" !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~⺀⺁⺂⺃⺄⺅⺆⺇⺈⺉⺊⺋⺌⺍⺎⺏⺐⺑⺒⺓⺔⺕⺖⺗⺘⺙⺚⺛⺜⺝⺞⺟⺠⺡⺢⺣⺤⺥⺦⺧⺨⺩⺪⺫⺬⺭⺮⺯⺰⺱⺲⺳⺴⺵⺶⺷⺸⺹⺺⺻⺼⺽⺾⺿⻀⻁⻂⻃⻄⻅⻆⻇⻈⻉⻊⻋⻌⻍⻎⻏⻐⻑⻒⻓⻔⻕⻖⻗⻘⻙⻚⻛⻜⻝⻞⻟⻠⻡⻢⻣⻤⻥⻦⻧⻨⻩⻪⻫⻬⻭⻮⻯⻰⻱⻲⻳⻴⻵⻶⻷⻸⻹⻺⻻⻼⻽⻾⻿⼀⼁⼂⼃⼄⼅⼆⼇⼈⼉⼊⼋⼌⼍⼎⼏⼐⼑⼒⼓⼔⼕⼖⼗⼘⼙⼚⼛⼜⼝⼞⼟⼠⼡⼢⼣⼤⼥⼦⼧⼨⼩⼪⼫⼬⼭⼮⼯⼰⼱⼲⼳⼴⼵⼶⼷⼸⼹⼺⼻⼼⼽⼾⼿⽀⽁⽂⽃⽄⽅⽆⽇⽈⽉⽊⽋⽌⽍⽎⽏⽐⽑⽒⽓⽔⽕⽖⽗⽘⽙⽚⽛⽜⽝⽞⽟⽠⽡⽢⽣⽤⽥⽦⽧⽨⽩⽪⽫⽬⽭⽮⽯⽰⽱⽲⽳⽴⽵⽶⽷⽸⽹⽺⽻⽼⽽⽾⽿⾀⾁⾂⾃⾄⾅⾆⾇⾈⾉⾊⾋⾌⾍⾎⾏⾐⾑⾒⾓⾔⾕⾖⾗⾘⾙⾚⾛⾜⾝⾞⾟⾠⾡⾢⾣⾤⾥⾦⾧⾨⾩⾪⾫⾬⾭⾮⾯⾰⾱⾲⾳⾴⾵⾶⾷⾸⾹⾺⾻⾼⾽⾾⾿⿀⿁⿂⿃⿄⿅⿆⿇⿈⿉⿊⿋⿌⿍⿎⿏⿐⿑⿒⿓⿔⿕⿖⿗⿘⿙⿚⿛⿜⿝⿞⿟⿠⿡⿢⿣⿤⿥⿦⿧⿨⿩⿪⿫⿬⿭⿮⿯⿰⿱⿲⿳⿴⿵⿶⿷⿸⿹⿺⿻⿼⿽⿾⿿ 、。〃〄々〆〇〈〉《》「」『』【】〒〓〔〕〖〗〘〙〚〛〜〝〞〟〠〡〢〣〤〥〦〧〨〩〪〭〮〯〫〬〰〱〲〳〴〵〶〷〸〹〺〻〼〽〾〿぀ぁあぃいぅうぇえぉおかがきぎくぐけげこごさざしじすずせぜそぞただちぢっつづてでとどなにぬねのはばぱひびぴふぶぷへべぺほぼぽまみむめもゃやゅゆょよらりるれろゎわゐゑをんゔゕゖ゗゘゙゚゛゜ゝゞゟ゠ァアィイゥウェエォオカガキギクグケゲコゴサザシジスズセゼソゾタダチヂッツヅテデトドナニヌネノハバパヒビピフブプヘベペホボポマミムメモャヤュユョヨラリルレロヮワヰヱヲンヴヵヶヷヸヹヺ・ーヽヾヿ㄀㄁㄂㄃㄄ㄅㄆㄇㄈㄉㄊㄋㄌㄍㄎㄏㄐㄑㄒㄓㄔㄕㄖㄗㄘㄙㄚㄛㄜㄝㄞㄟㄠㄡㄢㄣㄤㄥㄦㄧㄨㄩㄪㄫㄬㄭㄮㄯ㄰ㄱㄲㄳㄴㄵㄶㄷㄸㄹㄺㄻㄼㄽㄾㄿㅀㅁㅂㅃㅄㅅㅆㅇㅈㅉㅊㅋㅌㅍㅎㅏㅐㅑㅒㅓㅔㅕㅖㅗㅘㅙㅚㅛㅜㅝㅞㅟㅠㅡㅢㅣㅤㅥㅦㅧㅨㅩㅪㅫㅬㅭㅮㅯㅰㅱㅲㅳㅴㅵㅶㅷㅸㅹㅺㅻㅼㅽㅾㅿㆀㆁㆂㆃㆄㆅㆆㆇㆈㆉㆊㆋㆌㆍㆎ㆏㆐㆑㆒㆓㆔㆕㆖㆗㆘㆙㆚㆛㆜㆝㆞㆟ㆠㆡㆢㆣㆤㆥㆦㆧㆨㆩㆪㆫㆬㆭㆮㆯㆰㆱㆲㆳㆴㆵㆶㆷㆸㆹㆺㆻㆼㆽㆾㆿ㇀㇁㇂㇃㇄㇅㇆㇇㇈㇉㇊㇋㇌㇍㇎㇏㇐㇑㇒㇓㇔㇕㇖㇗㇘㇙㇚㇛㇜㇝㇞㇟㇠㇡㇢㇣㇤㇥㇦㇧㇨㇩㇪㇫㇬㇭㇮㇯ㇰㇱㇲㇳㇴㇵㇶㇷㇸㇹㇺㇻㇼㇽㇾㇿ㈀㈁㈂㈃㈄㈅㈆㈇㈈㈉㈊㈋㈌㈍㈎㈏㈐㈑㈒㈓㈔㈕㈖㈗㈘㈙㈚㈛㈜㈝㈞㈟㈠㈡㈢㈣㈤㈥㈦㈧㈨㈩㈪㈫㈬㈭㈮㈯㈰㈱㈲㈳㈴㈵㈶㈷㈸㈹㈺㈻㈼㈽㈾㈿㉀㉁㉂㉃㉄㉅㉆㉇㉈㉉㉊㉋㉌㉍㉎㉏㉐㉑㉒㉓㉔㉕㉖㉗㉘㉙㉚㉛㉜㉝㉞㉟㉠㉡㉢㉣㉤㉥㉦㉧㉨㉩㉪㉫㉬㉭㉮㉯㉰㉱㉲㉳㉴㉵㉶㉷㉸㉹㉺㉻㉼㉽㉾㉿㊀㊁㊂㊃㊄㊅㊆㊇㊈㊉㊊㊋㊌㊍㊎㊏㊐㊑㊒㊓㊔㊕㊖㊗㊘㊙㊚㊛㊜㊝㊞㊟㊠㊡㊢㊣㊤㊥㊦㊧㊨㊩㊪㊫㊬㊭㊮㊯㊰㊱㊲㊳㊴㊵㊶㊷㊸㊹㊺㊻㊼㊽㊾㊿㋀㋁㋂㋃㋄㋅㋆㋇㋈㋉㋊㋋㋌㋍㋎㋏㋐㋑㋒㋓㋔㋕㋖㋗㋘㋙㋚㋛㋜㋝㋞㋟㋠㋡㋢㋣㋤㋥㋦㋧㋨㋩㋪㋫㋬㋭㋮㋯㋰㋱㋲㋳㋴㋵㋶㋷㋸㋹㋺㋻㋼㋽㋾㋿㌀㌁㌂㌃㌄㌅㌆㌇㌈㌉㌊㌋㌌㌍㌎㌏㌐㌑㌒㌓㌔㌕㌖㌗㌘㌙㌚㌛㌜㌝㌞㌟㌠㌡㌢㌣㌤㌥㌦㌧㌨㌩㌪㌫㌬㌭㌮㌯㌰㌱㌲㌳㌴㌵㌶㌷㌸㌹㌺㌻㌼㌽㌾㌿㍀㍁㍂㍃㍄㍅㍆㍇㍈㍉㍊㍋㍌㍍㍎㍏㍐㍑㍒㍓㍔㍕㍖㍗㍘㍙㍚㍛㍜㍝㍞㍟㍠㍡㍢㍣㍤㍥㍦㍧㍨㍩㍪㍫㍬㍭㍮㍯㍰㍱㍲㍳㍴㍵㍶㍷㍸㍹㍺㍻㍼㍽㍾㍿㎀㎁㎂㎃㎄㎅㎆㎇㎈㎉㎊㎋㎌㎍㎎㎏㎐㎑㎒㎓㎔㎕㎖㎗㎘㎙㎚㎛㎜㎝㎞㎟㎠㎡㎢㎣㎤㎥㎦㎧㎨㎩㎪㎫㎬㎭㎮㎯㎰㎱㎲㎳㎴㎵㎶㎷㎸㎹㎺㎻㎼㎽㎾㎿㏀㏁㏂㏃㏄㏅㏆㏇㏈㏉㏊㏋㏌㏍㏎㏏㏐㏑㏒㏓㏔㏕㏖㏗㏘㏙㏚㏛㏜㏝㏞㏟㏠㏡㏢㏣㏤㏥㏦㏧㏨㏩㏪㏫㏬㏭㏮㏯㏰㏱㏲㏳㏴㏵㏶㏷㏸㏹㏺㏻㏼㏽㏾㏿㐀㐁㐂㐃㐄㐅㐆㐇㐈㐉㐊㐋㐌㐍㐎㐏㐐㐑㐒㐓㐔㐕㐖㐗㐘㐙㐚㐛㐜㐝㐞㐟㐠㐡㐢㐣㐤㐥㐦㐧㐨㐩㐪㐫㐬㐭㐮㐯㐰㐱㐲㐳㐴㐵㐶㐷㐸㐹㐺㐻㐼㐽㐾㐿㑀㑁㑂㑃㑄㑅㑆㑇㑈㑉㑊㑋㑌㑍㑎㑏㑐㑑㑒㑓㑔㑕㑖㑗㑘㑙㑚㑛㑜㑝㑞㑟㑠㑡㑢㑣㑤㑥㑦㑧㑨㑩㑪㑫㑬㑭㑮㑯㑰㑱㑲㑳㑴㑵㑶㑷㑸㑹㑺㑻㑼㑽㑾㑿㒀㒁㒂㒃㒄㒅㒆㒇㒈㒉㒊㒋㒌㒍㒎㒏㒐㒑㒒㒓㒔㒕㒖㒗㒘㒙㒚㒛㒜㒝㒞㒟㒠㒡㒢㒣㒤㒥㒦㒧㒨㒩㒪㒫㒬㒭㒮㒯㒰㒱㒲㒳㒴㒵㒶㒷㒸㒹㒺㒻㒼㒽㒾㒿㓀㓁㓂㓃㓄㓅㓆㓇㓈㓉㓊㓋㓌㓍㓎㓏㓐㓑㓒㓓㓔㓕㓖㓗㓘㓙㓚㓛㓜㓝㓞㓟㓠㓡㓢㓣㓤㓥㓦㓧㓨㓩㓪㓫㓬㓭㓮㓯㓰㓱㓲㓳㓴㓵㓶㓷㓸㓹㓺㓻㓼㓽㓾㓿㔀㔁㔂㔃㔄㔅㔆㔇㔈㔉㔊㔋㔌㔍㔎㔏㔐㔑㔒㔓㔔㔕㔖㔗㔘㔙㔚㔛㔜㔝㔞㔟㔠㔡㔢㔣㔤㔥㔦㔧㔨㔩㔪㔫㔬㔭㔮㔯㔰㔱㔲㔳㔴㔵㔶㔷㔸㔹㔺㔻㔼㔽㔾㔿㕀㕁㕂㕃㕄㕅㕆㕇㕈㕉㕊㕋㕌㕍㕎㕏㕐㕑㕒㕓㕔㕕㕖㕗㕘㕙㕚㕛㕜㕝㕞㕟㕠㕡㕢㕣㕤㕥㕦㕧㕨㕩㕪㕫㕬㕭㕮㕯㕰㕱㕲㕳㕴㕵㕶㕷㕸㕹㕺㕻㕼㕽㕾㕿㖀㖁㖂㖃㖄㖅㖆㖇㖈㖉㖊㖋㖌㖍㖎㖏㖐㖑㖒㖓㖔㖕㖖㖗㖘㖙㖚㖛㖜㖝㖞㖟㖠㖡㖢㖣㖤㖥㖦㖧㖨㖩㖪㖫㖬㖭㖮㖯㖰㖱㖲㖳㖴㖵㖶㖷㖸㖹㖺㖻㖼㖽㖾㖿㗀㗁㗂㗃㗄㗅㗆㗇㗈㗉㗊㗋㗌㗍㗎㗏㗐㗑㗒㗓㗔㗕㗖㗗㗘㗙㗚㗛㗜㗝㗞㗟㗠㗡㗢㗣㗤㗥㗦㗧㗨㗩㗪㗫㗬㗭㗮㗯㗰㗱㗲㗳㗴㗵㗶㗷㗸㗹㗺㗻㗼㗽㗾㗿㘀㘁㘂㘃㘄㘅㘆㘇㘈㘉㘊㘋㘌㘍㘎㘏㘐㘑㘒㘓㘔㘕㘖㘗㘘㘙㘚㘛㘜㘝㘞㘟㘠㘡㘢㘣㘤㘥㘦㘧㘨㘩㘪㘫㘬㘭㘮㘯㘰㘱㘲㘳㘴㘵㘶㘷㘸㘹㘺㘻㘼㘽㘾㘿㙀㙁㙂㙃㙄㙅㙆㙇㙈㙉㙊㙋㙌㙍㙎㙏㙐㙑㙒㙓㙔㙕㙖㙗㙘㙙㙚㙛㙜㙝㙞㙟㙠㙡㙢㙣㙤㙥㙦㙧㙨㙩㙪㙫㙬㙭㙮㙯㙰㙱㙲㙳㙴㙵㙶㙷㙸㙹㙺㙻㙼㙽㙾㙿㚀㚁㚂㚃㚄㚅㚆㚇㚈㚉㚊㚋㚌㚍㚎㚏㚐㚑㚒㚓㚔㚕㚖㚗㚘㚙㚚㚛㚜㚝㚞㚟㚠㚡㚢㚣㚤㚥㚦㚧㚨㚩㚪㚫㚬㚭㚮㚯㚰㚱㚲㚳㚴㚵㚶㚷㚸㚹㚺㚻㚼㚽㚾㚿㛀㛁㛂㛃㛄㛅㛆㛇㛈㛉㛊㛋㛌㛍㛎㛏㛐㛑㛒㛓㛔㛕㛖㛗㛘㛙㛚㛛㛜㛝㛞㛟㛠㛡㛢㛣㛤㛥㛦㛧㛨㛩㛪㛫㛬㛭㛮㛯㛰㛱㛲㛳㛴㛵㛶㛷㛸㛹㛺㛻㛼㛽㛾㛿㜀㜁㜂㜃㜄㜅㜆㜇㜈㜉㜊㜋㜌㜍㜎㜏㜐㜑㜒㜓㜔㜕㜖㜗㜘㜙㜚㜛㜜㜝㜞㜟㜠㜡㜢㜣㜤㜥㜦㜧㜨㜩㜪㜫㜬㜭㜮㜯㜰㜱㜲㜳㜴㜵㜶㜷㜸㜹㜺㜻㜼㜽㜾㜿㝀㝁㝂㝃㝄㝅㝆㝇㝈㝉㝊㝋㝌㝍㝎㝏㝐㝑㝒㝓㝔㝕㝖㝗㝘㝙㝚㝛㝜㝝㝞㝟㝠㝡㝢㝣㝤㝥㝦㝧㝨㝩㝪㝫㝬㝭㝮㝯㝰㝱㝲㝳㝴㝵㝶㝷㝸㝹㝺㝻㝼㝽㝾㝿㞀㞁㞂㞃㞄㞅㞆㞇㞈㞉㞊㞋㞌㞍㞎㞏㞐㞑㞒㞓㞔㞕㞖㞗㞘㞙㞚㞛㞜㞝㞞㞟㞠㞡㞢㞣㞤㞥㞦㞧㞨㞩㞪㞫㞬㞭㞮㞯㞰㞱㞲㞳㞴㞵㞶㞷㞸㞹㞺㞻㞼㞽㞾㞿㟀㟁㟂㟃㟄㟅㟆㟇㟈㟉㟊㟋㟌㟍㟎㟏㟐㟑㟒㟓㟔㟕㟖㟗㟘㟙㟚㟛㟜㟝㟞㟟㟠㟡㟢㟣㟤㟥㟦㟧㟨㟩㟪㟫㟬㟭㟮㟯㟰㟱㟲㟳㟴㟵㟶㟷㟸㟹㟺㟻㟼㟽㟾㟿㠀㠁㠂㠃㠄㠅㠆㠇㠈㠉㠊㠋㠌㠍㠎㠏㠐㠑㠒㠓㠔㠕㠖㠗㠘㠙㠚㠛㠜㠝㠞㠟㠠㠡㠢㠣㠤㠥㠦㠧㠨㠩㠪㠫㠬㠭㠮㠯㠰㠱㠲㠳㠴㠵㠶㠷㠸㠹㠺㠻㠼㠽㠾㠿㡀㡁㡂㡃㡄㡅㡆㡇㡈㡉㡊㡋㡌㡍㡎㡏㡐㡑㡒㡓㡔㡕㡖㡗㡘㡙㡚㡛㡜㡝㡞㡟㡠㡡㡢㡣㡤㡥㡦㡧㡨㡩㡪㡫㡬㡭㡮㡯㡰㡱㡲㡳㡴㡵㡶㡷㡸㡹㡺㡻㡼㡽㡾㡿㢀㢁㢂㢃㢄㢅㢆㢇㢈㢉㢊㢋㢌㢍㢎㢏㢐㢑㢒㢓㢔㢕㢖㢗㢘㢙㢚㢛㢜㢝㢞㢟㢠㢡㢢㢣㢤㢥㢦㢧㢨㢩㢪㢫㢬㢭㢮㢯㢰㢱㢲㢳㢴㢵㢶㢷㢸㢹㢺㢻㢼㢽㢾㢿㣀㣁㣂㣃㣄㣅㣆㣇㣈㣉㣊㣋㣌㣍㣎㣏㣐㣑㣒㣓㣔㣕㣖㣗㣘㣙㣚㣛㣜㣝㣞㣟㣠㣡㣢㣣㣤㣥㣦㣧㣨㣩㣪㣫㣬㣭㣮㣯㣰㣱㣲㣳㣴㣵㣶㣷㣸㣹㣺㣻㣼㣽㣾㣿㤀㤁㤂㤃㤄㤅㤆㤇㤈㤉㤊㤋㤌㤍㤎㤏㤐㤑㤒㤓㤔㤕㤖㤗㤘㤙㤚㤛㤜㤝㤞㤟㤠㤡㤢㤣㤤㤥㤦㤧㤨㤩㤪㤫㤬㤭㤮㤯㤰㤱㤲㤳㤴㤵㤶㤷㤸㤹㤺㤻㤼㤽㤾㤿㥀㥁㥂㥃㥄㥅㥆㥇㥈㥉㥊㥋㥌㥍㥎㥏㥐㥑㥒㥓㥔㥕㥖㥗㥘㥙㥚㥛㥜㥝㥞㥟㥠㥡㥢㥣㥤㥥㥦㥧㥨㥩㥪㥫㥬㥭㥮㥯㥰㥱㥲㥳㥴㥵㥶㥷㥸㥹㥺㥻㥼㥽㥾㥿㦀㦁㦂㦃㦄㦅㦆㦇㦈㦉㦊㦋㦌㦍㦎㦏㦐㦑㦒㦓㦔㦕㦖㦗㦘㦙㦚㦛㦜㦝㦞㦟㦠㦡㦢㦣㦤㦥㦦㦧㦨㦩㦪㦫㦬㦭㦮㦯㦰㦱㦲㦳㦴㦵㦶㦷㦸㦹㦺㦻㦼㦽㦾㦿㧀㧁㧂㧃㧄㧅㧆㧇㧈㧉㧊㧋㧌㧍㧎㧏㧐㧑㧒㧓㧔㧕㧖㧗㧘㧙㧚㧛㧜㧝㧞㧟㧠㧡㧢㧣㧤㧥㧦㧧㧨㧩㧪㧫㧬㧭㧮㧯㧰㧱㧲㧳㧴㧵㧶㧷㧸㧹㧺㧻㧼㧽㧾㧿㨀㨁㨂㨃㨄㨅㨆㨇㨈㨉㨊㨋㨌㨍㨎㨏㨐㨑㨒㨓㨔㨕㨖㨗㨘㨙㨚㨛㨜㨝㨞㨟㨠㨡㨢㨣㨤㨥㨦㨧㨨㨩㨪㨫㨬㨭㨮㨯㨰㨱㨲㨳㨴㨵㨶㨷㨸㨹㨺㨻㨼㨽㨾㨿㩀㩁㩂㩃㩄㩅㩆㩇㩈㩉㩊㩋㩌㩍㩎㩏㩐㩑㩒㩓㩔㩕㩖㩗㩘㩙㩚㩛㩜㩝㩞㩟㩠㩡㩢㩣㩤㩥㩦㩧㩨㩩㩪㩫㩬㩭㩮㩯㩰㩱㩲㩳㩴㩵㩶㩷㩸㩹㩺㩻㩼㩽㩾㩿㪀㪁㪂㪃㪄㪅㪆㪇㪈㪉㪊㪋㪌㪍㪎㪏㪐㪑㪒㪓㪔㪕㪖㪗㪘㪙㪚㪛㪜㪝㪞㪟㪠㪡㪢㪣㪤㪥㪦㪧㪨㪩㪪㪫㪬㪭㪮㪯㪰㪱㪲㪳㪴㪵㪶㪷㪸㪹㪺㪻㪼㪽㪾㪿㫀㫁㫂㫃㫄㫅㫆㫇㫈㫉㫊㫋㫌㫍㫎㫏㫐㫑㫒㫓㫔㫕㫖㫗㫘㫙㫚㫛㫜㫝㫞㫟㫠㫡㫢㫣㫤㫥㫦㫧㫨㫩㫪㫫㫬㫭㫮㫯㫰㫱㫲㫳㫴㫵㫶㫷㫸㫹㫺㫻㫼㫽㫾㫿㬀㬁㬂㬃㬄㬅㬆㬇㬈㬉㬊㬋㬌㬍㬎㬏㬐㬑㬒㬓㬔㬕㬖㬗㬘㬙㬚㬛㬜㬝㬞㬟㬠㬡㬢㬣㬤㬥㬦㬧㬨㬩㬪㬫㬬㬭㬮㬯㬰㬱㬲㬳㬴㬵㬶㬷㬸㬹㬺㬻㬼㬽㬾㬿㭀㭁㭂㭃㭄㭅㭆㭇㭈㭉㭊㭋㭌㭍㭎㭏㭐㭑㭒㭓㭔㭕㭖㭗㭘㭙㭚㭛㭜㭝㭞㭟㭠㭡㭢㭣㭤㭥㭦㭧㭨㭩㭪㭫㭬㭭㭮㭯㭰㭱㭲㭳㭴㭵㭶㭷㭸㭹㭺㭻㭼㭽㭾㭿㮀㮁㮂㮃㮄㮅㮆㮇㮈㮉㮊㮋㮌㮍㮎㮏㮐㮑㮒㮓㮔㮕㮖㮗㮘㮙㮚㮛㮜㮝㮞㮟㮠㮡㮢㮣㮤㮥㮦㮧㮨㮩㮪㮫㮬㮭㮮㮯㮰㮱㮲㮳㮴㮵㮶㮷㮸㮹㮺㮻㮼㮽㮾㮿㯀㯁㯂㯃㯄㯅㯆㯇㯈㯉㯊㯋㯌㯍㯎㯏㯐㯑㯒㯓㯔㯕㯖㯗㯘㯙㯚㯛㯜㯝㯞㯟㯠㯡㯢㯣㯤㯥㯦㯧㯨㯩㯪㯫㯬㯭㯮㯯㯰㯱㯲㯳㯴㯵㯶㯷㯸㯹㯺㯻㯼㯽㯾㯿㰀㰁㰂㰃㰄㰅㰆㰇㰈㰉㰊㰋㰌㰍㰎㰏㰐㰑㰒㰓㰔㰕㰖㰗㰘㰙㰚㰛㰜㰝㰞㰟㰠㰡㰢㰣㰤㰥㰦㰧㰨㰩㰪㰫㰬㰭㰮㰯㰰㰱㰲㰳㰴㰵㰶㰷㰸㰹㰺㰻㰼㰽㰾㰿㱀㱁㱂㱃㱄㱅㱆㱇㱈㱉㱊㱋㱌㱍㱎㱏㱐㱑㱒㱓㱔㱕㱖㱗㱘㱙㱚㱛㱜㱝㱞㱟㱠㱡㱢㱣㱤㱥㱦㱧㱨㱩㱪㱫㱬㱭㱮㱯㱰㱱㱲㱳㱴㱵㱶㱷㱸㱹㱺㱻㱼㱽㱾㱿㲀㲁㲂㲃㲄㲅㲆㲇㲈㲉㲊㲋㲌㲍㲎㲏㲐㲑㲒㲓㲔㲕㲖㲗㲘㲙㲚㲛㲜㲝㲞㲟㲠㲡㲢㲣㲤㲥㲦㲧㲨㲩㲪㲫㲬㲭㲮㲯㲰㲱㲲㲳㲴㲵㲶㲷㲸㲹㲺㲻㲼㲽㲾㲿㳀㳁㳂㳃㳄㳅㳆㳇㳈㳉㳊㳋㳌㳍㳎㳏㳐㳑㳒㳓㳔㳕㳖㳗㳘㳙㳚㳛㳜㳝㳞㳟㳠㳡㳢㳣㳤㳥㳦㳧㳨㳩㳪㳫㳬㳭㳮㳯㳰㳱㳲㳳㳴㳵㳶㳷㳸㳹㳺㳻㳼㳽㳾㳿㴀㴁㴂㴃㴄㴅㴆㴇㴈㴉㴊㴋㴌㴍㴎㴏㴐㴑㴒㴓㴔㴕㴖㴗㴘㴙㴚㴛㴜㴝㴞㴟㴠㴡㴢㴣㴤㴥㴦㴧㴨㴩㴪㴫㴬㴭㴮㴯㴰㴱㴲㴳㴴㴵㴶㴷㴸㴹㴺㴻㴼㴽㴾㴿㵀㵁㵂㵃㵄㵅㵆㵇㵈㵉㵊㵋㵌㵍㵎㵏㵐㵑㵒㵓㵔㵕㵖㵗㵘㵙㵚㵛㵜㵝㵞㵟㵠㵡㵢㵣㵤㵥㵦㵧㵨㵩㵪㵫㵬㵭㵮㵯㵰㵱㵲㵳㵴㵵㵶㵷㵸㵹㵺㵻㵼㵽㵾㵿㶀㶁㶂㶃㶄㶅㶆㶇㶈㶉㶊㶋㶌㶍㶎㶏㶐㶑㶒㶓㶔㶕㶖㶗㶘㶙㶚㶛㶜㶝㶞㶟㶠㶡㶢㶣㶤㶥㶦㶧㶨㶩㶪㶫㶬㶭㶮㶯㶰㶱㶲㶳㶴㶵㶶㶷㶸㶹㶺㶻㶼㶽㶾㶿㷀㷁㷂㷃㷄㷅㷆㷇㷈㷉㷊㷋㷌㷍㷎㷏㷐㷑㷒㷓㷔㷕㷖㷗㷘㷙㷚㷛㷜㷝㷞㷟㷠㷡㷢㷣㷤㷥㷦㷧㷨㷩㷪㷫㷬㷭㷮㷯㷰㷱㷲㷳㷴㷵㷶㷷㷸㷹㷺㷻㷼㷽㷾㷿㸀㸁㸂㸃㸄㸅㸆㸇㸈㸉㸊㸋㸌㸍㸎㸏㸐㸑㸒㸓㸔㸕㸖㸗㸘㸙㸚㸛㸜㸝㸞㸟㸠㸡㸢㸣㸤㸥㸦㸧㸨㸩㸪㸫㸬㸭㸮㸯㸰㸱㸲㸳㸴㸵㸶㸷㸸㸹㸺㸻㸼㸽㸾㸿㹀㹁㹂㹃㹄㹅㹆㹇㹈㹉㹊㹋㹌㹍㹎㹏㹐㹑㹒㹓㹔㹕㹖㹗㹘㹙㹚㹛㹜㹝㹞㹟㹠㹡㹢㹣㹤㹥㹦㹧㹨㹩㹪㹫㹬㹭㹮㹯㹰㹱㹲㹳㹴㹵㹶㹷㹸㹹㹺㹻㹼㹽㹾㹿㺀㺁㺂㺃㺄㺅㺆㺇㺈㺉㺊㺋㺌㺍㺎㺏㺐㺑㺒㺓㺔㺕㺖㺗㺘㺙㺚㺛㺜㺝㺞㺟㺠㺡㺢㺣㺤㺥㺦㺧㺨㺩㺪㺫㺬㺭㺮㺯㺰㺱㺲㺳㺴㺵㺶㺷㺸㺹㺺㺻㺼㺽㺾㺿㻀㻁㻂㻃㻄㻅㻆㻇㻈㻉㻊㻋㻌㻍㻎㻏㻐㻑㻒㻓㻔㻕㻖㻗㻘㻙㻚㻛㻜㻝㻞㻟㻠㻡㻢㻣㻤㻥㻦㻧㻨㻩㻪㻫㻬㻭㻮㻯㻰㻱㻲㻳㻴㻵㻶㻷㻸㻹㻺㻻㻼㻽㻾㻿㼀㼁㼂㼃㼄㼅㼆㼇㼈㼉㼊㼋㼌㼍㼎㼏㼐㼑㼒㼓㼔㼕㼖㼗㼘㼙㼚㼛㼜㼝㼞㼟㼠㼡㼢㼣㼤㼥㼦㼧㼨㼩㼪㼫㼬㼭㼮㼯㼰㼱㼲㼳㼴㼵㼶㼷㼸㼹㼺㼻㼼㼽㼾㼿㽀㽁㽂㽃㽄㽅㽆㽇㽈㽉㽊㽋㽌㽍㽎㽏㽐㽑㽒㽓㽔㽕㽖㽗㽘㽙㽚㽛㽜㽝㽞㽟㽠㽡㽢㽣㽤㽥㽦㽧㽨㽩㽪㽫㽬㽭㽮㽯㽰㽱㽲㽳㽴㽵㽶㽷㽸㽹㽺㽻㽼㽽㽾㽿㾀㾁㾂㾃㾄㾅㾆㾇㾈㾉㾊㾋㾌㾍㾎㾏㾐㾑㾒㾓㾔㾕㾖㾗㾘㾙㾚㾛㾜㾝㾞㾟㾠㾡㾢㾣㾤㾥㾦㾧㾨㾩㾪㾫㾬㾭㾮㾯㾰㾱㾲㾳㾴㾵㾶㾷㾸㾹㾺㾻㾼㾽㾾㾿㿀㿁㿂㿃㿄㿅㿆㿇㿈㿉㿊㿋㿌㿍㿎㿏㿐㿑㿒㿓㿔㿕㿖㿗㿘㿙㿚㿛㿜㿝㿞㿟㿠㿡㿢㿣㿤㿥㿦㿧㿨㿩㿪㿫㿬㿭㿮㿯㿰㿱㿲㿳㿴㿵㿶㿷㿸㿹㿺㿻㿼㿽㿾㿿䀀䀁䀂䀃䀄䀅䀆䀇䀈䀉䀊䀋䀌䀍䀎䀏䀐䀑䀒䀓䀔䀕䀖䀗䀘䀙䀚䀛䀜䀝䀞䀟䀠䀡䀢䀣䀤䀥䀦䀧䀨䀩䀪䀫䀬䀭䀮䀯䀰䀱䀲䀳䀴䀵䀶䀷䀸䀹䀺䀻䀼䀽䀾䀿䁀䁁䁂䁃䁄䁅䁆䁇䁈䁉䁊䁋䁌䁍䁎䁏䁐䁑䁒䁓䁔䁕䁖䁗䁘䁙䁚䁛䁜䁝䁞䁟䁠䁡䁢䁣䁤䁥䁦䁧䁨䁩䁪䁫䁬䁭䁮䁯䁰䁱䁲䁳䁴䁵䁶䁷䁸䁹䁺䁻䁼䁽䁾䁿䂀䂁䂂䂃䂄䂅䂆䂇䂈䂉䂊䂋䂌䂍䂎䂏䂐䂑䂒䂓䂔䂕䂖䂗䂘䂙䂚䂛䂜䂝䂞䂟䂠䂡䂢䂣䂤䂥䂦䂧䂨䂩䂪䂫䂬䂭䂮䂯䂰䂱䂲䂳䂴䂵䂶䂷䂸䂹䂺䂻䂼䂽䂾䂿䃀䃁䃂䃃䃄䃅䃆䃇䃈䃉䃊䃋䃌䃍䃎䃏䃐䃑䃒䃓䃔䃕䃖䃗䃘䃙䃚䃛䃜䃝䃞䃟䃠䃡䃢䃣䃤䃥䃦䃧䃨䃩䃪䃫䃬䃭䃮䃯䃰䃱䃲䃳䃴䃵䃶䃷䃸䃹䃺䃻䃼䃽䃾䃿䄀䄁䄂䄃䄄䄅䄆䄇䄈䄉䄊䄋䄌䄍䄎䄏䄐䄑䄒䄓䄔䄕䄖䄗䄘䄙䄚䄛䄜䄝䄞䄟䄠䄡䄢䄣䄤䄥䄦䄧䄨䄩䄪䄫䄬䄭䄮䄯䄰䄱䄲䄳䄴䄵䄶䄷䄸䄹䄺䄻䄼䄽䄾䄿䅀䅁䅂䅃䅄䅅䅆䅇䅈䅉䅊䅋䅌䅍䅎䅏䅐䅑䅒䅓䅔䅕䅖䅗䅘䅙䅚䅛䅜䅝䅞䅟䅠䅡䅢䅣䅤䅥䅦䅧䅨䅩䅪䅫䅬䅭䅮䅯䅰䅱䅲䅳䅴䅵䅶䅷䅸䅹䅺䅻䅼䅽䅾䅿䆀䆁䆂䆃䆄䆅䆆䆇䆈䆉䆊䆋䆌䆍䆎䆏䆐䆑䆒䆓䆔䆕䆖䆗䆘䆙䆚䆛䆜䆝䆞䆟䆠䆡䆢䆣䆤䆥䆦䆧䆨䆩䆪䆫䆬䆭䆮䆯䆰䆱䆲䆳䆴䆵䆶䆷䆸䆹䆺䆻䆼䆽䆾䆿䇀䇁䇂䇃䇄䇅䇆䇇䇈䇉䇊䇋䇌䇍䇎䇏䇐䇑䇒䇓䇔䇕䇖䇗䇘䇙䇚䇛䇜䇝䇞䇟䇠䇡䇢䇣䇤䇥䇦䇧䇨䇩䇪䇫䇬䇭䇮䇯䇰䇱䇲䇳䇴䇵䇶䇷䇸䇹䇺䇻䇼䇽䇾䇿䈀䈁䈂䈃䈄䈅䈆䈇䈈䈉䈊䈋䈌䈍䈎䈏䈐䈑䈒䈓䈔䈕䈖䈗䈘䈙䈚䈛䈜䈝䈞䈟䈠䈡䈢䈣䈤䈥䈦䈧䈨䈩䈪䈫䈬䈭䈮䈯䈰䈱䈲䈳䈴䈵䈶䈷䈸䈹䈺䈻䈼䈽䈾䈿䉀䉁䉂䉃䉄䉅䉆䉇䉈䉉䉊䉋䉌䉍䉎䉏䉐䉑䉒䉓䉔䉕䉖䉗䉘䉙䉚䉛䉜䉝䉞䉟䉠䉡䉢䉣䉤䉥䉦䉧䉨䉩䉪䉫䉬䉭䉮䉯䉰䉱䉲䉳䉴䉵䉶䉷䉸䉹䉺䉻䉼䉽䉾䉿䊀䊁䊂䊃䊄䊅䊆䊇䊈䊉䊊䊋䊌䊍䊎䊏䊐䊑䊒䊓䊔䊕䊖䊗䊘䊙䊚䊛䊜䊝䊞䊟䊠䊡䊢䊣䊤䊥䊦䊧䊨䊩䊪䊫䊬䊭䊮䊯䊰䊱䊲䊳䊴䊵䊶䊷䊸䊹䊺䊻䊼䊽䊾䊿䋀䋁䋂䋃䋄䋅䋆䋇䋈䋉䋊䋋䋌䋍䋎䋏䋐䋑䋒䋓䋔䋕䋖䋗䋘䋙䋚䋛䋜䋝䋞䋟䋠䋡䋢䋣䋤䋥䋦䋧䋨䋩䋪䋫䋬䋭䋮䋯䋰䋱䋲䋳䋴䋵䋶䋷䋸䋹䋺䋻䋼䋽䋾䋿䌀䌁䌂䌃䌄䌅䌆䌇䌈䌉䌊䌋䌌䌍䌎䌏䌐䌑䌒䌓䌔䌕䌖䌗䌘䌙䌚䌛䌜䌝䌞䌟䌠䌡䌢䌣䌤䌥䌦䌧䌨䌩䌪䌫䌬䌭䌮䌯䌰䌱䌲䌳䌴䌵䌶䌷䌸䌹䌺䌻䌼䌽䌾䌿䍀䍁䍂䍃䍄䍅䍆䍇䍈䍉䍊䍋䍌䍍䍎䍏䍐䍑䍒䍓䍔䍕䍖䍗䍘䍙䍚䍛䍜䍝䍞䍟䍠䍡䍢䍣䍤䍥䍦䍧䍨䍩䍪䍫䍬䍭䍮䍯䍰䍱䍲䍳䍴䍵䍶䍷䍸䍹䍺䍻䍼䍽䍾䍿䎀䎁䎂䎃䎄䎅䎆䎇䎈䎉䎊䎋䎌䎍䎎䎏䎐䎑䎒䎓䎔䎕䎖䎗䎘䎙䎚䎛䎜䎝䎞䎟䎠䎡䎢䎣䎤䎥䎦䎧䎨䎩䎪䎫䎬䎭䎮䎯䎰䎱䎲䎳䎴䎵䎶䎷䎸䎹䎺䎻䎼䎽䎾䎿䏀䏁䏂䏃䏄䏅䏆䏇䏈䏉䏊䏋䏌䏍䏎䏏䏐䏑䏒䏓䏔䏕䏖䏗䏘䏙䏚䏛䏜䏝䏞䏟䏠䏡䏢䏣䏤䏥䏦䏧䏨䏩䏪䏫䏬䏭䏮䏯䏰䏱䏲䏳䏴䏵䏶䏷䏸䏹䏺䏻䏼䏽䏾䏿䐀䐁䐂䐃䐄䐅䐆䐇䐈䐉䐊䐋䐌䐍䐎䐏䐐䐑䐒䐓䐔䐕䐖䐗䐘䐙䐚䐛䐜䐝䐞䐟䐠䐡䐢䐣䐤䐥䐦䐧䐨䐩䐪䐫䐬䐭䐮䐯䐰䐱䐲䐳䐴䐵䐶䐷䐸䐹䐺䐻䐼䐽䐾䐿䑀䑁䑂䑃䑄䑅䑆䑇䑈䑉䑊䑋䑌䑍䑎䑏䑐䑑䑒䑓䑔䑕䑖䑗䑘䑙䑚䑛䑜䑝䑞䑟䑠䑡䑢䑣䑤䑥䑦䑧䑨䑩䑪䑫䑬䑭䑮䑯䑰䑱䑲䑳䑴䑵䑶䑷䑸䑹䑺䑻䑼䑽䑾䑿䒀䒁䒂䒃䒄䒅䒆䒇䒈䒉䒊䒋䒌䒍䒎䒏䒐䒑䒒䒓䒔䒕䒖䒗䒘䒙䒚䒛䒜䒝䒞䒟䒠䒡䒢䒣䒤䒥䒦䒧䒨䒩䒪䒫䒬䒭䒮䒯䒰䒱䒲䒳䒴䒵䒶䒷䒸䒹䒺䒻䒼䒽䒾䒿䓀䓁䓂䓃䓄䓅䓆䓇䓈䓉䓊䓋䓌䓍䓎䓏䓐䓑䓒䓓䓔䓕䓖䓗䓘䓙䓚䓛䓜䓝䓞䓟䓠䓡䓢䓣䓤䓥䓦䓧䓨䓩䓪䓫䓬䓭䓮䓯䓰䓱䓲䓳䓴䓵䓶䓷䓸䓹䓺䓻䓼䓽䓾䓿䔀䔁䔂䔃䔄䔅䔆䔇䔈䔉䔊䔋䔌䔍䔎䔏䔐䔑䔒䔓䔔䔕䔖䔗䔘䔙䔚䔛䔜䔝䔞䔟䔠䔡䔢䔣䔤䔥䔦䔧䔨䔩䔪䔫䔬䔭䔮䔯䔰䔱䔲䔳䔴䔵䔶䔷䔸䔹䔺䔻䔼䔽䔾䔿䕀䕁䕂䕃䕄䕅䕆䕇䕈䕉䕊䕋䕌䕍䕎䕏䕐䕑䕒䕓䕔䕕䕖䕗䕘䕙䕚䕛䕜䕝䕞䕟䕠䕡䕢䕣䕤䕥䕦䕧䕨䕩䕪䕫䕬䕭䕮䕯䕰䕱䕲䕳䕴䕵䕶䕷䕸䕹䕺䕻䕼䕽䕾䕿䖀䖁䖂䖃䖄䖅䖆䖇䖈䖉䖊䖋䖌䖍䖎䖏䖐䖑䖒䖓䖔䖕䖖䖗䖘䖙䖚䖛䖜䖝䖞䖟䖠䖡䖢䖣䖤䖥䖦䖧䖨䖩䖪䖫䖬䖭䖮䖯䖰䖱䖲䖳䖴䖵䖶䖷䖸䖹䖺䖻䖼䖽䖾䖿䗀䗁䗂䗃䗄䗅䗆䗇䗈䗉䗊䗋䗌䗍䗎䗏䗐䗑䗒䗓䗔䗕䗖䗗䗘䗙䗚䗛䗜䗝䗞䗟䗠䗡䗢䗣䗤䗥䗦䗧䗨䗩䗪䗫䗬䗭䗮䗯䗰䗱䗲䗳䗴䗵䗶䗷䗸䗹䗺䗻䗼䗽䗾䗿䘀䘁䘂䘃䘄䘅䘆䘇䘈䘉䘊䘋䘌䘍䘎䘏䘐䘑䘒䘓䘔䘕䘖䘗䘘䘙䘚䘛䘜䘝䘞䘟䘠䘡䘢䘣䘤䘥䘦䘧䘨䘩䘪䘫䘬䘭䘮䘯䘰䘱䘲䘳䘴䘵䘶䘷䘸䘹䘺䘻䘼䘽䘾䘿䙀䙁䙂䙃䙄䙅䙆䙇䙈䙉䙊䙋䙌䙍䙎䙏䙐䙑䙒䙓䙔䙕䙖䙗䙘䙙䙚䙛䙜䙝䙞䙟䙠䙡䙢䙣䙤䙥䙦䙧䙨䙩䙪䙫䙬䙭䙮䙯䙰䙱䙲䙳䙴䙵䙶䙷䙸䙹䙺䙻䙼䙽䙾䙿䚀䚁䚂䚃䚄䚅䚆䚇䚈䚉䚊䚋䚌䚍䚎䚏䚐䚑䚒䚓䚔䚕䚖䚗䚘䚙䚚䚛䚜䚝䚞䚟䚠䚡䚢䚣䚤䚥䚦䚧䚨䚩䚪䚫䚬䚭䚮䚯䚰䚱䚲䚳䚴䚵䚶䚷䚸䚹䚺䚻䚼䚽䚾䚿䛀䛁䛂䛃䛄䛅䛆䛇䛈䛉䛊䛋䛌䛍䛎䛏䛐䛑䛒䛓䛔䛕䛖䛗䛘䛙䛚䛛䛜䛝䛞䛟䛠䛡䛢䛣䛤䛥䛦䛧䛨䛩䛪䛫䛬䛭䛮䛯䛰䛱䛲䛳䛴䛵䛶䛷䛸䛹䛺䛻䛼䛽䛾䛿䜀䜁䜂䜃䜄䜅䜆䜇䜈䜉䜊䜋䜌䜍䜎䜏䜐䜑䜒䜓䜔䜕䜖䜗䜘䜙䜚䜛䜜䜝䜞䜟䜠䜡䜢䜣䜤䜥䜦䜧䜨䜩䜪䜫䜬䜭䜮䜯䜰䜱䜲䜳䜴䜵䜶䜷䜸䜹䜺䜻䜼䜽䜾䜿䝀䝁䝂䝃䝄䝅䝆䝇䝈䝉䝊䝋䝌䝍䝎䝏䝐䝑䝒䝓䝔䝕䝖䝗䝘䝙䝚䝛䝜䝝䝞䝟䝠䝡䝢䝣䝤䝥䝦䝧䝨䝩䝪䝫䝬䝭䝮䝯䝰䝱䝲䝳䝴䝵䝶䝷䝸䝹䝺䝻䝼䝽䝾䝿䞀䞁䞂䞃䞄䞅䞆䞇䞈䞉䞊䞋䞌䞍䞎䞏䞐䞑䞒䞓䞔䞕䞖䞗䞘䞙䞚䞛䞜䞝䞞䞟䞠䞡䞢䞣䞤䞥䞦䞧䞨䞩䞪䞫䞬䞭䞮䞯䞰䞱䞲䞳䞴䞵䞶䞷䞸䞹䞺䞻䞼䞽䞾䞿䟀䟁䟂䟃䟄䟅䟆䟇䟈䟉䟊䟋䟌䟍䟎䟏䟐䟑䟒䟓䟔䟕䟖䟗䟘䟙䟚䟛䟜䟝䟞䟟䟠䟡䟢䟣䟤䟥䟦䟧䟨䟩䟪䟫䟬䟭䟮䟯䟰䟱䟲䟳䟴䟵䟶䟷䟸䟹䟺䟻䟼䟽䟾䟿䠀䠁䠂䠃䠄䠅䠆䠇䠈䠉䠊䠋䠌䠍䠎䠏䠐䠑䠒䠓䠔䠕䠖䠗䠘䠙䠚䠛䠜䠝䠞䠟䠠䠡䠢䠣䠤䠥䠦䠧䠨䠩䠪䠫䠬䠭䠮䠯䠰䠱䠲䠳䠴䠵䠶䠷䠸䠹䠺䠻䠼䠽䠾䠿䡀䡁䡂䡃䡄䡅䡆䡇䡈䡉䡊䡋䡌䡍䡎䡏䡐䡑䡒䡓䡔䡕䡖䡗䡘䡙䡚䡛䡜䡝䡞䡟䡠䡡䡢䡣䡤䡥䡦䡧䡨䡩䡪䡫䡬䡭䡮䡯䡰䡱䡲䡳䡴䡵䡶䡷䡸䡹䡺䡻䡼䡽䡾䡿䢀䢁䢂䢃䢄䢅䢆䢇䢈䢉䢊䢋䢌䢍䢎䢏䢐䢑䢒䢓䢔䢕䢖䢗䢘䢙䢚䢛䢜䢝䢞䢟䢠䢡䢢䢣䢤䢥䢦䢧䢨䢩䢪䢫䢬䢭䢮䢯䢰䢱䢲䢳䢴䢵䢶䢷䢸䢹䢺䢻䢼䢽䢾䢿䣀䣁䣂䣃䣄䣅䣆䣇䣈䣉䣊䣋䣌䣍䣎䣏䣐䣑䣒䣓䣔䣕䣖䣗䣘䣙䣚䣛䣜䣝䣞䣟䣠䣡䣢䣣䣤䣥䣦䣧䣨䣩䣪䣫䣬䣭䣮䣯䣰䣱䣲䣳䣴䣵䣶䣷䣸䣹䣺䣻䣼䣽䣾䣿䤀䤁䤂䤃䤄䤅䤆䤇䤈䤉䤊䤋䤌䤍䤎䤏䤐䤑䤒䤓䤔䤕䤖䤗䤘䤙䤚䤛䤜䤝䤞䤟䤠䤡䤢䤣䤤䤥䤦䤧䤨䤩䤪䤫䤬䤭䤮䤯䤰䤱䤲䤳䤴䤵䤶䤷䤸䤹䤺䤻䤼䤽䤾䤿䥀䥁䥂䥃䥄䥅䥆䥇䥈䥉䥊䥋䥌䥍䥎䥏䥐䥑䥒䥓䥔䥕䥖䥗䥘䥙䥚䥛䥜䥝䥞䥟䥠䥡䥢䥣䥤䥥䥦䥧䥨䥩䥪䥫䥬䥭䥮䥯䥰䥱䥲䥳䥴䥵䥶䥷䥸䥹䥺䥻䥼䥽䥾䥿䦀䦁䦂䦃䦄䦅䦆䦇䦈䦉䦊䦋䦌䦍䦎䦏䦐䦑䦒䦓䦔䦕䦖䦗䦘䦙䦚䦛䦜䦝䦞䦟䦠䦡䦢䦣䦤䦥䦦䦧䦨䦩䦪䦫䦬䦭䦮䦯䦰䦱䦲䦳䦴䦵䦶䦷䦸䦹䦺䦻䦼䦽䦾䦿䧀䧁䧂䧃䧄䧅䧆䧇䧈䧉䧊䧋䧌䧍䧎䧏䧐䧑䧒䧓䧔䧕䧖䧗䧘䧙䧚䧛䧜䧝䧞䧟䧠䧡䧢䧣䧤䧥䧦䧧䧨䧩䧪䧫䧬䧭䧮䧯䧰䧱䧲䧳䧴䧵䧶䧷䧸䧹䧺䧻䧼䧽䧾䧿䨀䨁䨂䨃䨄䨅䨆䨇䨈䨉䨊䨋䨌䨍䨎䨏䨐䨑䨒䨓䨔䨕䨖䨗䨘䨙䨚䨛䨜䨝䨞䨟䨠䨡䨢䨣䨤䨥䨦䨧䨨䨩䨪䨫䨬䨭䨮䨯䨰䨱䨲䨳䨴䨵䨶䨷䨸䨹䨺䨻䨼䨽䨾䨿䩀䩁䩂䩃䩄䩅䩆䩇䩈䩉䩊䩋䩌䩍䩎䩏䩐䩑䩒䩓䩔䩕䩖䩗䩘䩙䩚䩛䩜䩝䩞䩟䩠䩡䩢䩣䩤䩥䩦䩧䩨䩩䩪䩫䩬䩭䩮䩯䩰䩱䩲䩳䩴䩵䩶䩷䩸䩹䩺䩻䩼䩽䩾䩿䪀䪁䪂䪃䪄䪅䪆䪇䪈䪉䪊䪋䪌䪍䪎䪏䪐䪑䪒䪓䪔䪕䪖䪗䪘䪙䪚䪛䪜䪝䪞䪟䪠䪡䪢䪣䪤䪥䪦䪧䪨䪩䪪䪫䪬䪭䪮䪯䪰䪱䪲䪳䪴䪵䪶䪷䪸䪹䪺䪻䪼䪽䪾䪿䫀䫁䫂䫃䫄䫅䫆䫇䫈䫉䫊䫋䫌䫍䫎䫏䫐䫑䫒䫓䫔䫕䫖䫗䫘䫙䫚䫛䫜䫝䫞䫟䫠䫡䫢䫣䫤䫥䫦䫧䫨䫩䫪䫫䫬䫭䫮䫯䫰䫱䫲䫳䫴䫵䫶䫷䫸䫹䫺䫻䫼䫽䫾䫿䬀䬁䬂䬃䬄䬅䬆䬇䬈䬉䬊䬋䬌䬍䬎䬏䬐䬑䬒䬓䬔䬕䬖䬗䬘䬙䬚䬛䬜䬝䬞䬟䬠䬡䬢䬣䬤䬥䬦䬧䬨䬩䬪䬫䬬䬭䬮䬯䬰䬱䬲䬳䬴䬵䬶䬷䬸䬹䬺䬻䬼䬽䬾䬿䭀䭁䭂䭃䭄䭅䭆䭇䭈䭉䭊䭋䭌䭍䭎䭏䭐䭑䭒䭓䭔䭕䭖䭗䭘䭙䭚䭛䭜䭝䭞䭟䭠䭡䭢䭣䭤䭥䭦䭧䭨䭩䭪䭫䭬䭭䭮䭯䭰䭱䭲䭳䭴䭵䭶䭷䭸䭹䭺䭻䭼䭽䭾䭿䮀䮁䮂䮃䮄䮅䮆䮇䮈䮉䮊䮋䮌䮍䮎䮏䮐䮑䮒䮓䮔䮕䮖䮗䮘䮙䮚䮛䮜䮝䮞䮟䮠䮡䮢䮣䮤䮥䮦䮧䮨䮩䮪䮫䮬䮭䮮䮯䮰䮱䮲䮳䮴䮵䮶䮷䮸䮹䮺䮻䮼䮽䮾䮿䯀䯁䯂䯃䯄䯅䯆䯇䯈䯉䯊䯋䯌䯍䯎䯏䯐䯑䯒䯓䯔䯕䯖䯗䯘䯙䯚䯛䯜䯝䯞䯟䯠䯡䯢䯣䯤䯥䯦䯧䯨䯩䯪䯫䯬䯭䯮䯯䯰䯱䯲䯳䯴䯵䯶䯷䯸䯹䯺䯻䯼䯽䯾䯿䰀䰁䰂䰃䰄䰅䰆䰇䰈䰉䰊䰋䰌䰍䰎䰏䰐䰑䰒䰓䰔䰕䰖䰗䰘䰙䰚䰛䰜䰝䰞䰟䰠䰡䰢䰣䰤䰥䰦䰧䰨䰩䰪䰫䰬䰭䰮䰯䰰䰱䰲䰳䰴䰵䰶䰷䰸䰹䰺䰻䰼䰽䰾䰿䱀䱁䱂䱃䱄䱅䱆䱇䱈䱉䱊䱋䱌䱍䱎䱏䱐䱑䱒䱓䱔䱕䱖䱗䱘䱙䱚䱛䱜䱝䱞䱟䱠䱡䱢䱣䱤䱥䱦䱧䱨䱩䱪䱫䱬䱭䱮䱯䱰䱱䱲䱳䱴䱵䱶䱷䱸䱹䱺䱻䱼䱽䱾䱿䲀䲁䲂䲃䲄䲅䲆䲇䲈䲉䲊䲋䲌䲍䲎䲏䲐䲑䲒䲓䲔䲕䲖䲗䲘䲙䲚䲛䲜䲝䲞䲟䲠䲡䲢䲣䲤䲥䲦䲧䲨䲩䲪䲫䲬䲭䲮䲯䲰䲱䲲䲳䲴䲵䲶䲷䲸䲹䲺䲻䲼䲽䲾䲿䳀䳁䳂䳃䳄䳅䳆䳇䳈䳉䳊䳋䳌䳍䳎䳏䳐䳑䳒䳓䳔䳕䳖䳗䳘䳙䳚䳛䳜䳝䳞䳟䳠䳡䳢䳣䳤䳥䳦䳧䳨䳩䳪䳫䳬䳭䳮䳯䳰䳱䳲䳳䳴䳵䳶䳷䳸䳹䳺䳻䳼䳽䳾䳿䴀䴁䴂䴃䴄䴅䴆䴇䴈䴉䴊䴋䴌䴍䴎䴏䴐䴑䴒䴓䴔䴕䴖䴗䴘䴙䴚䴛䴜䴝䴞䴟䴠䴡䴢䴣䴤䴥䴦䴧䴨䴩䴪䴫䴬䴭䴮䴯䴰䴱䴲䴳䴴䴵䴶䴷䴸䴹䴺䴻䴼䴽䴾䴿䵀䵁䵂䵃䵄䵅䵆䵇䵈䵉䵊䵋䵌䵍䵎䵏䵐䵑䵒䵓䵔䵕䵖䵗䵘䵙䵚䵛䵜䵝䵞䵟䵠䵡䵢䵣䵤䵥䵦䵧䵨䵩䵪䵫䵬䵭䵮䵯䵰䵱䵲䵳䵴䵵䵶䵷䵸䵹䵺䵻䵼䵽䵾䵿䶀䶁䶂䶃䶄䶅䶆䶇䶈䶉䶊䶋䶌䶍䶎䶏䶐䶑䶒䶓䶔䶕䶖䶗䶘䶙䶚䶛䶜䶝䶞䶟䶠䶡䶢䶣䶤䶥䶦䶧䶨䶩䶪䶫䶬䶭䶮䶯䶰䶱䶲䶳䶴䶵䶶䶷䶸䶹䶺䶻䶼䶽䶾䶿䷀䷁䷂䷃䷄䷅䷆䷇䷈䷉䷊䷋䷌䷍䷎䷏䷐䷑䷒䷓䷔䷕䷖䷗䷘䷙䷚䷛䷜䷝䷞䷟䷠䷡䷢䷣䷤䷥䷦䷧䷨䷩䷪䷫䷬䷭䷮䷯䷰䷱䷲䷳䷴䷵䷶䷷䷸䷹䷺䷻䷼䷽䷾䷿乥乲兙兛兝兞兡兣兺匁厼叾哛唜唟喸嗧囕夞巼怾旕朩朰栍桛椧烪猠瓧瓩瓰瓱瓲瓼甅硛硳穒縇莻虄襨迲闏鞥啊腌錒锕阿哀哎唉埃挨溾銰鎄锿凒啀嘊捱敱敳溰癌皑皚磑娾昹毐濭矮蔼藹譪躷霭靄伌僾叆嗳噯塧壒嫒嬡愛懓懝暧曖爱瑷璦皧瞹砹硋碍礙艾薆譺賹鑀隘靉餲馤鱫鴱侒偣啽媕安峖庵桉氨痷盦盫腤菴萻葊蓭誝諳谙鞌鞍韽馣鮟鵪鶕鹌儑玵雸俺唵垵埯揞罯銨铵堓屵岸按晻暗案洝胺荌豻貋錌闇隌黯肮骯岇昂昻枊盎醠凹柪梎熬爊軪厫嗷嗸嶅廒慠摮敖滶獒獓璈磝翱翶翺聱蔜螯謷謸遨鏖隞骜鰲鳌鷔鼇媪媼抝艹芺袄襖镺傲坳垇墺奡奥奧嫯岙岰嶴懊拗擙澚澳鏊隩驁丷仈八叭吧哵夿岜巴扒扷捌朳柭玐疤笆粑羓芭蚆豝釟魞鲃叐妭抜拔炦癹胈茇菝詙跋軷颰魃鼥把鈀钯靶坝垻壩弝欛灞爸矲罢罷耙覇跁霸鮁鲅挀掰白佰捭摆擺柏栢瓸百竡粨絔襬庍拜拝敗猈稗粺薭贁败韛扳搬攽斑斒班瘢癍肦般螌褩辬頒颁鳻坂岅昄板版瓪粄舨蝂鈑钣闆阪魬伴办半坢姅怑扮拌湴瓣秚絆绊辦鉡靽垹帮幇幚幫捠梆浜縍邦邫鞤榜牓綁绑膀髈傍塝挷搒棒棓玤磅稖艕蒡蚌蜯謗谤鎊镑佨剝勹包孢枹煲笣胞苞蕔裦褒襃闁齙龅窇薄雹保堡堢媬宝宲寚寳寶怉珤緥葆藵褓賲靌飹飽饱駂鳵鴇鸨儤勽嚗報忁报抱暴曓爆犦菢虣蚫袌豹趵鉋鑤铇骲髱鮑鲍卑庳悲揹杯柸桮椑盃碑背藣陂鵯鹎北鉳俻倍偝偹備僃备孛悖惫愂憊昁梖焙牬犕狈狽珼琲碚禙糒苝蓓蛽被褙誖貝贝軰輩辈邶郥鄁鋇鐾钡鞁鞴骳呗唄喯奔栟泍漰犇錛锛奙本楍畚翉苯倴坋坌捹撪桳渀笨逩伻嗙嘣奟崩嵭痭祊絣綳繃绷閍甭甮埄埲琣琫菶鞛塴揼泵甏蹦迸逬鏰镚偪屄楅榌毴螕豍逼鎞鰏鲾鵖嬶荸鼻佊俾匕啚夶妣彼朼柀比毞沘疕秕笔筆粃聛舭貏鄙佖咇哔嗶坒堛壁奰妼婢嬖币幣幤庇廦弊弻弼彃必怭怶愊愎敝斃朇柲梐毕毖毙湢滗滭潷濞煏熚狴獘獙珌璧畀畁畢疪痹痺皕睤睥碧禆筚箅箆篦篳粊綼縪繴罼腷臂芘苾荜萆萞蓖蓽蔽薜蜌袐襅襞襣觱詖诐貱賁贔贲赑跸蹕躃躄避邲鄨鄪鉍鏎鐴铋閇閉閟闭陛鞸韠飶饆馝駜驆髀髲魓鮅鷝鷩鼊炞煸牑猵獱甂砭笾箯籩糄編编萹蝙边邉邊鍽鞕鞭鯾鯿鳊匾惼扁揙碥稨窆藊褊貶贬鴘便卞变変峅弁徧忭抃昪汳汴玣緶缏艑苄覍諚變辡辧辨辩辫辮辯遍釆閞儦墂幖彪标標檦淲滮瀌熛爂猋瘭磦穮脿膘臕蔈藨謤贆鏢鑣镖镳颩颮颷飆飇飈飊飑飙飚驫骉骠髟嫑婊表裱褾諘錶俵摽鳔憋瘪癟虌蟞鱉鳖鼈龞別别徶莂蛂襒蹩彆傧儐宾彬斌梹椕槟檳汃滨濒濱濵瀕玢瑸璸繽缤虨豩豳賓賔邠鑌镔霦頻顮摈擯殡殯膑臏髌髕髩鬂鬓鬢仌仒兵冫冰掤氷蛃鋲丙偋寎怲抦昞昺柄棅炳眪禀秉稟苪邴鈵鉼陃鞆鞞餅餠饼並併倂傡垪并幷庰摒栤病窉竝誁靐鮩僠剥嶓拨撥播波溊玻癶癷盋砵碆礡紴缽菠袰蹳鉢钵餑饽驋鱍亳仢伯侼僰勃博帛愽懪挬搏桲欂泊浡淿渤煿牔狛猼瓝瓟礴秡箔簙糪肑胉脖膊舶艊萡葧袯袹襏襮謈踣郣鈸鉑鋍鎛鑮钹铂镈餺馎馛馞駁駮驳髆髉鮊鲌鵓鹁跛孹擘檗簸蘗譒啵蔔峬庯晡誧逋鈽錻钸餔鵏轐醭鳪卜卟哺捕补補鸔不佈勏吥咘埗埠布廍怖悑抪捗柨步歨歩瓿篰簿荹蔀踄部郶鈈钚餢嚓擦攃礤礸遪偲猜才材纔裁財财倸啋埰婇寀彩採棌毝睬綵跴踩采縩菜蔡傪参參叄叅喰嬠湌爘飡餐驂骖惭慙慚残殘蚕蝅蠶蠺惨慘憯朁穇黪黲儏澯灿燦璨粲薒謲仓仺伧倉傖凔嵢沧滄濸獊舱艙苍蒼螥鶬鸧欌藏鑶賶撡操糙嘈嶆慒曹曺槽漕艚蓸螬褿鏪愺懆艸草騲肏襙鄵鼜侧側冊册厕厠夨廁恻惻憡拺敇测測畟笧策筞筴箣簎粣荝萗萴蓛嵾篸埁岑涔笒噌层層嶒曽曾竲驓蹭偛叉嗏扠挿插揷杈疀臿艖銟鍤锸餷馇垞察嵖搽查査槎檫猹碴秅茬茶詧靫蹅鑔镲侘刹剎奼姹岔差汊紁衩詫诧拆肞芆釵钗侪儕喍柴犲祡豺茝囆瘥虿蠆袃訍幨掺搀摻攙梴裧襜覘觇辿鋓儃儳劖嚵壥婵嬋孱巉廛棎欃毚湹潹潺澶瀍瀺煘獑磛禅緾纏纒缠艬苂蝉螹蟐蟬蟾誗讒谗躔鄽酁鋋鑱镵饞馋丳产冁刬剗剷囅嵼幝摌斺旵浐滻灛燀產産簅繟蒇蕆諂譂讇谄醦鏟铲閳闡阐骣忏懴懺摲硟羼韂顫颤伥倀娼昌椙淐猖琩菖裮錩锠閶阊鯧鲳鼚仧仩偿償兏嘗嚐塲嫦尝常徜瑺瓺甞肠腸膓苌萇裳長镸长鱨鲿僘厂厰场場廠惝敞昶氅鋹倡唱怅悵暢焻玚瑒畅畼誯韔鬯弨怊抄欩窼訬超鈔钞嘲巢巣晁朝樔漅潮牊窲罺謿轈鄛鼂鼌吵巐炒焣煼眧麨仦仯耖觘伡俥唓砗硨莗蛼車车偖扯撦勶坼屮彻徹掣撤澈烢爡瞮硩聅迠頙嗔抻捵棽琛瞋諃謓賝郴塵宸尘忱愖敐敶晨曟栕桭梣樄沉煁瘎臣茞莀莐蔯薼螴訦諶谌軙辰迧鈂陈陳霃鷐麎墋夦硶碜磣贂趻踸鍖儭嚫榇櫬疢衬襯讖谶趁趂齓齔龀偁僜憆摚撐撑晿柽棦橕檉泟浾爯牚琤瞠碀称稱穪竀緽罉蛏蟶赪赬鏿鐣阷靗頳饓丞乗乘呈城埕堘塍塖娍宬峸惩憕懲成承挰掁揨朾枨棖椉橙檙洆溗澂澄瀓珵珹畻程窚筬絾脭荿裎誠诚郕酲鋮铖騬鯎侱庱徎悜睈逞騁骋秤吃哧喫嗤噄妛媸彨彲摛攡殦瓻痴癡眵瞝笞粚絺胵蚩螭訵誺魑鴟鵄鸱黐齝匙墀弛持池漦竾筂箎篪茌荎蚳謘貾赿踟迟迡遅遟遲鍉馳驰伬侈卶叺呎垑尺恥欼歯耻肔胣蚇袲袳裭褫豉鉹齒齿侙傺勅勑叱啻彳恜慗憏懘抶敕斥杘湁灻炽烾熾痸瘛翄翅翤翨腟赤趩遫鉓銐雴飭饬鶒鷘麶充冲嘃忡憃憧摏沖浺珫罿翀舂艟茺衝蹖崇崈漴爞緟虫蝩蟲褈隀埫宠寵揰銃铳抽搊犨犫瘳篘紬仇俦儔嬦帱幬惆愁懤栦梼椆檮燽畴疇皗稠筹籌絒綢绸菗薵裯詶讎讐踌躊酧酬醻雔雠雦丑丒偢吜杽瞅矁醜魗殠臭臰遚鮘出初岀摴榋樗貙齣刍厨媰幮廚橱櫉櫥滁犓篨耡芻蒢蒭蜍蟵豠趎蹰躇躕鉏鋤锄除雏雛鶵储儲杵椘楚楮檚濋璴础礎禇處齭齼亍俶傗儊処埱处怵憷搐敊斶欪歜泏滀珿畜矗竌竐絀绌臅触觸諔豖鄐閦黜搋膗揣膪踹巛川氚瑏穿传傳剶圌暷椽篅舡舩船輲遄僢喘堾歂舛荈踳串汌猭玔賗釧钏鶨刅摐牎牕疮瘡窓窗窻噇幢床牀傸磢闖闯创刱剏剙創怆愴吹炊龡倕垂埀捶搥桘棰槌箠腄菙錘鎚锤陲顀媋旾春暙杶椿槆橁櫄瑃箺萅蝽輴鰆鶞唇浱淳湻滣漘犉純纯脣莼蒓蓴醇醕錞陙鯙鶉鹑偆惷睶萶蠢賰戳繛趠踔逴哾啜嚽娕娖婥惙擉歠涰磭綽绰踀輟辍辵辶酫鑡餟齪龊偨玼疵縒蠀趀跐骴髊齹垐嬨慈柌濨珁瓷甆磁礠祠糍茨薋詞词辝辞辤辭雌飺餈鴜鶿鷀鹚佌此泚皉鮆伺佽刺刾庛朿栨次絘茦莿蛓螆賜赐匆囪囱忩怱悤暰枞棇樅樬漗潨熜瑽璁瞛篵繱聡聦聪聰苁茐葱蓯蔥蟌鍯鏓鏦騘驄骢丛从叢婃孮従徔徖從悰樷欉淙漎潀潈灇爜琮藂誴賨賩錝愡憁謥凑楱湊腠輳辏怚橻粗觕麁麄麤徂殂促噈媨憱猝瘄瘯簇縬脨蔟誎趗踧踿蹙蹴蹵醋顣鼀撺攛汆蹿躥鑹镩巑櫕欑穳殩熶爨窜竄篡簒催凗墔崔嵟慛摧榱槯磪縗缞脺鏙漼璀皠趡伜倅啐啛忰悴毳淬濢焠琗疩瘁竁粋粹紣綷翆翠脃脆膬膵臎萃襊顇村澊皴竴膥邨侟壿存拵刌忖寸籿搓撮瑳磋蹉遳醝鎈嵯嵳痤睉矬蒫蔖虘酂酇鹺鹾脞剉剒厝夎庴挫措莝莡蓌逪銼錯锉错咑哒嗒噠墶搭撘笚耷褡鎉鎝剳匒呾垯妲怛溚炟燵畗畣瘩笪答羍荅荙薘蟽詚跶达迏迖迚逹達鐽靼鞑韃龖龘打亣大眔繨呆呔懛獃傣歹代侢叇垈埭岱帒带帯帶廗待怠戴曃柋殆瀻玳瑇甙簤紿緿绐艜蚮蝳袋襶貣貸贷跢蹛軑軚軩轪迨逮霴靆鴏黛黱丹儋勯匰单単單妉媅担擔殚殫甔眈砃箪簞耼耽聃聸褝襌躭郸鄲酖頕亶伔刐抌掸撢撣玬瓭疸紞胆膽衴賧赕馾黕黵但僤唌啖啗啿嘾噉嚪帎惮憚憺旦柦氮沊泹淡澹狚疍瘅癉癚禫窞繵腅萏蓞蛋蜑觛訑誕诞贉霮餤饏駳髧鴠黮儅噹当澢珰璫當筜簹艡蟷裆襠鐺铛闣党挡擋攩欓灙譡讜谠黨凼圵垱壋婸宕愓档檔氹潒璗瓽盪瞊砀碭礑簜荡菪蕩蘯趤逿雼刀刂叨忉朷氘舠螩釖魛鱽捯倒壔导導岛島嶋嶌嶹捣搗擣槝祷禂禱蹈陦隝隯到噵悼椡檤焘燾瓙盗盜稲稻纛翢翿艔菿衜衟軇辺道嘚得徳德恴悳惪棏淂鍀锝的扥扽噔嬁灯燈璒登竳簦艠豋蹬戥等凳墱嶝櫈瞪磴覴邓鄧鐙镫隥仾低啲埞堤奃岻彽樀氐滴磾秪羝袛趆隄鞮唙啇嘀嚁嫡廸敌敵梑涤滌狄笛籴糴翟苖荻蔋蔐藡覿觌豴蹢迪鏑镝靮頔馰髢鸐厎呧坘坻底弤抵拞掋柢牴砥聜菧觝詆诋軧邸阺骶鯳俤偙僀地坔埅埊墑墬娣媂嶳帝弟怟慸摕旳杕枤梊棣楴焍玓珶甋眱睇碲祶禘第締缔腣苐菂蒂蔕蝃蝭螮諦谛踶递逓遆遞遰釱鉪嗲傎厧嵮巅巓巔掂攧敁槇槙滇瘨癫癲蹎顚顛颠齻典嚸奌婰敟椣点碘蒧蕇跕踮點佃坫垫墊壂奠婝店惦扂橂殿淀澱玷琔电甸癜磹簟蜔鈿钿阽電靛驔凋刁刟叼奝弴彫汈琱瞗碉簓虭蛁貂錭雕鮉鯛鲷鳭鵰鼦屌扚伄吊弔掉瘹盄窎窵竨蓧藋訋調釣鈟銚銱鋽鑃钓铞铫雿魡爹褺跌叠咥喋垤堞峌嵽幉恎惵戜挕昳曡楪殜氎牃牒瓞畳疂疉疊眣眰碟絰绖耊耋胅臷艓苵蜨蝶螲褋詄諜谍趃跮蹀迭镻鰈鲽鴩哋丁仃叮帄玎疔盯耵虰酊釘钉靪奵嵿濎艼薡鐤頂顶鼎鼑啶定忊椗矴碇碠磸聢腚萣蝊訂订錠锭顁飣饤丟丢銩铥东倲冬咚埬娻岽崠崬徚昸東氡氭涷笗苳菄蝀鮗鯟鶇鶫鸫鼕嬞懂箽董蕫諌侗働冻凍动動垌姛恫戙挏栋棟洞湩硐胨胴腖迵霘駧兜兠吺唗枓橷篼蔸都唞乧抖蚪鈄钭阧陡吋斗斣梪毭浢痘窦竇脰荳豆逗郖酘閗闘餖饾鬥鬦鬪鬬鬭剢厾嘟督醏闍阇凟匵嬻椟櫝殰毒涜渎瀆牍牘犊犢独獨瓄皾裻読讀讟读豄贕錖鑟韇韣韥騳髑黩黷堵琽睹笃篤覩賭赌妒妬度杜殬渡秺肚芏荰螙蠧蠹鍍镀靯偳媏端耑褍鍴短塅断斷椴段毈煅瑖碫簖籪緞缎腶葮躖鍛锻垖堆塠痽磓鐓鐜镦鴭頧兊兌兑对対對怼憝憞懟濧瀩碓祋綐薱譈譵轛队陮隊吨噸墩墪惇撉撴敦犜獤礅蜳蹲蹾驐盹趸躉伅庉沌潡炖燉盾砘碷踲逇遁遯鈍钝頓顿剟咄哆嚉多夛掇敠敪毲畓裰凙剫喥夺奪敓敚痥踱鈬鐸铎亸哚嚲垛垜埵奲崜挆朵朶椯綞缍趓躱躲軃鬌刴剁堕墮墯尮惰憜挅柮桗舵跥跺陊陏飿饳鵽妸妿娿婀屙俄吪囮娥峉峨峩涐珴皒睋磀莪蛾訛誐譌讹迗鈋鋨锇頟額额魤鵝鵞鹅噁枙砨頋騀鵈偔僫匎卾厄呃呝咢咹噩垩堊堨堮姶岋崿廅恶悪惡愕戹扼搤搹擜櫮歞歺湂琧砈砐硆礘腭苊萼蕚蚅蝁覨諤讍谔豟軛軶轭遌遏遻鄂鈪鍔鑩锷閼阏阨阸頞顎颚餓餩饿鰐鰪鱷鳄鶚鹗齃齶誒诶欸奀恩煾蒽峎嗯摁侕儿児兒唲峏栭洏粫而耏聏胹荋袻輀轜陑隭髵鮞鲕鴯鸸尒尓尔栮毦洱爾珥耳薾衈趰迩邇鉺铒餌饵駬二佴刵咡弍弐樲誀貮貳贰髶冹发彂沷発發乏伐傠坺垡墢姂栰橃浌疺瞂笩筏罚罰罸茷藅閥阀佱峜法灋砝鍅珐琺蕟髪髮勫噃嬏帆幡忛憣旙旛畨番籓繙翻藩轓颿飜鱕凡凢凣匥墦杋柉棥樊瀿烦煩燔璠矾礬笲籵緐繁羳膰舤舧蕃薠蘩蠜襎蹯釩鐇鐢钒鷭仮反払橎返奿嬎梵氾汎泛滼瀪犯畈盕笵範范訉販贩軓軬輽飯飰饭匚坊堏方枋汸淓牥芳蚄趽邡鈁錺钫鴋妨房肪防魴鲂仿倣旊昉昘瓬眆紡纺舫訪访髣鶭放啡妃婓婔扉暃渄猆緋绯菲蜚裶霏非靟飛飝飞餥馡騑騛鯡鲱淝肥腓蜰匪奜悱斐朏棐榧篚翡胐蕜誹诽俷剕厞吠屝废廃廢昲曊杮櫠沸濷狒疿痱癈肺胇芾萉蟦費费鐨镄陫靅鼣分吩帉昐朆梤棻氛竕紛纷翂芬衯訜躮酚鈖雰餴饙馚坟墳妢岎幩朌枌棼橨汾濆炃焚燌燓獖羒羵蒶蕡蚠蚡豮豶轒鐼隫馩魵黂鼖鼢粉黺份偾僨奋奮弅忿愤憤瀵瞓秎粪糞膹鱝鲼丰仹偑僼凨凬凮堼妦寷封峯峰崶枫桻楓檒沣沨渢灃烽犎猦琒疯瘋盽砜碸篈葑蘴蜂蠭豐鄷酆鋒鎽鏠锋霻靊風飌风麷冯堸夆摓浲溄漨綘縫缝艂逢馮唪覂諷讽俸凤奉湗焨煈賵赗鳯鳳鴌覅仏佛坲梻紑否妚殕缶缹缻雬鴀伕呋夫妋姇娐孵尃怤懯敷旉柎玞砆稃筟粰糐紨綒肤胕膚荂荴衭趺跗邞鄜酜鈇鳺麩麬麱麸乀伏俘凫刜匐咈哹垘孚岪巿帗幅幞弗怫扶拂服枎柫栿桴棴榑氟泭洑浮涪澓炥烰玸琈甶畉畐癁砩祓福稪符笰箙紱紼絥綍绂绋罘罦翇艀艴芙芣苻茀茯莩菔葍虙蚨蜉蝠袚袱襆襥諨豧踾輻辐郛鉘鉜韍韨颫髴鮄鮲鳧鳬鴔鵩鶝黻乶俌俛俯呒嘸府弣抚拊捬撫斧椨滏焤甫盙簠脯腐腑蜅輔辅郙釜釡阝頫鬴黼付偩傅冨副咐坿复妇婏婦媍嬔富峊彿復椱父祔禣秿竎緮縛缚腹萯蕧蚥蚹蛗蝜蝮袝複褔覄覆訃詂讣負賦賻负赋赙赴輹鍑鍢阜附馥駙驸鮒鰒鲋鳆嘎嘠旮噶尜釓錷钆尕玍尬魀侅垓姟峐晐畡祴絯荄該该豥賅賌赅郂陔忋改絠丐乢匃匄戤摡概槩槪溉漑瓂盖葢蓋鈣钙凲坩尲尴尶尷干忓攼杆柑泔漧玕甘疳矸竿筸粓肝苷迀酐魐鳱仠感擀敢桿橄澉澸皯秆稈簳芉衦赶趕鱤鳡倝凎幹旰榦檊汵淦灨盰紺绀詌贑贛赣骭冈冮刚剛堈堽岡掆摃棡牨犅疘矼綱纲缸罁罡肛釭鋼鎠钢岗崗港戅戆戇杠槓焵焹筻槔槹橰櫜皋皐睾篙糕羔膏臯韟餻高髙鷎鷱鼛夰搞杲槀槁檺稁稾稿縞缟菒藁藳鎬镐勂吿告峼祮祰禞筶誥诰郜鋯锆割哥圪彁戈戓戨搁擱歌滒牫犵疙肐胳袼謌鎶饹鴚鴿鸽佫佮匌呄嗝塥愅挌搿敋格槅櫊滆獦膈臵葛蛒蛤裓觡諽輵轕鎘镉閣阁隔革鞈鞷韐韚騔骼鬲鮯哿嗰笴舸个亇個各箇茖虼鉻铬給给根跟哏亘亙揯搄艮茛刯庚椩浭焿畊絚緪縆羮羹耕菮賡赓鶊鹒哽埂峺挭梗綆绠耿莄郠骾鯁鲠堩更侊公功匑匔厷塨宫宮工幊弓恭愩慐攻杛碽篢糼糿肱蚣觥觵躬躳髸龏龔龚巩廾拱拲栱汞珙輁鞏供共唝嗊熕貢贡佝勾沟溝痀篝簼緱缑芶袧褠鈎鉤钩鞲韝岣枸狗玽笱耇耈耉苟蚼豿冓啂坸垢够夠姤媾彀搆撀构構煹覯觏訽詬诟購购遘雊估咕唂唃姑嫴孤巬巭杚柧橭沽泒稒笟箍箛篐罛苽菇菰蓇蛄觚軱軲轱辜酤鈲鮕鴣鸪傦古啒嘏夃尳愲扢榖毂汩淈濲瀔牯皷皼盬瞽穀糓縎罟羖股脵臌薣蛊蠱詁诂谷轂逧鈷钴餶馉骨鶻鹘鼓鼔僱凅固堌崓崮故梏棝榾牿痼祻錮锢雇顧顾鯝鲴刮劀呱栝桰歄煱瓜緺胍趏踻颪颳騧鴰鸹冎剐剮叧寡卦啩坬挂掛絓罣褂詿诖乖叏拐枴柺箉罫夬怪恠倌关官棺涫瘝癏窤蒄覌観觀观関闗關鰥鱞鳏琯璭痯筦管舘輨錧館馆鳤丱冠卝悹悺惯慣掼摜樌欟毌泴潅灌爟瓘盥矔礶祼罆罐貫贯躀遦鏆鑵雚鱹鸛鹳僙光咣垙姯桄洸灮炗炚炛烡珖胱茪輄銧黆广広廣犷獷臩俇臦逛亀圭妫媯嫢嬀嶲巂帰廆归摫椝槻槼櫷歸珪瑰璝瓌皈瞡硅胿茥蘬袿規规邽郌閨闺雟騩鬶鬹鮭鲑龜龟佹匦匭厬垝姽宄庋庪恑攱晷氿湀癸祪簋蛫蟡觤詭诡軌轨陒鬼刽刿劊劌撌攰昋柜桂桧椢槶樻檜櫃猤癐眭瞆瞶禬筀蓕螝襘貴贵跪鐀鑎鞼鱖鱥鳜丨惃滚滾磙緄緷绲蓘蔉衮袞輥辊鮌鯀鲧棍睔謴啯嘓埚堝墎崞彉彍懖楇濄猓瘑聒蝈蟈郭鈛鍋锅囯囶囻国圀國帼幗慖掴摑漍簂聝腘膕蔮虢馘惈果椁槨淉粿綶菓蜾裹褁輠餜馃腂过過鐹哈紦鉿铪咍嗨孩还骸塰海烸胲酼醢亥嗐妎害氦餀饚駭駴骇佄哻嫨憨犴蚶谽酣頇顸馠魽鼾函凾含唅圅娢寒崡嵅晗梒浛涵澏焓琀甝筨虷蜬邗邯鋡韓韩丆喊浫罕豃傼厈垾屽悍憾扞捍撖撼旱晘暵汉汗涆漢瀚焊熯猂皔睅翰莟菡蔊蛿蜭螒譀輚釬銲鋎閈闬雗頷顄颔馯駻鶾兯爳夯吭垳斻杭笐筕絎绗航苀蚢裄貥迒頏颃魧沆嚆茠蒿薅薧乚儫嗥嘷噑嚎壕椃毜毫濠獆獋獔竓籇蚝蠔譹豪好郝侴傐号哠恏悎昊昦晧暠暤暭曍浩淏滈澔灏灝皓皜皞皡皥秏耗聕薃號鄗顥颢鰝呵喝嗬抲欱蠚訶诃何劾合咊和啝姀峆惒敆曷朅柇核楁毼河涸渮澕熆狢皬盇盉盍盒礉禾篕籺粭紇纥翮荷菏萂螛覈訸詥貈貉郃釛鉌鑉閡閤闔阂阖鞨頜颌餄饸魺鲄鶡鹖麧齕龁龢哬嗃嚇垎壑寉焃煂熇燺爀癋碋翯袔褐謞賀贺赫靍靎靏鶮鶴鸖鹤嘿潶黑黒拫痕鞎佷很狠詪恨亨哼悙涥脝姮恆恒撗桁横橫烆珩胻蘅衡鑅鴴鵆鸻啈叿呍哄嚝揈渹灴烘焢硡薨訇谾軣輷轟轰鍧仜吰垬妅娂宏宖屸弘彋汯沗泓洪浤渱潂玒玜硔竑竤篊粠紅紘紭綋红纮羾翃翝耾苰荭葒葓虹谹谼鈜鉷鋐閎闳霐霟鞃魟鴻鸿黉黌晎撔澒蕻訌讧銾閧闀闂鬨齁侯喉帿猴瘊睺矦篌糇翭翵葔鄇銗鍭餱骺鯸吼吽犼候厚后垕堠後洉茩豞逅郈鮜鱟鲎鲘乎乯匢匫呼唿嘑垀寣幠忽恗惚昒曶歑泘淴滹烀糊膴苸虍虖謼軤轷雐雽喖嘝囫壶壷壺媩弧抇搰斛楜槲湖瀫焀煳狐猢瑚瓳箶絗縠胡葫蔛蝴螜衚觳醐鍸隺頶餬鬍魱鰗鵠鶘鶦鹄鹕乕俿唬汻浒滸琥萀虎虝錿鯱互冱嗀嚛婟嫭嫮岵帍弖怘怙戶户戸戽扈护摢昈枑槴沍沪滬熩瓠祜笏簄粐綔芐蔰護豰鄠鍙頀鱯鳠鳸鸌鹱埖婲椛硴糀花蒊蘤誮錵划劃华呚哗嘩姡搳撶滑猾磆華蕐螖譁釪釫鋘鏵铧驊骅鷨化夻婳嫿嬅崋摦杹枠桦槬樺澅画畫畵繣舙觟話諙諣譮话黊徊怀懐懷槐櫰淮瀤耲蘹褢褱踝咶坏壊壞蘾孉懽欢歓歡犿獾讙貛酄驩鴅鵍圜堚嬛寏寰峘桓洹澴狟獂环環瓛糫絙綄繯缳羦荁萈萑豲貆還鍰鐶锾镮闤阛雈鬟鹮睆緩缓唤喚喛嚾奂奐宦嵈幻患愌换換擐攌梙槵浣涣渙漶澣烉焕煥瑍痪瘓肒藧豢轘逭鯇鯶鰀鲩塃宺巟慌朚肓荒衁偟凰喤堭墴媓崲徨惶揘楻湟潢煌熿獚瑝璜癀皇磺穔篁簧艎葟蝗蟥諻趪遑鍠鐄锽隍韹餭騜鰉鱑鳇鷬黃黄兤奛幌怳恍晃晄櫎炾熀縨詤謊谎愰曂榥滉皝皩鎤咴噅噕婎媈幑徽恢拻挥揮撝晖暉楎洃瀈灰灳烣煇睢睳禈翚翬蘳袆褘詼诙豗輝辉隓隳鰴麾佪囘回囬廻廽恛洄烠痐茴蚘蛔蛕蜖迴逥鮰悔檓毀毁毇燬虺譭会僡儶匯卉喙嘒嚖圚嬒寭屶屷彗彙彚徻恚恵惠慧憓懳晦暳會槥橞檅櫘汇泋湏滙潓濊烩燴獩璤璯瘣瞺秽穢篲絵繢繪绘缋翙翽芔荟蔧蕙薈薉藱蟪詯誨諱譓譿讳诲賄贿鏸鐬闠阓靧頮顪颒餯婚惛昏昬棔殙涽睧睯荤葷蔒轋閽阍忶浑渾珲琿餛馄魂鼲俒倱圂婫尡慁掍混溷焝睴觨諢诨劐吙攉秴耠豁騞佸活秮秳伙夥漷火灬煷邩鈥钬俰剨咟喐嚄嚯嚿奯彟彠惑或捇掝擭旤曤檴沎湱濩瀖獲癨眓矆矐祸禍穫窢耯臛艧获蒦藿蠖謋貨货鍃鑊锪镬閄雘霍靃韄乩僟击刉刏剞叽咭唧喞嗘嘰圾基墼姬屐嵆嵇撃擊朞机枅槣樭機櫅毄激犄玑璣畸畿癪矶磯禨积稘稽積笄筓箕簊綨緁緝缉羁羇羈耭肌芨虀覉覊觭譏譤讥賫賷赍跻踑躋躸銈錤鐖鑇鑙隮雞鞿韲飢饑饥魕鳮鶏鶺鷄鸄鸡鹡齏齑亟亼亽伋佶偮卙即卽及叝吉堲塉姞嫉岌嶯彶忣急愱戢揤极棘楖楫極槉檝殛汲湒潗濈焏疾瘠皀皍磼笈箿籍級级耤膌艥蒺蕀蕺蝍螏襋觙谻趌踖蹐躤輯轚辑郆銡鍓鏶集雧霵齎丮几妀嵴己幾戟挤掎撠擠橶泲犱穖脊虮蟣魢鱾麂伎偈兾冀剂剤劑勣哜嚌坖垍塈妓季寂寄廭彐彑徛忌悸惎懻技旡既旣暨暩曁梞檕檵洎济済漃漈濟瀱璾痵癠祭禝稩稷穄穊穧紀紒継績繋繼纪继绩罽臮芰茍茤荠葪蓟蔇薊薺蘎蘮蘻裚襀覬觊計記誋諅计记跡跽蹟迹际際霁霽驥骥髻鬾魝魥鯚鯽鰶鰿鱀鱭鲚鲫鵋鷑齌乫伽佳傢加嘉家徍抸拁枷梜毠泇浃浹犌猳珈痂笳糘耞腵葭袈豭貑跏迦鉫鎵镓鴐麚唊圿夹夾忦恝戛戞扴脥荚莢蛱蛺袷裌郏郟鋏铗頬頰颊鴶鵊假叚婽岬徦斚斝椵榎槚檟玾甲瘕胛賈贾鉀钾价價嫁幏架榢稼駕驾兼冿囏坚堅奸姦姧尖幵惤戋戔搛椷椾樫櫼歼殱殲湔瀐瀸煎熞熸牋犍猏玪瑊监監睷碊礛礷笺箋緘縑缄缣肩艰艱菅菺葌蒹蔪蕑蕳虃譼豜豣鋻鑯間间雃靬鞯韀韉餰馢鰔鰜鰹鲣鳒鳽鵑鵳鶼鹣麉俭倹儉减剪囝堿帴弿彅戩戬拣挸捡揀揃撿暕枧柬梘检検檢減湕瀽瑐睑瞼硷碱礆笕筧简篯簡籛絸繭翦茧藆蠒裥襇襉襺詃謇謭譾谫趼蹇鐗鐧锏鬋鰎鹸鹻鹼件俴健僭剑剣剱劍劎劒劔墹寋建徤擶旔栫楗榗槛檻毽洊涧渐溅漸澗濺瀳牮珔瞷磵礀箭糋繝腱臶舰艦荐薦袸見覵覸见諓諫譛谏賎賤贱趝跈践踐踺轞鉴鍳鍵鏩鐱鑑鑒鑬鑳键鞬餞饯僵壃姜将將摪橿殭江浆漿畕畺疅疆礓繮缰翞茳葁薑螀螿豇韁鱂鳉傋塂奖奨奬桨槳獎耩膙蒋蔣講讲顜勥匞匠夅嵹弜弶摾櫤洚滰犟糡糨絳绛謽酱醤醬降交僬姣娇嬌峧嶕嶣憍椒浇澆焦燋礁穚簥胶膠膲艽茭茮蕉虠蛟蟭跤轇郊鐎驕骄鮫鲛鵁鷦鷮鹪嚼佼侥僥儌剿劋勦孂徺徼憿挢捁搅摷撟撹攪敫敽敿晈暞曒灚烄煍燞狡璬皎皦矫矯笅筊絞繳纐绞缴脚腳臫蟜角譑賋踋鉸铰餃饺鱎龣叫呌嘂嘄嘦噍噭嬓嶠挍敎教斠滘漖潐獥珓皭窌窖藠訆譥趭較轎轿较酵醮釂喈喼嗟堦媘嫅接掲揭擑椄楬湝煯疖痎癤皆秸稭脻菨蝔街謯阶階鞂鶛倢偼傑刦刧刼劫劼卩卪婕媫孑尐岊崨嵥嶻巀幯截拮捷掶搩擮昅杢杰桀桔桝楶榤洁滐潔狤疌睫碣礍竭節結结羯节莭蓵蛣蜐蠘蠞蠽衱袺訐詰誱讦诘跲踕迼鉣鍻镼鞊頡颉鮚鲒姐媎檞毑解觧飷丯介借吤唶堺屆届岕庎徣悈戒楐犗玠琾界畍疥砎芥藉蚧蛶衸褯誡诫鎅骱魪今仐堇堻巾惍斤津珒琎琻璡矜矝砛禁筋紟荕衿襟觔金釒釿钅鹶黅仅侭僅儘卺厪嫤巹廑慬槿漌瑾紧緊菫蓳謹谨錦锦饉馑伒僸凚劤劲勁唫噤嚍墐壗妗嬧尽搢晉晋枃歏殣浕浸溍濅濜烬煡燼瑨璶盡祲縉缙荩藎覲觐賮贐赆近进進靳齽京亰兢坕坙婛巠惊旌旍晶橸泾涇猄睛秔稉粳精経經綡经聙腈茎荆荊菁葏驚鯨鲸鶁鶄麖麠鼱丼井儆刭剄坓宑幜憬憼景暻殌汫汬澋璄璟璥穽肼蟼警阱頚頸颈俓傹净凈境妌婙婧弪弳径徑敬曔桱梷浄淨瀞獍痉痙竞竟竧竫競竸胫脛莖誩踁迳逕鏡镜靓靖静靚靜鵛冂冋坰埛扃絅蘏蘔駉駫侰僒冏囧泂浻澃炅炯烱煚煛熲燛窘綗褧迥逈顈颎丩勼啾揂揪揫摎朻樛牞究糺糾纠萛赳阄鬏鬮鳩鸠久乆九乣奺杦汣灸玖紤舏酒镹韭韮倃僦匓匛匶厩咎就廄廏廐慦捄救旧柩柾桕欍殧疚臼舅舊鯦鷲鹫麔齨凥匊娵婮居岨崌抅拘掬梮椐檋毩毱泃涺狙琚疽眗砠罝腒艍苴蜛裾諊跔跙踘躹鋦锔陱雎鞠鞫駒驹鮈鴡鶋侷啹婅局巈挶椈橘泦淗湨焗犑狊粷繘菊蘜趜跼蹫輂郹閰駶驧鵙鵴鶪鼰鼳举咀弆挙擧椇榉榘櫸欅沮矩筥聥舉莒蒟襷踽齟龃乬俱倨倶具剧劇勮句埧埾壉姖寠屦屨岠巨巪怇惧愳懅懼拒拠据據昛歫洰澽炬烥犋秬窭窶簴粔耟聚苣虡蚷袓詎讵豦貗距踞躆遽邭醵鉅鋸鐻钜锯颶飓駏鮔勬姢娟捐朘涓焆脧蠲裐鋑鎸鐫镌鹃卷呟埍巻捲臇菤錈锩倦劵勌奆婘帣弮惓慻桊淃狷獧瓹眷睊睠絭絹绢罥羂腃蔨讂鄄餋噘屩屫撅撧亅决刔劂匷厥噊噱孒孓崛崫嶡嶥弡彏憠憰戄抉挗捔掘攫斍桷橛橜櫭欮氒決泬灍焳熦爑爝爴爵獗玃玦玨珏瑴疦瘚矍矡砄絕絶绝臄芵蕝蕨虳蚗蟨蟩覐覚覺觉觖觮觼訣譎诀谲貜赽趉趹蹶蹷躩鈌鐍鐝钁镢駃鴂鴃鷢倔军君均桾汮皲皸皹碅莙菌蚐袀覠軍鈞銁銞鍕钧頵鮶鲪麇麏麕俊儁呁埈寯峻懏捃攈攟晙棞浚濬燇珺畯竣箘箟葰蜠賐郡陖隽雋餕馂駿骏鵔鵕鵘咖喀佧卡咔咯垰胩裃鉲奒开揩鐦锎開凯凱剀剴嘅垲塏嵦恺愷慨暟楷蒈輆鍇鎧铠锴闓闿颽勓忾愾欬炌烗鎎刊勘堪嵁戡栞龕龛侃偘冚凵坎惂欿歁砍竷莰輡轗顑墈崁看瞰矙磡衎闞阚鬫嫝嵻康忼慷槺漮砊穅粇糠躿鏮閌鱇扛亢伉匟囥抗炕犺邟鈧钪闶尻嵪髛丂拷攷栲洘烤考犒銬铐靠鮳鯌鲓匼嗑嵙搕柯棵榼樖牁牱犐珂疴痾瞌砢磕礚科稞窠苛萪薖蚵蝌趷軻轲醘鈳钶頦顆颏颗髁咳壳揢殻殼翗可坷岢嵑嶱敤渇渴炣克刻勀勊堁娔客尅峇恪愘愙氪溘碦礊緙缂艐衉課课錁锞騍骒剋啃垦墾恳懇肎肯肻豤貇錹掯硍裉褃劥坑妔挳摼牼硁硜硻誙銵鍞鏗铿阬倥埪崆悾涳硿空箜躻錓鵼孔恐控鞚剾彄抠摳眍瞘芤劶口冦叩宼寇怐扣敂滱瞉窛筘簆蔲蔻釦鷇刳哭圐堀枯桍矻窟跍郀骷鮬楛狜苦俈喾嚳库庫廤焅瘔秙絝绔袴裤褲酷咵夸姱舿誇侉垮銙挎胯趶跨骻擓蒯侩儈凷哙噲圦块塊墤巜廥快旝欳浍澮狯獪筷糩脍膾郐鄶鱠鲙宽寛寬臗鑧髋髖梡欵款歀窽窾劻匡匩哐恇洭硄筐筺誆诓軭邼忹抂狂狅誑诳軖軠鵟儣夼懭况圹壙岲懬旷昿曠框況爌眖眶矌矿砿礦穬絋絖纊纩貺贶軦邝鄺鉱鋛鑛黋亏刲岿巋悝盔窥窺聧虧闚顝喹夔奎巙戣揆晆暌楏楑櫆犪睽葵藈蘷虁蝰躨逵鄈鍨鍷頯馗騤骙魁傀煃磈跬蹞頍匮匱喟嘳媿嬇尯愦愧憒殨溃潰篑簣籄聩聭聵膭蒉蕢謉餽饋馈坤堃堒崐崑昆晜潉焜熴猑琨瑻菎蜫裈裩褌醌錕锟騉髠髡髨鯤鲲鵾鶤鹍壸壼悃捆梱硱祵稇稛綑裍閫閸阃困涃睏廓扩拡括挄擴濶筈萿葀蛞闊阔霩鞟鞹韕頢髺鬠啦垃拉搚柆菈邋嚹旯磖喇藞剌揦揧攋楋櫴溂爉瓎瘌翋腊臈臘蜡蝋蝲蠟辢辣鑞镴鬎鯻鞡來俫倈婡崃崍庲徕徠来梾棶涞淶猍琜筙箂莱萊逨郲錸铼騋鯠鶆麳襰唻濑瀨瀬癞癩睐睞籁籟藾賚賴赉赖頼顂鵣儖兰啉囒婪岚嵐幱惏懢拦攔斓斕栏欄欗澜瀾灆灡燣燷璼篮籃籣繿葻蓝藍蘫蘭褴襕襤襴襽譋讕谰躝鑭镧闌阑韊壈嬾孄孏懒懶揽擥攬榄欖浨漤灠爦纜缆罱覧覽览醂顲嚂滥濫烂燗爁爛爤瓓糷钄啷勆嫏廊斏桹榔樃欴狼琅瑯硠稂筤艆蓈蜋螂躴郎郒郞鋃鎯锒塱崀朖朗朤烺蓢誏埌浪莨蒗閬阆捞撈粩僗劳労勞哰崂嶗憥朥浶牢痨癆磱窂簩蟧醪鐒铹顟髝佬咾姥恅栳潦狫珯硓老耂荖蛯轑銠铑鮱唠嗠嘮嫪憦橯涝澇烙耢耮躼軂酪乐仂勒叻忇扐楽樂氻泐玏砳竻簕艻阞韷餎鰳鱳鳓了儽嫘擂攂樏檑櫑欙瓃畾礌礧累縲纍纝缧罍羸蔂蘲虆轠鐳鑘镭雷靁鱩鼺傫儡厽垒塁壘壨櫐洡灅癗矋磊磥礨絫耒蕌蕾藟蘽蠝誄讄诔鑸鸓泪涙淚禷类纇肋蘱酹銇錑頛頪類颣嘞唥塄棱楞碐稜薐冷倰堎愣睖踜刕剓剺劙厘喱嚟囄嫠孷廲悡斄梨梸棃樆漓灕犁犂狸琍璃瓈盠睝离穲竰筣篱籬糎縭纚缡罹艃荲菞蓠蔾藜蘺蟍蟸蠫褵謧貍邌醨釐鋫錅鏫鑗離驪骊鯏鯬鱺鲡鵹鸝鹂黎黧俚娌峛峢峲李欚浬澧理礼禮粴蠡裏裡豊逦邐醴里鋰锂鯉鱧鱱鲤鳢丽例俐俪傈儮儷凓利力励勵历厉厤厯厲叓吏呖唎唳嚦囇坜塛壢娳婯孋屴岦巁悧悷慄戾搮擽攊攦攭暦曆曞朸枥栃栎栗栛棙檪櫔櫟櫪欐歴歷沥沴浰涖溧濿瀝爄爏犡猁珕瑮瓅瓑瓥疠疬痢癘癧皪盭睙砅砬砺砾磿礪礫礰禲秝立笠篥粒粝糲綟脷苈苙茘荔莅莉蒚蒞藶蚸蛎蛠蜊蜧蝷蠇蠣觻詈讈赲跞躒轢轣轹郦酈鉝隶隷隸雳靂靋鬁鳨鴗鷅麗麜哩亷劆匲匳嗹噒奁奩嫾帘廉怜慩憐梿槤櫣涟溓漣濂濓瀮熑燫磏簾籢籨縺翴联聨聫聮聯臁莲蓮薕螊蠊裢褳覝謰蹥连連鎌鐮镰鬑鰱鲢嬚摙敛斂歛琏璉羷脸臉蔹蘝蘞裣襝鄻僆堜媡恋戀楝殓殮湅潋澰瀲炼煉瑓練纞练萰錬鍊鏈链鰊俍凉墚梁椋樑涼粮粱糧良踉輬辌駺両两俩倆兩唡啢掚緉脼蜽裲魉魎亮倞哴喨悢晾湸諒谅輌輛辆量鍄撩蹽僚嘹嫽寥寮尞屪嵺嶚嶛廫憀敹暸橑漻燎爎爒獠璙疗療竂簝繚缭聊膋膫藔蟟豂賿蹘辽遼飉髎鷯鹩憭曢瞭蓼鄝釕钌镽尥尦廖撂料炓窷鐐镣咧挘毟儠冽列劣劽哷埒埓姴巤挒捩擸栵洌浖烈烮煭犣猎猟獵聗脟茢蛚裂趔躐迾颲鬛鬣鮤鱲鴷拎临冧厸壣崊嶙斴晽暽林淋潾瀶燐獜琳璘疄瞵碄磷箖粦粼綝繗翷臨轔辚遴邻鄰鏻阾隣霖驎鱗鳞麐麟亃僯凛凜廩廪懍懔撛檁檩澟癛癝菻吝恡悋橉焛甐膦蔺藺賃赁蹸躏躙躪轥閵〇伶凌刢呤囹坽夌姈婈孁崚彾掕昤朎柃棂櫺欞泠淩澪灵燯爧狑玲琌瓴皊砱祾秢竛笭紷綾绫羐羚翎聆舲苓菱蓤蔆蕶蛉衑裬詅跉軨輘酃醽鈴錂铃閝陵零霊霗霛霝駖魿鯪鲮鴒鸰鹷麢齡齢龄龗岭岺嶺袊領领令另炩蘦靈溜澑熘蹓刘劉嚠媹嵧懰斿旈旒榴橊流浏瀏琉瑠瑬璢畄留畱疁瘤癅硫磂蒥蓅藰蟉裗鎏鎦鏐鐂镏镠飀飅飗駠駵騮驑骝鰡鶹鹠麍嬼柳栁桞桺橮熮珋綹绺罶羀鋶锍六塯廇磟翏遛雡霤飂餾馏鬸鷚鹨咙嚨尨嶐巃巄昽曨朧栊槞櫳泷湰滝漋瀧爖珑瓏癃眬矓砻礱礲窿竜笼篭籠聋聾胧茏蘢蠪蠬襱豅躘鏧鑨隆霳靇驡鸗龍龒龓龙儱垄垅壟壠拢攏竉陇隴哢徿梇贚剅喽嘍娄婁廔楼樓溇漊熡瞜耧耬艛蒌蔞蝼螻謱軁遱鞻髅髏鷜塿嵝嶁搂摟甊篓簍屚漏瘘瘺瘻鏤镂陋露噜嚕撸擼謢卢嚧垆壚庐廬攎曥枦栌櫨泸瀘炉爐獹玈璷瓐盧矑籚纑罏胪臚舮舻艫芦蘆蠦轤轳鈩鑪顱颅馿髗魲鱸鲈鸕鸬黸卤塷掳擄樐橹櫓氇氌滷澛瀂硵磠穞艣艪蓾虏虜鏀鐪鑥镥魯鲁鹵侓僇剹勎勠圥坴塶娽峍廘彔录戮摝椂樚淕淥渌漉潞熝琭璐甪盝睩硉碌祿禄稑穋箓簏簬簵簶籙粶膔菉蔍蕗虂螰賂赂趢路踛蹗輅轆辂辘逯醁錄録錴鏕鏴陆陸騄騼鯥鴼鵦鵱鷺鹭鹿麓圝圞奱娈孌孪孿峦巒挛攣曫栾欒滦灓灤癴癵羉脔臠虊銮鑾鵉鸞鸾卵乱亂釠抡掄仑伦侖倫囵圇婨崘崙棆沦淪碖磮綸纶耣腀芲菕蜦踚輪轮錀陯鯩埨惀稐溣論论啰囉捋頱儸囖攞椤欏猡玀箩籮罗羅脶腡萝蘿螺覶覼逻邏鏍鑼锣镙饠騾驘骡鸁倮剆曪瘰癳臝蓏蠃裸躶峈摞泺洛洜漯濼犖珞硌硦笿絡纙络荦落詻雒駱骆鮥鵅榈櫚氀膢藘閭闾驢驴侣侶偻僂儢吕呂屡屢履慺挔捛旅梠焒祣稆穭絽縷缕膂膐褛褸郘鋁铝勴垏嵂律慮櫖氯滤濾爈率箻綠緑繂绿膟葎虑鑢圙寽掠略畧稤鋝鋢锊妈媽嫲嘛犘痲痳蔴蟆蟇麻杩溤犸獁玛瑪码碼蚂螞遤鎷馬马鰢鷌傌嘜榪睰祃禡罵閁駡骂鬕吗嗎埋薶霾买嘪荬蕒買鷶佅劢勱卖唛売脈脉衇賣迈邁霡霢麥麦顢颟姏悗慲摱樠瞒瞞蛮蠻謾谩鞔饅馒鬗鬘鰻鳗娨屘満满滿矕螨蟎襔鏋僈墁嫚幔慢曼槾漫澷熳獌縵缦蔄蔓蘰鄤鏝镘牤厖吂哤娏忙恾杗杧汒浝牻狵痝盲盳硭笀芒茫蘉蛖邙釯鋩铓駹壾漭硥茻莽莾蟒蠎猫貓堥旄枆楙毛氂渵牦犛矛罞芼茅茆蝥蟊軞酕鉾錨锚髦髳鶜乮冇卯夘峁戼昴泖笷蓩鉚铆冃冐冒媢帽愗懋暓柕毷瑁皃眊瞀耄茂萺蝐袤覒貌貿贸鄚鄮嚒嚰濹么麼麽坆堳塺媒嵋徾攗枚栂梅楣楳槑沒没湄湈煤猸玫珻瑂眉睂禖脄脢腜苺莓葿郿酶鋂鎇镅霉鶥鹛黴凂媄媺嬍嵄挴毎每浼渼燘美羙躾鎂镁黣嚜妹媚寐抺旀昧沬煝痗眛睸祙篃蝞袂跊韎鬽魅椚们們扪捫玧璊穈菛虋鍆钔門閅门悶懑懣暪焖燜闷掹擝矇蒙儚幪懞曚朦橗檬氋氓溕濛獴甍甿盟瞢矒礞艨莔萌蕄虻蝱鄳鄸霿靀顭饛鯍鸏鹲冡勐懵猛艋蜢蠓錳锰鯭鼆夢夣孟懜梦癦霥咪眯瞇冞弥彌戂擟攠瀰爢猕獼瓕祢禰糜縻蒾藌蘪蘼袮詸謎谜迷醚醾醿釄镾靡鸍麊麋麛麿侎孊弭敉沵洣渳濔灖米粎羋脒芈葞蔝銤冖冪嘧塓宓宻密峚幂幎幦怽榓樒櫁汨沕泌淧滵漞濗熐祕秘簚糸羃蔤蜜覓覔覛觅謐谧鼏婂媔嬵宀杣棉檰櫋眠矈矊矏綿緜绵臱芇蝒丏偭免冕勉勔喕娩愐汅沔渑湎澠眄睌絻緬缅腼葂靦鮸糆面靣麪麫麵麺喵媌嫹描瞄緢苗鶓鹋劰杪淼渺眇秒篎緲缈藐邈妙庙庿廟玅竗乜吀咩哶孭幭懱搣櫗滅瀎灭烕礣篾蔑薎蠛衊鑖鱴鴓垊姄岷崏怋慜捪旻旼民玟珉琘琝瑉痻盿砇碈緍緡缗罠苠鈱錉鍲鴖僶冺刡勄忞忟悯惽愍憫抿敃敏敯暋泯湣潣皿笢笽簢蠠閔閩闵闽鰵鳘黽黾冥名嫇明暝朙榠洺溟猽眀眳瞑茗蓂螟覭詺鄍銘铭鳴鸣佲凕姳慏酩命掵謬谬嚤摸劘嫫嬤嬷尛庅摩摹擵模橅磨糢膜蘑謨謩谟饃饝馍髍魔魹懡抹嗼圽塻墨妺嫼寞帓帞昩末枺歾歿殁沫漠爅獏瘼皌眜眽眿瞐瞙砞礳秣絈纆耱茉莈莫蓦藦蛨蟔貃貊貘銆鏌镆陌靺驀魩默黙哞侔劺呣恈牟眸繆缪蛑謀谋踎鍪鴾麰某毪氁亩姆峔拇母牡牳畂畆畒畝畞畮砪胟踇鉧仫凩募坶墓幕幙慔慕暮暯木楘毣沐炑牧狇目睦穆縸艒苜莯蚞鉬钼雮霂鞪嗱拏拿搻鎿镎乸哪雫吶呐妠捺笝納纳肭蒳衲袦豽貀軜那郍鈉钠靹魶孻腉乃倷奶嬭廼氖疓艿迺釢奈柰渿耐萘螚褦錼鼐囡侽南喃娚抩暔枏柟楠男畘莮諵遖难難戁揇湳煵腩萳蝻赧婻囔乪嚢囊欜蠰饢馕擃攮曩灢儾齉孬呶夒峱嶩巎怓憹挠撓猱獶獿硇碙蛲蟯詉譊鐃铙匘垴堖嫐恼悩惱瑙碯脑脳腦淖臑閙闹鬧抐疒眲訥讷呢娞脮腇餒馁鮾鯘內内氝氞錗嫩嫰恁能妮倪坭埿婗尼屔怩棿泥淣猊秜籾聣臡蚭蜺觬貎跜輗郳鈮铌霓馜鯢鲵麑齯伱伲你儗儞妳孴抳拟掜擬旎晲柅檷狔聻苨薿隬匿堄嫟嬺屰惄愵昵暱氼溺眤睨縌胒腻膩誽逆拈蔫哖姩年秊秥粘鮎鯰鲇鲶鵇黏捻撚撵攆涊淰焾碾簐蹍蹨躎輦辇卄唸埝廿念惗艌娘嬢孃酿醸釀嫋嬝嬲樢茑蔦袅裊褭鳥鸟尿脲捏揑苶啮嗫噛嚙囁囓圼孼孽嵲嶭巕帇摰敜枿槷櫱涅湼痆篞籋糱糵聂聶臬臲菍蘖蠥讘踂踗踙蹑躡錜鎳鑈鑷钀镊镍闑陧隉顳颞齧囜您脌拰儜凝咛嚀嬣宁寍寕寗寜寧擰柠橣檸狞獰甯聍聹薴鑏鬡鸋拧矃佞侫倿泞澝濘妞汼牛牜忸扭杻炄狃紐纽莥鈕钮靵侬儂农哝噥檂欁浓濃燶禯秾穠脓膿蕽襛譨農辳醲鬞繷弄挊挵癑齈羺槈檽獳耨鎒鐞伮奴孥帑笯駑驽努弩砮胬傉怒搙奻暖渜煖煗餪黁傩儺娜挪梛橠喏愞懦懧掿搦榒稬穤糑糥糯諾诺蹃逽鍩锘女籹釹钕恧朒沑衂衄婩疟瘧硸虐喔噢哦筽塸櫙欧歐殴毆熰瓯甌膒藲謳讴鏂鴎鷗鸥偶吘呕嘔耦腢蕅藕怄慪沤漚啪妑皅舥苩葩趴掱杷潖爬琶筢帊帕怕袙拍俳徘排棑牌犤猅箄簰簲輫哌沠派渒湃蒎鎃攀潘眅萠丬媻幋搫柈槃洀瀊爿盘盤磐磻縏蒰蟠跘蹒蹣鎜鞶冸判叛沜泮溿炍牉畔盼聁袢襻詊鋬鑻頖鵥乓滂胮膖雱霶厐嫎庞庬彷徬旁舽螃逄鰟鳑龎龐耪覫炐眫肨胖抛拋脬萢刨匏咆垉庖炰爮狍袍褜軳鞄麃麅跑奅泡炮疱皰砲礟礮靤麭呸怌肧胚衃醅培婄毰裴裵賠赔錇锫阫陪俖伂佩姵帔斾旆沛浿犻珮蓜轡辔配霈馷喷噴歕湓瓫盆葐呠翸剻匉嘭怦恲抨梈泙烹砰硑磞軯閛駍倗傰堋塜塳弸彭憉捀朋棚椖樥澎熢硼稝竼篣篷纄膨芃莑蓬蘕蟚蟛袶輣錋鑝韸韼騯髼鬅鬔鵬鹏捧淎皏掽椪槰碰踫丕伓伾劈噼坯岯悂憵批披抷旇枈炋狉狓砒磇礔礕秛秠紕纰翍耚豾邳釽鈚鉟銔錃錍陴霹駓髬魾啤埤壀崥枇毗毘焷琵疲皮笓篺罴羆肶脾腗膍蚍蚽蚾蜱螷蠯裨豼貔郫鈹铍阰隦魮鮍鲏鵧鼙仳匹吡噽嚭圮嶏庀擗疋痞癖脴苉諀銢鴄僻媲嫓屁揊淠潎澼甓疈稫譬辟闢鷿鸊偏囨媥楄犏篇翩鍂鶣楩胼腁賆跰蹁駢騈骈骿覑諞谝貵片騗騙骗魸剽勡嘌彯慓旚漂犥翲螵飃飄飘魒嫖瓢薸闝殍皫瞟篻縹缥醥顠僄徱票驃鰾撆撇暼氕瞥覕丿苤鐅嫳姘拚拼砏礗穦馪驞嚬娦嫔嬪玭琕矉薲蘋蠙貧贫顰频颦品榀汖牝聘乒俜娉涄甹砯聠艵頩凭凴呯坪塀屏岼帡帲幈平慿憑枰檘洴淜焩玶瓶甁竮箳簈缾胓苹荓萍蓱蚲蛢評评軿輧郱鮃鲆屛坡岥泼溌潑酦醗醱釙鏺钋頗颇嘙嚩婆櫇皤蔢鄱叵尀笸箥鉕钷駊哱奤岶廹敀昢洦湐烞珀破砶粕蒪迫魄剖娝垺抔抙捊箁裒咅哣掊犃仆噗扑撲攴攵潽炇痡鋪铺陠鯆僕匍圤墣濮獛璞瞨穙纀莆菐菩葡蒱蒲贌酺鏷镤圃圑埔擈普暜朴樸檏氆浦溥烳諩譜谱蹼鐠镨曝瀑舖舗七倛傶僛凄嘁墄妻娸悽慼慽戚捿攲敧期柒栖桤桼棲榿欹欺沏淒漆紪緀萋褄諆踦蹊迉郪鏚霋魌鶈丌亓亝其剘圻埼奇岐岓崎嵜帺忯愭懠掑斉斊旂旗棊棋檱櫀歧淇濝猉玂琦琪璂畦疧碁碕祁祈祺禥竒簯簱籏粸綥綦耆肵脐臍艩芪萁萕蕲藄蘄蚑蚔蚚蛴蜝蜞螧蠐褀跂軝鄿釮錡锜陭隑頎颀騎騏騹骐骑鬐鬿鯕鰭鲯鳍鵸鶀麒麡齊齐乞企启呇唘啓啔啟婍屺岂晵杞棨玘盀綺绮芑諬豈起邔闙呮咠唭噐器夡契弃愒憇憩摖暣栔棄槭欫气気氣汔汽泣湆湇滊炁甈盵矵砌碛碶磜磧磩罊芞葺藒蟿訖讫迄鐑掐擖葜峠拤跒酠鞐冾圶帢恰殎洽硈胢髂仟佥僉千厱圱圲奷婜孯岍悭愆慳扦拪掔搴撁攐攑攓杄檶櫏欦汘汧牵牽竏签簽籖籤粁臤芊茾蚈褰諐謙谦谸迁遷釺鈆鉛鏲钎铅阡韆顅騫骞鬜鬝鵮鹐乹乾亁仱偂前墘媊岒忴扲拑掮揵榩橬歬潛潜濳灊箝羬荨葥蕁虔軡鈐鉗銭錢鎆钤钱钳騚騝鰬黔黚槏浅淺繾缱肷膁蜸譴谴遣鑓伣俔倩傔儙刋堑塹壍嬱嵌悓慊棈椠槧欠歉皘篏篟綪縴芡茜蒨蔳輤呛啌嗆嗴嶈戕戗戧搶摤斨枪椌槍溬牄猐獇玱瑲篬羌羗羫腔蜣謒跄蹌蹡鎗鏘锖锵墙墻嫱嬙廧強强彊樯檣漒牆艢蔃蔷薔蘠墏抢繈繦羟羥襁鏹镪唴炝熗羻劁勪墝墽帩幧悄敲橇毃燆硗磽繑繰缲趬跷踍蹺蹻郻鄡鄥鍫鍬鐰锹頝骹乔侨僑喬嘺墧嫶峤憔桥槗樵橋櫵犞癄睄瞧硚礄翘翹荍荞菬蕎藮譙谯趫鐈鞒鞽顦巧愀釥髜俏僺峭撬撽窍竅誚诮躈陗鞘鞩韒髚切苆癿聺茄且匧厒妾怯悏惬愜挈洯淁穕窃竊笡箧篋籡蛪趄踥郄鍥锲鯜亲侵兓媇寴嵚嵰嶔欽綅衾親誛钦顉駸骎鮼勤嗪噙埐嫀嶜庈懃懄捦擒斳檎澿珡琴琹瘽禽秦耹肣芩芹菦菳蚙螓蠄鈙鈫雂靲鳹鵭坅寑寖寝寢昑梫笉螼赾鋟锓吢吣唚抋揿搇撳沁瀙菣藽倾傾卿圊埥寈氢氫淸清蜻軽輕轻郬錆鑋靑青鯖鲭剠勍啨夝情擎擏晴暒棾樈檠殑氰甠硘葝黥庼廎檾漀苘請謦请頃顷儬凊庆慶掅櫦殸濪碃磬箐綮罄靘儝卭宆惸憌桏橩焪焭煢熍琼璚瓊瓗睘瞏穷穹窮竆笻筇舼茕藑藭蛩蛬赹跫邛銎丘丠坵媝恘恷楸湫湬秋秌穐篍緧萩蓲蘒蚯蝵蟗蠤趥邱鞦鞧鰌鰍鳅鶖鹙龝俅叴唒囚崷巯巰扏朹梂殏毬求汓泅浗渞湭煪犰玌球璆皳盚紌絿肍芁莍虬虯蛷蝤裘觓觩訄訅賕赇逎逑遒酋醔釚釻銶頄鮂鯄鰽鼽搝糗伹佉匤区區呿坥屈岖岴嶇憈抾敺浀焌煀祛筁粬紶胠蛆蛐袪覰詘誳诎趋趍趨躯軀阹駆駈驅驱髷魼鰸鱋鶌麯麴麹黢佢劬忂戵斪朐欋欔氍淭渠灈爠璖璩癯瞿磲籧絇翑胊臞菃葋蕖蘧螶蟝蠷蠼衐衢躣軥鑺鴝鸜鸲鼩取娶曲竘竬蝺詓齲龋刞厺去耝覷覻觑趣閴闃阒麮鼁圈圏奍悛棬椦箞鐉佺全啳埢姾峑巏恮拳搼权楾権權泉洤湶牷犈瑔痊硂筌絟縓荃葲蜷蠸觠詮诠跧踡輇辁醛銓铨闎顴颧駩騡鬈鰁鳈齤烇犬犭犮畎綣绻虇券劝勧勸牶韏炔缺缼蒛阙瘸傕却卻埆塙崅悫愨慤搉棤榷燩琷皵硞确碏確碻礐礭趞闋闕阕雀鵲鹊囷夋踆逡宭峮帬羣群裙裠呥嘫然燃繎肰蚦蚺衻袇袡髥髯冄冉姌媣染橪珃苒蒅儴勷瀼獽瓤禳穣穰蘘躟鬤嚷壌壤攘爙懹譲讓让娆嬈桡橈荛蕘襓饒饶扰擾隢繞绕遶惹热熱人亻仁壬忈忎朲秂芢銋魜鵀忍栠栣棯秹稔綛荏荵躵仞仭任刃刄妊姙屻岃扨杒梕牣祍紉紝絍纫纴肕腍衽袵訒認认讱軔轫鈓靭靱韌韧飪餁饪扔仍礽芿辸陾囸日衵釰釼鈤馹驲傛媶嫆嬫容峵嵘嵤嶸戎搈搑曧栄榕榮榵槦毧溶瀜烿熔爃狨瑢穁絨縙绒羢肜茙茸荣蓉蝾融螎蠑褣鎔镕駥傇冗坈宂氄軵穃厹媃揉柔楺渘煣瑈瓇禸粈糅脜腬葇蝚蹂輮鍒鞣騥鰇鶔韖宍肉譳嶿侞儒嚅如嬬孺帤挐曘桇渪濡筎繻茹蒘蕠薷蝡蠕袽襦邚醹銣铷顬颥鱬鴑鴽乳擩汝肗辱鄏入嗕媷扖杁洳溽縟缛蓐褥鳰堧壖撋偄媆朊瑌瓀碝礝緛耎腝軟輭软阮桵甤緌蕤壡惢橤繠蕊蕋蘂蘃叡枘汭瑞睿芮蚋蜹銳鋭锐瞤橍润潤膶閏閠闰挼捼偌叒婼嵶弱楉渃焫爇箬篛若蒻鄀鰙鰯鶸仨撒洒灑訯躠靸卅摋櫒脎萨蕯薩鈒钑隡颯飒馺嘥噻塞愢揌毢毸腮顋鰓鳃嗮僿簺賽赛三厁叁弎毵毶毿犙鬖伞傘糁糝糣糤繖鏒鏾饊馓俕散潵閐壭桑桒槡嗓搡磉褬鎟顙颡丧喪慅掻搔溞繅缫臊螦颾騒騷骚鰠鱢鳋嫂扫掃埽氉瘙矂髞閪啬嗇懎摵擌栜歮歰洓涩渋澀澁濇濏瀒瑟璱瘷穑穡穯繬色譅轖銫鏼铯雭飋森椮槮襂僧鬙乷唦杀桬榝樧殺毮沙煞猀痧砂硰粆紗繺纱蔱裟鎩铩閷髿魦鯊鯋鲨啥傻儍倽厦唼啑喢嗄帹廈歃箑翜翣萐閯霎筛篩簁簛籭晒曬傓删刪剼嘇圸姍姗山幓彡挻搧杉柵檆潸澘煽狦珊痁笘縿羴羶脠膻舢芟苫衫跚軕邖釤钐閊鯅晱炶煔熌睒覢閃闪陕陝僐善墠墡嬗扇掞擅敾椫樿歚汕灗疝磰禪繕缮膳蟮蟺訕謆譱讪贍赡赸鄯銏鐥饍騸骟鱓鱔鳝伤傷商墒慯殇殤滳漡熵禓蔏螪觞觴謪鬺垧扄晌樉賞贘赏鋿鏛鑜丄上尙尚恦緔绱鞝弰捎旓梢烧焼燒稍筲艄莦萷蕱輎髾鮹勺杓柖玿芍韶少劭卲哨娋潲紹綤绍袑邵奓奢檨猞畬畭畲賒賖赊輋佘揲舌虵蛇蛥捨舍厍厙射弽慑慴懾摂摄攝欇涉涻渉滠灄社舎蔎蠂設设赦韘騇麝伸侁兟呻堔妽姺娠屾峷扟敒曑柛氠深燊珅甡甧申眒砷穼籶籸糂紳绅罙罧莘葠蓡蔘薓裑訷詵诜身駪鯓鯵鰺鲹鵢什榊神鉮鰰哂婶嬸审宷審弞曋沈渖瀋瞫矤矧覾訠諗讅谂谉邥頣魫侺愼慎昚涁渗滲甚瘆瘮眘祳肾胂脤腎葚蜃蜄鋠升呏声斘昇曻枡殅泩湦焺牲狌珄生甥竔笙聲苼鉎鍟阩陞陹鵿鼪憴縄繉繩绳譝偗渻省眚剩剰勝圣墭嵊晟晠榺橳琞盛聖胜蕂貹賸呞失尸屍师師施浉湤湿溮溼濕狮獅瑡箷絁葹蒒蓍虱蝨褷襹詩诗邿酾釃釶鉇鍦鯴鰤鲺鳲鳾鶳鸤乭十埘塒姼实実寔實峕嵵拾时旹時榯湜溡炻石祏竍蚀蝕識识遈鉐食飠饣鮖鰣鲥鼫鼭乨使兘史始宩屎榁矢笶豕鉂駛驶世丗亊事仕侍冟势勢卋呩嗜噬士奭嬕室崼市式弑弒徥忕恀恃戺拭揓是昰枾柹柿栻氏澨烒煶眂眎眡睗示礻秲筮簭舐舓莳蒔螫襫視视觢試誓諟諡謚试谥貰贳軾轼适逝適遾釈释釋鈰鉃鉽銴铈飾餙餝饰鰘籂辻収收垨守手扌艏首兽受售嘼壽夀寿授涭狩獣獸痩瘦綬绶膄鏉书倏倐儵叔姝婌抒掓摅攄書杸枢梳樞橾殊殳毹毺淑瀭焂琡疎疏紓綀纾舒菽蔬跾踈軗輸输鄃陎鮛鵨塾孰尗熟璹秫贖赎属屬数數暏暑曙潻癙糬署薥薯藷蜀蠴襡襩鱪鱰黍鼠鼡侸咰墅尌庶庻怷恕戍捒朮术束树樹沭漱潄澍濖竖竪絉腧荗蒁虪術裋豎述鉥錰鏣霔鶐刷唰耍誜摔衰甩卛帅帥蟀拴栓閂闩涮腨双孀孇欆礵艭雙霜騻驦骦鷞鸘鹴塽慡漺爽縔鏯灀脽誰谁水氵氺閖帨涗涚睡祱稅税裞吮楯橓瞚瞬舜蕣順顺鬊說説说妁搠朔槊欶烁爍獡矟硕碩箾蒴鎙鑠铄丝俬凘厮厶司咝嘶噝媤廝思恖撕斯楒泀澌燍磃禗禠私糹絲緦纟缌罳蕬虒蛳蜤螄蟖蟴鉰銯鋖鍶鐁锶颸飔騦鷥鸶鼶死亖似佀価俟儩兕嗣四姒娰孠寺巳杫枱柶梩榹汜泗泤洍洠涘瀃牭祀禩竢笥耛耜肂肆蕼覗貄釲鈶鈻飤飼饲駟騃驷倯凇娀崧嵩庺忪憽松枀枩柗梥檧淞濍硹菘鬆傱嵷怂悚愯慫楤竦耸聳駷宋訟誦讼诵送鎹頌颂餸凁嗖廀廋捜搜摉摗溲獀艘蒐蓃螋鄋醙鎪锼颼飕餿馊騪傁叜叟嗾擻櫢瞍籔薮藪嗽擞瘶囌櫯甦稣穌窣苏蘇蘓酥鯂俗傃僳嗉塐塑夙嫊宿愫愬憟梀榡樎樕橚殐泝洬涑溯溸潚潥玊珟璛碿簌粛粟素縤肃肅膆莤蔌藗觫訴謖诉谡趚蹜速遡遬鋉餗驌骕鱐鷫鹔狻痠酸匴祘笇筭算蒜倠哸夊浽滖濉熣芕荽荾虽雖鞖瓍綏绥遀隋随隨髄瀡膸髓亗埣嬘岁嵗旞檖歲歳澻煫燧璲睟砕碎祟禭穂穗穟繀繐繸襚誶譢谇賥遂邃鐆鐩隧韢孙孫搎槂狲猻荪蓀蕵薞飧飱损損榫笋筍箰簨鎨隼鶽傞唆嗍嗦娑挱挲摍桫梭睃簑簔縮缩羧莎莏蓑趖鮻乺唢嗩所暛溑獕琐琑瑣索褨鎍鎖鎻鏁锁溹蜶逤他塌她它榙溻牠祂褟趿鉈铊闧塔墖獭獺鮙鰨鳎傝嚃嚺崉挞搨撻榻橽毾沓涾澾濌狧禢粏誻譶踏蹋蹹躂躢遝遢錔闒闥闼阘鞜鞳侤囼孡胎儓台坮嬯抬擡旲檯炱炲箈籉臺苔菭薹跆邰颱駘骀鮐鲐冭太夳忲态態汏汰汱泰溙燤肽舦酞鈦钛啴嘽坍怹摊擹攤滩潬灘痑瘫癱舑貪贪倓坛埮墰墵壇壜婒弹弾彈惔憛昙曇榃橝檀潭燂痰罈罎藫覃談譚譠谈谭貚郯醈醰錟锬顃僋嗿坦忐憳憻暺毯璮菼袒襢醓鉭钽叹嘆探歎湠炭碳舕劏嘡汤湯羰薚蝪蹚鏜镗鞺鼞傏唐啺坣堂塘嵣搪棠榶樘橖溏漟煻瑭磄禟篖糃糖糛膅膛蓎螗螳赯踼鄌醣鎕闛隚餹饄鶶伖倘偒傥儻戃曭淌爣矘耥躺鎲钂镋摥烫燙趟鐋铴夲嫍幍弢慆掏搯槄涛滔濤瑫絛縚縧绦詜謟轁鞱韜韬飸饕匋咷啕桃洮淘祹綯绹萄蜪裪迯逃醄鋾陶鞀鞉饀駣騊鼗討讨套忑忒慝特脦蟘鋱铽熥膯鼟儯幐滕漛疼痋籐籘縢腾藤虅螣誊謄邆駦騰驣鰧霯剔擿梯踢銻锑鷈鷉偍厗啼嗁媞崹徲惿提渧漽瑅睼碮禔禵稊綈緹绨缇罤蕛褆謕趧蹄蹏醍鍗題题騠鮷鯷鳀鵜鶗鶙鷤鹈体挮躰軆骵體倜剃嚏嚔屉屜悌悐惕惖戻掦揥替朑歒殢涕瓋笹籊薙褅趯逖逷髰鬀鬄兲天婖添酟靔靝黇塡填屇恬搷沺湉璳甛甜田畋畑碵磌窴緂胋菾闐阗鴫鷆鷏倎唺忝悿晪殄淟琠痶睓腆舔覥觍賟錪餂掭瑱舚佻庣恌挑旫祧聎岧岹条條樤祒笤芀苕萔蓚蓨蜩调迢鋚鎥鞗髫鯈鰷鲦齠龆嬥宨晀朓窕窱脁誂眺粜糶絩覜趒跳怗聑萜貼贴僣帖蛈鉄銕鐡鐵铁驖呫飻餮厅厛听庁廰廳桯汀烃烴綎耓聴聼聽鞓亭停婷嵉庭廷楟榳渟筳聤莛葶蜓蝏諪邒閮霆鼮侹圢娗挺梃涏烶珽町甼脡艇誔鋌铤頲颋嗵樋炵痌絧蓪通仝佟僮勭同哃峂峒峝庝彤晍曈朣桐橦氃浵潼烔燑犝狪獞眮瞳砼秱穜童粡膧茼蚒詷赨酮鉖鉵銅铜餇鮦鲖捅桶筒筩統綂统恸慟憅痛衕偷偸婾媮緰鋀鍮亠头投頭骰妵敨斢紏蘣黈透凸堗宊嶀怢捸涋湥痜禿秃突葖鋵鵚鼵凃図图圖圗塗屠峹嵞庩廜徒悇捈揬梌涂潳瑹瘏稌筡腯荼蒤跿途酴鈯鍎馟駼鵌鶟鷋鷵吐唋土圡釷钍兎兔堍莵菟迌鵵汢圕湍煓猯貒剸团団團慱抟摶槫檲漙篿糰鏄鷒鷻墥畽疃彖湪褖推蓷藬尵弚橔穨蘈蹪隤頹頺頽颓魋俀僓腿蹆骽娧煺蛻蜕螁褪退駾吞呑噋旽暾朜涒焞囤坉屯忳臀臋芚蛌豘豚軘霕飩饨魨鲀黗氽乇仛侂咃咜托扡拕拖挩捝杔汑沰涶脫脱莌袥託讬飥饦馲魠鮵佗侻坨堶媠岮柁槖橐沱沲狏砣砤碢紽袉詑跎酡阤陀陁馱駄駝駞騨驒驝驮驼鮀鴕鸵鼉鼍鼧妥嫷庹彵椭楕橢鰖鵎唾嶞拓柝毤毻箨籜萚蘀跅劸哇嗗娲媧屲挖搲攨洼溛漥瓾畖穵窊窐窪蛙韈鼃娃佤咓瓦砙邷嗢聉腽膃袜襪韤呙咼喎歪竵外顡剜塆壪婠帵弯彎湾潫灣睕蜿豌丸刓完岏忨抏捖汍烷玩琓笂紈纨翫芄貦頑顽倇唍埦婉宛惋挽晚晥晩晼梚椀涴琬畹皖盌碗箢綩綰绾脘莞菀萖踠輓鋔万卍卐妧捥杤澫瞣脕腕萬薍蟃贃贎輐鋄錽鎫尣尩尪尫汪亡亾仼兦王莣蚟彺往徃惘暀枉棢瀇網网罒罓罔罖菵蛧蝄誷輞辋魍妄忘旺望朢迋偎危厃喴威媙崴嵔嶶巍微愄揋揻椳楲溦烓煨燰癓縅葨葳薇蜲蝛覣詴逶隇隈霺鰃鰄鳂唯喡囗囲围圍壝媁峗峞嵬帏帷幃惟桅欈沩洈涠湋溈潍潙潿濰為爲犩琟矀硙維维蓶覹违違鄬醀鍏闈闱韋韦鮠亹伟伪偉偽僞儰委娓寪尾屗崣嶉徫愇捤撱斖暐梶椲洧浘渨濻瀢炜煒猥玮瑋痏痿硊碨緯纬腲艉芛苇荱萎葦蒍蔿諉诿踓鍡隗韑韙韡韪頠颹骩骪骫鮪鲔为位卫叞味喂墛媦尉慰懀未渭煟熭犚猬畏緭罻胃苿菋蔚藯蘶蜼蝟螱衛衞褽謂讆讏谓躗躛軎轊鏏霨餧餵饖魏鮇鳚塭昷榅榲殟温溫瑥瘟豱輼轀辒鎾鞰饂鰛鰮鳁彣文炆珳瘒紋繧纹聞芠蚉蚊螡蟁閺閿闅闦闻阌雯馼駇魰鳼鴍鼤伆刎吻呅呡抆桽稳穏穩紊肳脗問妏揾搵汶渂璺莬问顐嗡翁聬螉鎓鶲鹟勜塕奣嵡攚暡滃瞈蓊瓮甕罋蕹齆倭唩挝涡涹渦猧窝窩莴萵蜗蝸踒婐婑我捰仴偓卧媉幄捾握斡枂楃沃渥濣焥瓁瞃硪肟腛臒臥齷龌乌剭呜嗚圬屋巫弙杇歍汙汚污洿烏窏箼螐誈誣诬邬鄔鎢钨鰞鴮吳吴吾呉墲娪峿无梧橆毋洖浯無珸璑祦芜茣莁蕪蜈蟱譕郚鋙铻鯃鵐鷡鹀鼯乄五仵伍侮倵儛午啎妩娒娬嫵庑廡忤怃憮捂摀武潕熓牾玝珷瑦甒瞴碔舞躌迕逜陚鵡鹉俉兀务務勿卼唔坞塢奦婺寤屼岉嵍嵨忢悞悟悮戊扤敄旿晤杌溩焐熃物痦矹窹粅芴蘁誤误鋈阢隖雺雾霚霧靰騖骛鶩鹜鼿齀俙傒僖兮凞卥厀吸唏唽嘻噏嚱夕奚娭嬆嬉屖嵠巇希徆徯忚怸恓息悉悕惁惜扱扸昔晞晰晳暿曦析桸榽樨橀欷歙氥汐浠淅渓溪潝烯焁焈焟焬煕熄熈熙熹熺熻燨爔牺犀犠犧狶琋瘜皙睎瞦矽硒磎礂稀穸窸粞糦緆繥羲翕翖肸肹膝舾莃菥蒠蜥螅螇蟋蠵裼西覡觹觽觿譆谿豀豨豯貕赥邜郗鄎酅醯釸錫鏭鐊鑴锡隵餏饎饻鯑鵗鸂鼷习喺媳嶍席椺槢檄漝習蒵蓆薂袭襲觋謵趘郋鎴隰霫飁騱騽驨鰼鳛喜囍壐屣徙憘憙枲橲歖洗漇玺璽矖禧縰葈葸蓰蟢諰謑蹝躧鈢鉨鉩鱚係匸卌呬墍屃屓屭忥怬恄慀戏戯戱戲椞欯潟澙熂犔盻磶禊稧系細綌縘繫细绤舃舄蕮虩衋覤赩趇郤釳闟阋隙隟霼餼饩鬩黖傄呷煆瞎虲虾蝦谺閕颬鰕侠俠匣埉峡峽敮暇柙炠烚狎狭狹珨瑕硖硤碬磍祫筪縖翈舝舺蕸赮轄辖遐鍜鎋陜陿霞騢魻鶷黠閜丅下乤吓圷夏夓懗梺疜睱罅諕鎼鏬仙仚佡僊僲先嘕奾嬐孅屳廯忺憸掀攕暹杴枮氙珗祆秈籼繊纎纖纤苮莶薟褼襳跹蹮躚酰銛銽鍁铦锨韯韱馦鮮鱻鲜鶱伭咁咸啣嗛妶娴娹婱嫌嫺嫻弦憪挦撏涎湺澖甉痫癇癎盷瞯礥稴絃胘舷藖蚿蛝衔衘誸諴賢贒贤輱醎銜鑦閑閒闲鷳鷴鷼鹇鹹麙冼尟尠崄嶮幰搟攇显櫶毨灦烍燹狝猃獫獮玁禒筅箲藓蘚蚬蜆譣赻跣銑鍌铣险険險韅顕顯僩僴县咞哯垷埳塪壏姭娊宪岘峴憲撊晛橌橺涀瀗献獻现現県睍粯糮絤綫線縣线缐羡羨腺臔臽苋莧誢豏鋧錎限陥陷霰餡馅麲鼸乡厢廂忀楿欀湘瓖相稥箱緗纕缃膷芗萫葙薌襄郷鄉鄊鄕鑲镶香驤骧鱜麘佭庠栙瓨祥絴翔詳详跭享亯响想晑蚃蠁銄響飨餉饗饟饷鮝鯗鱶鲞像勨向嚮姠嶑巷曏橡珦缿蟓衖襐象鐌項项鱌侾削呺哓嘐嘵嚣嚻囂婋宯宵庨彇憢揱撨枭枵梟櫹歊毊消潇瀟灱灲烋焇猇獢痚痟硝硣穘窙箫簘簫綃绡翛肖膮萧蕭藃虈虓蛸蟂蟏蟰蠨踃逍銷销霄颵驍骁髇髐魈鴞鴵鷍鸮崤殽洨淆訤誵郩小晓暁曉皛皢筱筿篠謏俲傚効咲哮啸嘋嘨嘯孝恔效敩斅斆校歗涍熽笑詨誟些娎揳楔歇猲蝎蠍偕劦勰协協嗋嚡垥奊孈峫恊愶拹挟挾携撷擕擷攜斜旪熁燲瑎絜綊緳縀缬翓胁脅脇脋膎蝢衺襭諧讗谐邪鞋鞵龤写冩寫藛血亵伳偞偰僁卨卸噧塮夑媟屑屟屧嶰廨徢懈暬械榍榭泄泻洩渫澥瀉瀣灺炧炨烲焎燮爕獬祄禼糏紲絏絬緤繲纈绁缷薢薤蟹蠏褉褻謝谢躞邂靾鞢韰齂齘齛齥俽噷噺妡嬜廞心忄忻惞新昕杺欣歆盺芯薪訢辛邤鈊鋅鑫锌馨馫枔襑鐔镡伈伩信囟孞炘焮脪舋衅訫軐釁阠顖馸垶惺星曐煋猩瑆皨箵篂腥興觪觲謃騂骍鮏鯹侀刑哘型娙形洐滎硎荥蛵行邢郉鈃鉶銒鋞钘铏陉陘餳饧擤睲醒倖兴姓婞嬹幸性悻杏涬緈臖荇莕葕兄兇凶匂匈哅忷恟汹洶胷胸芎訩詾讻賯熊熋雄焸焽夐敻詗诇休俢修咻庥樇烌羞脙脩臹貅銝鎀鏅飍饈馐髤髹鮴鱃鵂鸺苬朽滫潃糔嗅嚊岫峀溴珛琇璓秀綉繍繡绣螑袖褎褏銹鏥鏽锈齅偦吁嘘噓圩墟媭嬃戌揟旴楈欨欻歔歘燸疞盱砉綇縃胥蕦虗虚虛蝑裇訏許諝譃谞鑐需須须顼驉鬚魆魖俆冔徐禑蒣呴喣姁暊栩湑珝盨稰糈詡諿许诩鄦醑伵侐勖勗卹叙垿壻婿序怴恤慉敍敘旭昫晇朂槒欰殈汿沀洫溆漵潊烅烼煦獝珬盢瞁稸絮続緒緖續绪续聓聟芧蓄蓿藇藚訹賉酗銊頊鱮儇吅喧塇媗宣弲愃愋懁揎昍晅暄梋煊瑄睻矎禤箮翧翾萱萲蓒蕿藼蘐蝖蠉諠諼譞谖軒轩鋗鍹鞙駽鰚嫙悬懸旋暶檈漩玄玹琁璇璿痃蜁咺暅烜癣癬选選怰昡楥楦泫渲炫琄眩眴碹絢縼繏绚蔙衒袨贙鉉鏇铉镟颴疶蒆薛辥辪靴鞾乴壆学學峃嶨斈泶澩燢穴茓袕觷踅鷽鸴樰膤艝轌雪鱈鳕吷坹岤桖瀥狘瞲謔谑趐勋勛勲勳嚑坃埙塤壎壦曛焄熏燻爋獯矄纁臐薫薰蘍醺偱噚姰寻尋峋巡廵循恂揗攳旬杊栒桪樳毥洵浔潯灥燅燖珣璕畃紃荀蟳詢询郇鄩駨鱏鱘鲟伨侚卂噀奞巺巽徇愻殉殾汛潠狥稄蕈訊訓訙训讯迅迿逊遜鑂顨馴驯丫压吖呀圧垭壓孲庘押枒桠椏錏鐚铔鴉鴨鵶鸦鸭伢厑厓堐岈崕崖涯漄牙猚琊睚笌芽蚜衙齖厊哑唖啞庌疨痖瘂蕥雅亚亜亞俹冴劜圔圠埡娅婭挜掗揠氩氬犽猰玡砑稏窫聐襾覀訝讶軋轧迓齾傿剦嫣嬮崦嶖恹懕懨樮歅淊淹渰湮漹烟焉焑煙珚硽篶胭臙菸鄢醃閹阉黫严厳啱喦嚴埏塩壛壧妍姸娫娮岩嵒嵓巌巖巗延揅昖楌檐櫩欕沿炎炏狿琂盐研硏碞礹筵簷綖莚蔅虤蜒言訁訮詽讠郔閆閻闫阎顏顔颜鹽麣乵俨偃儼兖兗剡匽厣厴噞夵奄孍嵃巘巚弇愝戭扊抁掩揜曮棪椼檿沇渷演琰甗眼縯罨萒蝘衍裺褗躽遃郾酓隒顩魇魘鰋鶠黡黤黬黭黶鼴鼹齴龑偐厌厭咽唁喭嚈嚥囐堰墕妟姲嬊嬿宴彥彦敥晏暥曕曣椻溎滟灎灔灧灩烻焔焰焱熖燄燕爓牪猒砚硯艳艶艷覎觃觾諺讌讞谚谳豓豔贋贗赝軅酀酽醶醼釅隁雁餍饜騐験騴驗驠验鬳鳫鴈鴳鷃鷰齞央姎抰殃泱眏秧胦鉠鍈雵鞅鴦鸯佯劷垟崵崸徉扬揚敭旸昜暘杨楊氜洋炀烊煬珜疡瘍眻羊羏蛘諹輰鍚钖阦阳陽霷颺飏鰑鴹鸉仰佒傟养卬咉坱岟慃懩攁柍楧氧氱瀁炴痒癢礢紻蝆軮飬養駚怏恙样様樣漾羕詇吆喓夭妖幺楆殀祅腰葽訞邀鴁鴢倄傜嗂垚堯姚媱尧尭峣嶢嶤徭愮揺搖摇摿暚榣滧烑爻猺珧瑤瑶磘窑窯窰繇肴蘨謠謡谣軺轺遙遥邎鎐顤颻飖餆餚鰩鱙鳐仸偠咬婹宎岆崾抭杳枖柼榚溔狕眑窅窈舀苭蓔闄騕鷕齩曜熎燿獟矅穾窔筄纅耀艞药葯薬藥袎要覞詏讑靿鷂鹞鼼倻吔噎擨暍椰歋潱蠮捓揶爷爺瑘耶釾鋣鎁铘也冶嘢埜壄漜野业亱僷叶墷夜嶪嶫抴捙掖擛擪擫晔曄曅曗曳曵枼枽業殗洂液澲烨煠燁爗璍皣瞱瞸礏腋葉謁谒邺鄴鍱鎑鐷靥靨頁页餣饁馌驜鵺鸈亪一乊伊依医吚咿噫壱壹夁嫛嬄弌悘揖撎檹毉洢渏漪猗瑿畩祎禕稦繄蛜衣衤譩辷郼醫銥铱鷖鹥黟黳乁仪侇儀冝匜咦圯夷姨媐宐宜宧寲峓嶬嶷巸彛彜彝彞怡恞扅拸暆杝柂栘桋椬椸沂沶洟熪狋珆瓵疑痍眙移簃籎羠胰荑萓蛦螔袘觺詒誃謻讉诒貽贻跠迻遗遺鏔頉頤頥顊颐飴饴鮧鴺乙乛以佁倚偯嬟崺已庡扆攺敼旑旖椅檥矣礒笖舣艤苡苢蚁螘蟻裿輢轙迆迤迱逘酏釔鈘鉯钇顗鳦齮乂义亄亦亿仡伇伿佚佾俋億兿刈劓劮勚勩匇呓呭呹唈嗌囈圛坄垼埶埸墿奕嫕嬑寱屹峄嶧帟帠幆廙异弈弋役忆忔怈怿悒悥意憶懌懿抑挹敡斁易晹曀曎杙枍枻栧棭榏槸檍欭歝殔殪殹毅泆浂浥浳湙溢潩澺瀷炈焲熠熤熼燚燡燱獈玴異疫痬瘗瘞瘱癔益睪瞖秇穓竩篒縊繶繹绎缢羛義羿翊翌翳翼耴肄肊膉臆艗艺芅苅萟蓺薏藙藝蘙虉蛡蜴螠衪袣裔裛褹襼訲訳詍詣誼譯議讛议译诣谊豙豛豷貖貤贀跇軼轶逸邑鄓醳醷釴鈠鎰鐿镒镱阣隿霬饐駅驛驿骮鮨鯣鶂鶃鶍鷁鷊鷧鷾鸃鹝鹢黓齸弬侌凐喑噾囙因垔堙姻婣愔慇栶殷氤洇溵濦瘖磤禋秵筃絪緸茵荫蒑蔭裀諲銦铟闉阥阴陰陻隂霒霠鞇音韾駰骃齗乑冘吟噖嚚圁垠夤婬寅峾崟崯斦檭殥泿淫滛烎犾狺珢璌碒荶蔩蟫訔訚訡誾鄞鈝銀银霪鷣齦龂龈吲尹嶾廴引朄檃檼櫽淾濥瘾癮粌蘟蚓螾讔赺趛輑鈏隐隠隱靷飮飲饮印垽堷廕慭憖憗懚洕湚猌癊窨胤茚酳鮣偀嘤噟嚶婴媖嫈嬰孆孾应応愥應撄攖朠桜樱櫻渶瀴煐珱瑛璎瓔甇甖碤礯緓纓绬缨罂罃罌膺英莺蘡蝧蠳褮譍譻賏軈鑍锳霙韺鴬鶑鶧鶯鷪鷹鸎鸚鹦鹰僌営塋嬴巆攍楹櫿溁溋滢潆濙濚濴瀅瀛瀠瀯灐灜熒營瑩盁盈禜籝籯縈茔荧莹萤营萦萾蓥藀蛍蝇蝿螢蠅覮謍贏赢迎鎣巊廮影摬梬浧潁瘿癭矨穎郢鐛頴颍颕颖媵映暎硬膡鱦哟唷喲佣傭嗈噰墉壅嫞庸廱慵拥擁滽澭灉牅痈癕癰臃邕郺鄘鏞镛雍雝饔鱅鳙鷛喁顒颙鰫俑勇勈咏埇塎嵱彮怺恿悀惥愑愹慂柡栐永泳涌湧甬硧蛹詠踊踴鯒鲬用砽苚蒏醟优優呦嚘峳幽忧怮悠憂懮攸櫌泑浟滺瀀纋羪耰逌鄾麀偤尢尤庮怞怣楢沋油游犹猶猷由甴疣秞肬莜莸蕕蚰蝣訧輏輶逰遊邮郵鈾铀駀魷鮋鱿鲉丣卣友有栯梄槱湵牖牗禉羑聈苃莠蜏酉銪铕黝亴佑佦侑又右哊唀囿姷孧宥峟幼柚櫾牰狖祐蚴誘诱貁迶酭釉鼬唹扜扝淤瘀盓穻箊紆纡込迂迃陓乻予于亐伃余俞兪堣堬妤娛娯娱媀嬩崳嵎嵛愉愚扵揄於旟杅桙楡楰榆欤歈歟歶渔渝湡漁澞牏狳玗玙瑜璵盂睮禺窬竽籅羭腴臾舁舆艅茰萮萸蕍蘛虞虶蝓螸衧褕覦觎諛謣谀踰輿轝逾邘酑鍝隃隅雓雩餘馀騟骬髃魚魣鮽鯲鰅鱼鷠鸆齵与伛俁俣偊傴匬噳圄圉宇寙屿嶼庾懙挧敔斔斞楀瑀瘐祤禹穥窳羽與萭語语貐鄅雨頨麌齬龉俼僪儥喅喩喻圫域堉妪嫗寓峪嶎庽彧御忬悆惐愈慾戫昱棛棜棫櫲欎欝欥欲毓浴淢淯滪潏澦灪焴煜燏燠爩狱獄玉琙瘉癒矞砡硢硲礇礖礜禦秗稢稶篽籞籲粖緎罭聿肀育艈芋芌茟蒮蓣蓹蕷薁蘌蜟蜮袬裕誉諭譽谕豫軉輍逳遇遹郁醧鈺銉鋊錥鐭钰閾阈雤霱預预飫饇饫馭驈驭鬰鬱鬻魊鱊鳿鴥鴧鴪鵒鷸鸒鹆鹬冤剈囦嬽寃悁惌棩淵渁渆渊渕灁眢肙葾蒬蜎蜵裷駌鳶鴛鵷鸢鸳鹓鼘鼝元円原厡厵员員园圆圎園圓垣塬媴嫄援杬榞榬橼櫞沅湲源溒爰猨猿笎緣縁缘羱芫茒蒝薗蚖蝝蝯螈袁褤謜貟贠轅辕邍邧酛鈨鎱騵魭鶢鶰黿鼋盶薳远逺遠鋺傆噮垸夗妴媛怨愿掾瑗禐苑衏裫褑院願啘曰曱矱箹約约哕噦刖妜嬳岄岳嶽恱悅悦戉抈捳月樾泧瀹爚玥礿禴篗籆籥籰粤粵蘥蚎蚏越跀跃躍軏鈅鉞鑰钥钺閱閲阅鸑鸙黦龠龥奫晕暈氲氳煴熅蒀蒕蝹贇赟馧云伝勻匀囩妘愪抣昀橒沄涢溳澐熉畇眃秐筠筼篔紜縜纭耘耺芸蒷蕓郧鄖鋆雲允喗夽抎殒殞狁磒荺賱鈗阭陨隕霣馻齫齳傊孕恽惲愠慍枟熨緼縕缊腪蕰蕴薀藴蘊褞运運郓鄆酝醖醞韗韞韫韵韻餫匝咂帀扎拶桚沞臜臢迊鉔魳囃杂沯砸襍雑雜雥韴咋哉栽渽溨災灾烖甾畠睵賳宰崽傤儎再在扗洅縡載载酨兂橵簪簮糌鐕鐟鵤偺咱喒儧儹噆寁揝撍攅攒攢昝趱趲囋暂暫濽灒瓉瓒瓚禶襸讃讚賛贊赞蹔鄼錾鏨饡匨牂羘臧賍賘贓贜赃髒駔驵塟奘弉脏臓臟葬蔵銺傮糟蹧遭醩凿鑿早枣栆棗澡璅璪薻藻蚤唕唣喿噪慥梍灶煰燥皁皂竃竈簉艁譟趮躁造则則啧啫嘖嫧帻幘択择擇樍歵沢泎泽溭滜澤皟瞔矠礋箦簀舴蔶蠌襗諎謮責賾责赜迮鸅齚齰仄崱庂捑昃昗汄戝蠈賊贼鰂鱡鲗怎譖谮増增憎橧璔矰磳繒缯罾譄鄫鱛囎熷甑贈赠鋥锃鬵偧劄哳喳抯挓揸摣柤楂樝渣皶皻紥紮觰譇齄齇札牐箚耫蚻譗鍘铡閘闸霅厏拃眨砟鮓鮺鲊鲝乍吒咤宱搾栅榨溠灹炸痄蚱詐诈醡夈捚摘斋斎榸粂齋宅檡窄鉙债債寨瘵砦噡岾嶦惉旃旜枬栴毡氈氊沾瞻薝蛅詀詹譫谵趈邅閚霑飦饘驙魙鱣鳣鸇鹯讝嫸展崭嶃嶄搌斩斬榐橏琖盏盞輾辗醆颭飐佔偡僝占嶘战戦戰栈桟棧湛站綻绽菚蘸虥虦覱譧轏驏傽嫜张張彰慞暲樟漳獐璋章粻蔁蟑遧鄣鏱餦騿鱆麞仉幥掌涨漲礃丈仗墇嶂帐帳幛扙杖涱痮瘬瘴瞕粀胀脹賬账障佋妱巶招昭皽釗鉊鍣钊駋找沼爪爫瑵兆召垗旐曌枛棹櫂炤照燳狣瞾笊箌罀罩羄肁肇肈詔诏赵趙鮡嗻嫬遮厇哲啠喆嚞埑悊折摺晢晣歽矺砓磔籷粍虴蛰蜇蟄袩詟謫謺讁讋谪輒輙轍辄辙銸鮿乽者褶襵赭踷鍺锗柘樜浙淛蔗蟅这這鷓鹧侦偵嫃寊帧帪幀搸斟桢椹楨榛樼殝浈湞溱潧澵獉珍珎瑧甄眞真砧碪祯禎禛箴籈胗臻葴蒖蓁薽貞贞轃遉酙針鉁錱鍼针鱵姫屒弫抮昣枕畛疹眕稹紾縝縥缜聄萙袗裖覙診诊軫轸辴駗鬒黰侲圳塦挋振揕朕栚甽眹紖絼纼誫賑赈鋴鎭鎮镇阵陣震鴆鸩争佂凧埩姃媜峥崝崢征徰徴徵怔掙揁炡烝爭狰猙癥眐睁睜筝箏篜糽聇脀蒸踭鉦錚鏳钲铮鬇愸抍拯掟撜整晸氶塣幁挣政正症証諍證证诤郑鄭靕鴊之倁卮吱巵憄搘支枝栀栺梔椥榰汁汥泜疷知祗祬秓稙綕織织肢胑胝脂臸芝蘵蜘衼隻馶鳷鴲鼅侄値值埴執妷姪嬂慹戠执摭植樴殖淔漐潪犆瓡直禃絷縶聀职職膱蟙跖踯蹠躑軄釞馽凪劧只咫址坁坧墌夂帋恉扺抧指旨枳止汦沚洔淽疻砋祇祉秖紙纸芷茋藢衹襧訨趾軹轵酯阯黹乿俧偫傂儨制剬劕厔垁墆娡寘峙崻帙帜幟庢庤廌彘徏徝志忮懥懫扻挃挚掷搱摨摯擲擳旘晊智柣栉桎梽櫍櫛歭治洷滍滞滯潌瀄炙熫狾猘璏瓆畤疐痓痔痣瘈礩祑秩秷稚稺穉窒筫紩緻置翐膣至致芖蛭袟袠製覟觗觯觶誌豑豒豸貭質贄质贽跱踬躓輊轾迣郅銍鋕鑕铚锧陟隲雉駤騭騺驇骘鯯鴙鷙鸷中伀刣妐幒彸忠柊汷泈炂盅籦終终舯蔠蜙螤螽衳衷蹱鈡銿鍾鐘钟锺鴤鼨冢喠塚尰徸歱煄瘇种種肿腫踵仲众偅堹妕媑狆眾祌筗茽蚛衆衶諥重侜周啁喌嚋婤州徟洲淍炿烐珘盩矪粥舟謅譸诌诪賙赒輈輖辀週郮銂霌駲騆鵃鸼妯碡軸轴帚晭疛睭箒肘菷鯞伷僽冑呪咒咮噣宙昼晝甃皱皺籀籒籕粙紂縐纣绉胄荮葤詋酎駎驟骤侏朱株槠橥櫧櫫洙潴瀦猪珠硃秼絑茱蕏藸蛛蝫蠩袾誅諸诛诸豬跦邾銖铢駯鮢鯺鴸鼄劚孎斸曯欘灟炢烛燭爥瘃窋竹竺笁笜篴舳茿蓫蠋蠾躅逐逫钃鱁丶主劯嘱囑宔帾拄渚濐煑煮燝瞩矚罜褚詝陼鸀麈乼伫佇住助坾墸壴嵀拀杼柱柷樦殶注炷疰眝砫祝祩竚筑筯箸築篫簗紵紸纻羜翥苎苧莇著蛀註貯贮跓軴迬鉒鋳鑄铸飳馵駐驻麆抓撾檛簻膼髽跩拽专叀塼嫥専專瑼甎砖磗磚膞蟤諯鄟顓颛鱄孨竱轉转僎啭囀堟撰灷瑑篆篹籑縳腞蒃襈譔賺赚転饌馔妆妝娤庄庒桩梉樁湷粧糚荘莊装裝壮壯壵撞焋状狀椎追錐锥隹騅骓鵻沝坠墜娷惴甀畷硾礈笍綴縋缀缒腏膇諈贅赘醊錣鑆啍宒窀肫衠諄谆迍准凖埻準綧稕訰倬拙捉桌梲棁棳槕涿炪焯穛穱窧鐯丵劅卓叕啄啅圴妰娺彴撯擆擢斀斫斮斱斲斵晫椓櫡汋浊浞濁濯灂灼烵犳琢琸着硺禚窡篧籗籱罬茁蠗蠿諁諑謶诼酌鋜鐲镯鵫鷟兹呲咨嗞姕姿孖孜孳孶崰嵫栥椔淄湽滋澬玆禌秶稵粢紎緇緕纃缁茊茲菑葘觜訾諮谘貲資赀资赼趑趦輜輺辎鄑鈭錙鍿鎡锱镃頾頿髭鯔鰦鲻鶅鼒齍齜龇蓻仔吇呰啙姉姊子杍梓榟橴滓矷秄秭笫籽紫耔胏茈虸訿釨倳剚字恣渍漬牸眥眦胔胾自芓茡荢嗭倧堫宗嵏嵕惾朡棕椶熧猣磫稯綜緃緵繌综翪腙葼蝬豵踨踪蹤鍐鑁騌騣骔鬃鬉鬷鯮鯼倊偬傯嵸总惣捴揔搃摠焧燪総緫縂總蓗昮猔疭瘲碂粽糉糭縦縱纵掫棷棸箃緅菆諏诹邹郰鄒鄹陬騶驺鯫鲰黀齱齺走赱鯐奏揍租菹葅蒩卆卒哫崒崪族椊箤足踤鏃镞俎唨爼珇祖組组詛诅鎺阻靻劗躜躦鉆鑚鑽钻籫繤纂纉纘缵攥厜嗺樶纗蟕嘴噿嶊璻冣嶵晬最栬槜檇檌祽稡絊罪蕞辠酔酻醉鋷錊噂墫尊嶟樽繜罇遵鐏鱒鳟鶎鷷僔撙譐捘銌嘬穝捽昨秨稓笮筰苲莋鈼佐左繓作侳做唑坐岝岞座怍柞祚糳胙葃葄蓙袏酢阼飵咗龦龧龨龩龪龫龬龭龮龯龰龱龲龳龴龵龶龷龸龹龺龻龼龽龾龿鿀鿁鿂鿃鿄鿅鿆鿇鿈鿉鿊鿋鿌鿍鿎鿏鿐";BI.CODE_INDEX={};for(var t=0;t"}),BI.createWidget({type:"bi.default",element:this.element,items:[this.tree]})},_selectTreeNode:function(e,t){this.fireEvent(BI.Controller.EVENT_CHANGE,BI.Events.CLICK,t,this),this.fireEvent(BI.TreeView.EVENT_CHANGE,t,this)},_configSetting:function(){var e=this.options.paras,o=this,t={async:{enable:!0,url:function(e,t){var n=o._getParentValues(t);return t.times=t.times||1,"&id="+t.id+"×="+t.times+++"&parentValues= "+_global.encodeURIComponent(BI.jsonEncode(n))+"&checkState="+_global.encodeURIComponent(BI.jsonEncode(t.getCheckStatus()))},autoParam:["id","name"],otherParam:BI.cjkEncodeDO(e)},check:{enable:!0},data:{key:{title:"title",name:"text"},simpleData:{enable:!0}},view:{showIcon:!1,expandSpeed:"",nameIsHTML:!0,dblClickExpand:!1},callback:{beforeExpand:function(e,t){if(t.isAjaxing)return BI.Msg.toast("Please Wait。","warning"),!1;t.children||(t.times=1,l(t,"refresh"));return!0},onAsyncSuccess:function(e,t,n,i){if(n.halfCheck=!1,!i||0===i.length||/^[\s,\S]*<\/html>$/gi.test(i)||o._stop)return;var r=o.nodes,a=n.count||0;n.children.length>a?(n.count=n.children.length,BI.delay(function(){l(n)},s)):(r.updateNode(n),r.selectNode(n.children[0]))},onAsyncError:function(e,t,n,i,r,a){o.nodes;BI.Msg.toast("Error!","warning")},beforeCheck:function(e,t){var n=t.getCheckStatus();{var i;!(t.halfCheck=!1)===t.checked&&(function r(e){BI.each(e,function(e,t){!0===t.halfCheck&&(t.halfCheck=!1,r(t.children))})}(t.children),i=o.nodes.getSelectedNodes(),BI.$.each(i,function(e,t){t.halfCheck=!1}))}!0===n.half&&!0===n.checked&&(t.checked=!1)},onCheck:function(e,t,n){o._selectTreeNode(t,n)},onExpand:function(e,t,n){n.halfCheck=!1},onCollapse:function(e,t,n){},onClick:function(e,t,n){var i=n.checked,r=n.getCheckStatus();!0===r.half&&!0===r.checked&&(i=!1);o.nodes.checkNode(n,!i,!0,!0)}}},s=100;function l(e,t){var n=o.nodes;"refresh"==t&&n.updateNode(e),n.reAsyncChildNodes(e,t,!0)}return t},_getParentValues:function(e){if(!e.getParentNode())return[];var t=e.getParentNode();return this._getParentValues(t).concat([this._getNodeValue(t)])},_getNodeValue:function(e){return null==e.value?BI.replaceAll(e.text.replace(/<[^>]+>/g,"")," "," "):e.value},_getHalfSelectedValues:function(n,e){var t,i,r,a,o,s=this,l=e.getCheckStatus();!1===l.checked&&!1===l.half||(BI.isNotEmptyArray(e.children)&&!0===l.half?(t=e.children,BI.each(t,function(e,t){s._getHalfSelectedValues(n,t)})):(r=(i=e.parentValues||s._getParentValues(e)).concat(this._getNodeValue(e)),BI.isNotEmptyArray(e.children)||!1===l.half?this._buildTree(n,r):(a=BI.deepClone(this.options.paras.selectedValues),o=this._getTree(a,r),this._addTreeNode(n,i,this._getNodeValue(e),o))))},_getTree:function(e,t){var n=e;return BI.any(t,function(e,t){return null==n[t]||void(n=n[t])}),n},_addTreeNode:function(e,t,n,i){var r=e;BI.each(t,function(e,t){null==r[t]&&(r[t]={}),r=r[t]}),r[n]=i},_buildTree:function(e,t){var n=e;BI.each(t,function(e,t){null==n[t]&&(n[t]={}),n=n[t]})},_getSelectedValues:function(){var e,r=this,a={},t=this.nodes.getNodes();return e=t,BI.each(e,function(e,t){var n,i=t.getCheckStatus();!0!==i.checked&&!0!==i.half||(!0===i.half?r._getHalfSelectedValues(a,t):(n=(t.parentValues||r._getParentValues(t)).concat([r._getNodeValue(t)]),r._buildTree(a,n)))}),a},_dealWidthNodes:function(e){var n=this.options,t=BI.Tree.arrayFormat(e);return BI.each(t,function(e,t){t.title=t.title||t.text||t.value,t.isParent=t.isParent||t.parent,t.value=t.value||t.text,BI.isKey(n.paras.keyword)?t.text=BI.$("
").__textKeywordMarked__(BI.Text.formatText(t.text+""),n.paras.keyword,t.py).html():t.text=BI.htmlEncode(BI.Text.formatText(t.text+""))}),e},_loadMore:function(){var i=this,e=this.options;this.tip.setLoading();var t=BI.extend({},e.paras,{times:++this.times});e.itemsCreator(t,function(e){var t,n;!0!==i._stop&&(t=!!e.hasNext,n=e.items||[],t?i.tip.setLoaded():i.tip.setEnd(),0"},_defaultConfig:function(){return BI.extend(BI.ListTreeView.superclass._defaultConfig.apply(this,arguments),{value:{}})},_init:function(){BI.ListTreeView.superclass._init.apply(this,arguments);var e=this.options;BI.isNotNull(e.value)&&this.setSelectedValue(e.value)},_configSetting:function(){this.options.paras;var a=this;return{async:{enable:!1},check:{enable:!0,chkboxType:{Y:"",N:""}},data:{key:{title:"title",name:"text"},simpleData:{enable:!0}},view:{showIcon:!1,expandSpeed:"",nameIsHTML:!0,dblClickExpand:!1},callback:{onCheck:function(e,t,n){a._selectTreeNode(t,n)},onClick:function(e,t,n){var i=BI.$.fn.zTree.getZTreeObj(t),r=n.checked;a._checkValue(n,!r),i.checkNode(n,!r,!0,!0)}}}},_selectTreeNode:function(e,t){this._checkValue(t,t.checked),BI.ListTreeView.superclass._selectTreeNode.apply(this,arguments)},_transArrayToMap:function(e){var i=this,r={};return BI.each(e,function(e,t){var n=t.join(i._constants.SPLIT);r[n]=!0}),r},_transMapToArray:function(e){var n=this,i=[];return BI.each(e,function(e){var t=e.split(n._constants.SPLIT);i.push(t)}),i},_checkValue:function(e,t){var n=BI.concat(this._getParentValues(e),this._getNodeValue(e)).join(this._constants.SPLIT);t?this.storeValue[n]=!0:delete this.storeValue[n]},setSelectedValue:function(e){this.options.paras.selectedValues=e||[],this.storeValue=this._transArrayToMap(e)},getValue:function(){return this._transMapToArray(this.storeValue)}}),BI.shortcut("bi.list_tree_view",BI.ListTreeView)},function(e,t){BI.ListAsyncTree=BI.inherit(BI.ListTreeView,{_defaultConfig:function(){return BI.extend(BI.ListAsyncTree.superclass._defaultConfig.apply(this,arguments),{})},_init:function(){BI.ListAsyncTree.superclass._init.apply(this,arguments)},_configSetting:function(){var e=this.options.paras,a=this;return{async:{enable:!1,otherParam:BI.cjkEncodeDO(e)},check:{enable:!0,chkboxType:{Y:"",N:""}},data:{key:{title:"title",name:"text"},simpleData:{enable:!0}},view:{showIcon:!1,expandSpeed:"",nameIsHTML:!0,dblClickExpand:!1},callback:{onCheck:function(e,t,n){a._selectTreeNode(t,n)},beforeExpand:function(e,t){a._beforeExpandNode(e,t)},beforeCheck:function(e,t){t.half=!1},onClick:function(e,t,n){var i=BI.$.fn.zTree.getZTreeObj(t),r=n.checked;a._checkValue(n,!r),i.checkNode(n,!r,!0,!0)}}}},_beforeExpandNode:function(e,r){var a=this,o=this.options,t=r.parentValues||a._getParentValues(r),s=BI.extend({},o.paras,{id:r.id,times:1,parentValues:t.concat(this._getNodeValue(r))}),l=function(e){var t,n,i=e.items||[];0'),iframe=handler.iframe||(handler.iframe=document.createElement(''))}catch(e){var form=document.createElement("form"),iframe=handler.iframe||(handler.iframe=document.createElement("iframe"));form.setAttribute("enctype","multipart/form-data"),iframe.setAttribute("name",iframe.id=target),iframe.setAttribute("src",url)}with(iframe.style.position="absolute",iframe.style.left=iframe.style.top="-10000px",iframe.onload=onload,iframe.onerror=function(e){isFunction(handler.onerror)&&handler.onerror(rpe,e||_global.event)},iframe.onreadystatechange=function(){/loaded|complete/i.test(iframe.readyState)?onload():isFunction(handler.onloadprogress)&&(rpe.loaded>0:-1,files:[],clean:function(){this.files=[]},upload:function(e){if(e)for(var t in e)this[t]=e[t];return sendFiles(this,this.maxSize),this},hide:function(){this.dom.disabled&&(this.dom.disabled=!1,this.dom.input.removeAttribute("disabled"))},show:function(e,t,n,i){this.dom.disabled||(this.dom.disabled=!0,this.dom.input.setAttribute("disabled","disabled"))}})},select:function(){this.wrap&&BI.Widget._renderEngine.createElement(this.wrap.dom.input).click()},upload:function(e){this.wrap&&this.wrap.upload(e)},getValue:function(){return this.wrap?this.wrap.attach_array:[]},reset:function(){this.wrap&&(this.wrap.attach_array=[],this.wrap.attach_names=[],this.wrap.attachNum=0)},_setEnable:function(e){BI.File.superclass._setEnable.apply(this,arguments),!0===e?this.element.attr("disabled","disabled"):this.element.removeAttr("disabled")}}),BI.File.EVENT_CHANGE="EVENT_CHANGE",BI.File.EVENT_UPLOADSTART="EVENT_UPLOADSTART",BI.File.EVENT_ERROR="EVENT_ERROR",BI.File.EVENT_PROGRESS="EVENT_PROGRESS",BI.File.EVENT_UPLOADED="EVENT_UPLOADED",BI.shortcut("bi.file",BI.File)}(_global.document||{})},function(module,exports){!function($){var settings={},roots={},caches={},_consts={className:{BUTTON:"button",LEVEL:"level",ICO_LOADING:"ico_loading",SWITCH:"switch"},event:{NODECREATED:"ztree_nodeCreated",CLICK:"ztree_click",EXPAND:"ztree_expand",COLLAPSE:"ztree_collapse",ASYNC_SUCCESS:"ztree_async_success",ASYNC_ERROR:"ztree_async_error",REMOVE:"ztree_remove",SELECTED:"ztree_selected",UNSELECTED:"ztree_unselected"},id:{A:"_a",ICON:"_ico",SPAN:"_span",SWITCH:"_switch",UL:"_ul"},line:{ROOT:"root",ROOTS:"roots",CENTER:"center",BOTTOM:"bottom",NOLINE:"noline",LINE:"line"},folder:{OPEN:"open",CLOSE:"close",DOCU:"docu"},node:{CURSELECTED:"curSelectedNode"}},_setting={treeId:"",treeObj:null,view:{addDiyDom:null,autoCancelSelected:!0,dblClickExpand:!0,expandSpeed:"fast",fontCss:{},nameIsHTML:!1,selectedMulti:!0,showIcon:!0,showLine:!0,showTitle:!0,txtSelectedEnable:!1},data:{key:{children:"children",name:"name",title:"",url:"url"},simpleData:{enable:!1,idKey:"id",pIdKey:"pId",rootPId:null},keep:{parent:!1,leaf:!1}},async:{enable:!1,contentType:"application/x-www-form-urlencoded",type:"post",dataType:"text",url:"",autoParam:[],otherParam:[],dataFilter:null},callback:{beforeAsync:null,beforeClick:null,beforeDblClick:null,beforeRightClick:null,beforeMouseDown:null,beforeMouseUp:null,beforeExpand:null,beforeCollapse:null,beforeRemove:null,onAsyncError:null,onAsyncSuccess:null,onNodeCreated:null,onClick:null,onDblClick:null,onRightClick:null,onMouseDown:null,onMouseUp:null,onExpand:null,onCollapse:null,onRemove:null}},_initRoot=function(e){var t=data.getRoot(e);t||(t={},data.setRoot(e,t)),t[e.data.key.children]=[],t.expandTriggerFlag=!1,t.curSelectedList=[],t.noSelection=!0,t.createdNodes=[],t.zId=0,t._ver=(new Date).getTime()},_initCache=function(e){var t=data.getCache(e);t||(t={},data.setCache(e,t)),t.nodes=[],t.doms=[]},_bindEvent=function(o){var e=o.treeObj,t=consts.event;e.bind(t.NODECREATED,function(e,t,n){tools.apply(o.callback.onNodeCreated,[e,t,n])}),e.bind(t.CLICK,function(e,t,n,i,r){tools.apply(o.callback.onClick,[t,n,i,r])}),e.bind(t.EXPAND,function(e,t,n){tools.apply(o.callback.onExpand,[e,t,n])}),e.bind(t.COLLAPSE,function(e,t,n){tools.apply(o.callback.onCollapse,[e,t,n])}),e.bind(t.ASYNC_SUCCESS,function(e,t,n,i){tools.apply(o.callback.onAsyncSuccess,[e,t,n,i])}),e.bind(t.ASYNC_ERROR,function(e,t,n,i,r,a){tools.apply(o.callback.onAsyncError,[e,t,n,i,r,a])}),e.bind(t.REMOVE,function(e,t,n){tools.apply(o.callback.onRemove,[e,t,n])}),e.bind(t.SELECTED,function(e,t,n,i){tools.apply(o.callback.onSelected,[t,n,i])}),e.bind(t.UNSELECTED,function(e,t,n,i){tools.apply(o.callback.onUnSelected,[t,n,i])})},_unbindEvent=function(e){var t=e.treeObj,n=consts.event;t.unbind(n.NODECREATED).unbind(n.CLICK).unbind(n.EXPAND).unbind(n.COLLAPSE).unbind(n.ASYNC_SUCCESS).unbind(n.ASYNC_ERROR).unbind(n.REMOVE).unbind(n.SELECTED).unbind(n.UNSELECTED)},_eventProxy=function(e){var t=e.target,n=data.getSetting(e.data.treeId),i="",r=null,a="",o="",s=null,l=null,u=null;if(tools.eqs(e.type,"mousedown")?o="mousedown":tools.eqs(e.type,"mouseup")?o="mouseup":tools.eqs(e.type,"contextmenu")?o="contextmenu":tools.eqs(e.type,"click")?tools.eqs(t.tagName,"span")&&null!==t.getAttribute("treeNode"+consts.id.SWITCH)?(i=tools.getNodeMainDom(t).id,a="switchNode"):(u=tools.getMDom(n,t,[{tagName:"a",attrName:"treeNode"+consts.id.A}]))&&(i=tools.getNodeMainDom(u).id,a="clickNode"):tools.eqs(e.type,"dblclick")&&(o="dblclick",(u=tools.getMDom(n,t,[{tagName:"a",attrName:"treeNode"+consts.id.A}]))&&(i=tools.getNodeMainDom(u).id,a="switchNode")),0/g,">");e.push("",r,"")},makeDOMNodeLine:function(e,t,n){e.push("")},makeDOMNodeMainAfter:function(e,t,n){e.push("")},makeDOMNodeMainBefore:function(e,t,n){e.push("
  • ")},makeDOMNodeNameAfter:function(e,t,n){e.push("")},makeDOMNodeNameBefore:function(e,t,n){var i=data.getNodeTitle(t,n),r=view.makeNodeUrl(t,n),a=view.makeNodeFontCss(t,n),o=[];for(var s in a)o.push(s,":",a[s],";");e.push("/g,">"),"'"),e.push(">")},makeNodeFontCss:function(e,t){var n=tools.apply(e.view.fontCss,[e.treeId,t],e.view.fontCss);return n&&"function"!=typeof n?n:{}},makeNodeIcoClass:function(e,t){var n=["ico"];return t.isAjaxing||(n[0]=(t.iconSkin?t.iconSkin+"_":"")+n[0],t.isParent?n.push(t.open?consts.folder.OPEN:consts.folder.CLOSE):n.push(consts.folder.DOCU)),consts.className.BUTTON+" "+n.join("_")},makeNodeIcoStyle:function(e,t){var n,i=[];return t.isAjaxing||((n=t.isParent&&t.iconOpen&&t.iconClose?t.open?t.iconOpen:t.iconClose:t.icon)&&i.push("background:url(",n,") 0 0 no-repeat;"),0!=e.view.showIcon&&tools.apply(e.view.showIcon,[e.treeId,t],!0)||i.push("width:0px;height:0px;")),i.join("")},makeNodeLineClass:function(e,t){var n=[];return e.view.showLine?0==t.level&&t.isFirstNode&&t.isLastNode?n.push(consts.line.ROOT):0==t.level&&t.isFirstNode?n.push(consts.line.ROOTS):t.isLastNode?n.push(consts.line.BOTTOM):n.push(consts.line.CENTER):n.push(consts.line.NOLINE),t.isParent?n.push(t.open?consts.folder.OPEN:consts.folder.CLOSE):n.push(consts.folder.DOCU),view.makeNodeLineClassEx(t)+n.join("_")},makeNodeLineClassEx:function(e){return consts.className.BUTTON+" "+consts.className.LEVEL+e.level+" "+consts.className.SWITCH+" "},makeNodeTarget:function(e){return e.target||"_blank"},makeNodeUrl:function(e,t){var n=e.data.key.url;return t[n]?t[n]:null},makeUlHtml:function(e,t,n,i){n.push("
      "),n.push(i),n.push("
    ")},makeUlLineClass:function(e,t){return e.view.showLine&&!t.isLastNode?consts.line.LINE:""},removeChildNodes:function(e,t){if(t){var n=e.data.key.children,i=t[n];if(i){for(var r,a,o=0,s=i.length;o
    ') !== '7';\n});\n\nvar SPLIT_WORKS_WITH_OVERWRITTEN_EXEC = (function () {\n // Chrome 51 has a buggy \"split\" implementation when RegExp#exec !== nativeExec\n var re = /(?:)/;\n var originalExec = re.exec;\n re.exec = function () { return originalExec.apply(this, arguments); };\n var result = 'ab'.split(re);\n return result.length === 2 && result[0] === 'a' && result[1] === 'b';\n})();\n\nmodule.exports = function (KEY, length, exec) {\n var SYMBOL = wks(KEY);\n\n var DELEGATES_TO_SYMBOL = !fails(function () {\n // String methods call symbol-named RegEp methods\n var O = {};\n O[SYMBOL] = function () { return 7; };\n return ''[KEY](O) != 7;\n });\n\n var DELEGATES_TO_EXEC = DELEGATES_TO_SYMBOL ? !fails(function () {\n // Symbol-named RegExp methods call .exec\n var execCalled = false;\n var re = /a/;\n re.exec = function () { execCalled = true; return null; };\n if (KEY === 'split') {\n // RegExp[@@split] doesn't call the regex's exec method, but first creates\n // a new one. We need to return the patched regex when creating the new one.\n re.constructor = {};\n re.constructor[SPECIES] = function () { return re; };\n }\n re[SYMBOL]('');\n return !execCalled;\n }) : undefined;\n\n if (\n !DELEGATES_TO_SYMBOL ||\n !DELEGATES_TO_EXEC ||\n (KEY === 'replace' && !REPLACE_SUPPORTS_NAMED_GROUPS) ||\n (KEY === 'split' && !SPLIT_WORKS_WITH_OVERWRITTEN_EXEC)\n ) {\n var nativeRegExpMethod = /./[SYMBOL];\n var fns = exec(\n defined,\n SYMBOL,\n ''[KEY],\n function maybeCallNative(nativeMethod, regexp, str, arg2, forceStringMethod) {\n if (regexp.exec === regexpExec) {\n if (DELEGATES_TO_SYMBOL && !forceStringMethod) {\n // The native String method already delegates to @@method (this\n // polyfilled function), leasing to infinite recursion.\n // We avoid it by directly calling the native @@method method.\n return { done: true, value: nativeRegExpMethod.call(regexp, str, arg2) };\n }\n return { done: true, value: nativeMethod.call(str, regexp, arg2) };\n }\n return { done: false };\n }\n );\n var strfn = fns[0];\n var rxfn = fns[1];\n\n redefine(String.prototype, KEY, strfn);\n hide(RegExp.prototype, SYMBOL, length == 2\n // 21.2.5.8 RegExp.prototype[@@replace](string, replaceValue)\n // 21.2.5.11 RegExp.prototype[@@split](string, limit)\n ? function (string, arg) { return rxfn.call(string, this, arg); }\n // 21.2.5.6 RegExp.prototype[@@match](string)\n // 21.2.5.9 RegExp.prototype[@@search](string)\n : function (string) { return rxfn.call(string, this); }\n );\n }\n};\n","var ctx = require('./_ctx');\nvar call = require('./_iter-call');\nvar isArrayIter = require('./_is-array-iter');\nvar anObject = require('./_an-object');\nvar toLength = require('./_to-length');\nvar getIterFn = require('./core.get-iterator-method');\nvar BREAK = {};\nvar RETURN = {};\nvar exports = module.exports = function (iterable, entries, fn, that, ITERATOR) {\n var iterFn = ITERATOR ? function () { return iterable; } : getIterFn(iterable);\n var f = ctx(fn, that, entries ? 2 : 1);\n var index = 0;\n var length, step, iterator, result;\n if (typeof iterFn != 'function') throw TypeError(iterable + ' is not iterable!');\n // fast case for arrays with default iterator\n if (isArrayIter(iterFn)) for (length = toLength(iterable.length); length > index; index++) {\n result = entries ? f(anObject(step = iterable[index])[0], step[1]) : f(iterable[index]);\n if (result === BREAK || result === RETURN) return result;\n } else for (iterator = iterFn.call(iterable); !(step = iterator.next()).done;) {\n result = call(iterator, f, step.value, entries);\n if (result === BREAK || result === RETURN) return result;\n }\n};\nexports.BREAK = BREAK;\nexports.RETURN = RETURN;\n","var global = require('./_global');\nvar navigator = global.navigator;\n\nmodule.exports = navigator && navigator.userAgent || '';\n","'use strict';\nvar global = require('./_global');\nvar $export = require('./_export');\nvar redefine = require('./_redefine');\nvar redefineAll = require('./_redefine-all');\nvar meta = require('./_meta');\nvar forOf = require('./_for-of');\nvar anInstance = require('./_an-instance');\nvar isObject = require('./_is-object');\nvar fails = require('./_fails');\nvar $iterDetect = require('./_iter-detect');\nvar setToStringTag = require('./_set-to-string-tag');\nvar inheritIfRequired = require('./_inherit-if-required');\n\nmodule.exports = function (NAME, wrapper, methods, common, IS_MAP, IS_WEAK) {\n var Base = global[NAME];\n var C = Base;\n var ADDER = IS_MAP ? 'set' : 'add';\n var proto = C && C.prototype;\n var O = {};\n var fixMethod = function (KEY) {\n var fn = proto[KEY];\n redefine(proto, KEY,\n KEY == 'delete' ? function (a) {\n return IS_WEAK && !isObject(a) ? false : fn.call(this, a === 0 ? 0 : a);\n } : KEY == 'has' ? function has(a) {\n return IS_WEAK && !isObject(a) ? false : fn.call(this, a === 0 ? 0 : a);\n } : KEY == 'get' ? function get(a) {\n return IS_WEAK && !isObject(a) ? undefined : fn.call(this, a === 0 ? 0 : a);\n } : KEY == 'add' ? function add(a) { fn.call(this, a === 0 ? 0 : a); return this; }\n : function set(a, b) { fn.call(this, a === 0 ? 0 : a, b); return this; }\n );\n };\n if (typeof C != 'function' || !(IS_WEAK || proto.forEach && !fails(function () {\n new C().entries().next();\n }))) {\n // create collection constructor\n C = common.getConstructor(wrapper, NAME, IS_MAP, ADDER);\n redefineAll(C.prototype, methods);\n meta.NEED = true;\n } else {\n var instance = new C();\n // early implementations not supports chaining\n var HASNT_CHAINING = instance[ADDER](IS_WEAK ? {} : -0, 1) != instance;\n // V8 ~ Chromium 40- weak-collections throws on primitives, but should return false\n var THROWS_ON_PRIMITIVES = fails(function () { instance.has(1); });\n // most early implementations doesn't supports iterables, most modern - not close it correctly\n var ACCEPT_ITERABLES = $iterDetect(function (iter) { new C(iter); }); // eslint-disable-line no-new\n // for early implementations -0 and +0 not the same\n var BUGGY_ZERO = !IS_WEAK && fails(function () {\n // V8 ~ Chromium 42- fails only with 5+ elements\n var $instance = new C();\n var index = 5;\n while (index--) $instance[ADDER](index, index);\n return !$instance.has(-0);\n });\n if (!ACCEPT_ITERABLES) {\n C = wrapper(function (target, iterable) {\n anInstance(target, C, NAME);\n var that = inheritIfRequired(new Base(), target, C);\n if (iterable != undefined) forOf(iterable, IS_MAP, that[ADDER], that);\n return that;\n });\n C.prototype = proto;\n proto.constructor = C;\n }\n if (THROWS_ON_PRIMITIVES || BUGGY_ZERO) {\n fixMethod('delete');\n fixMethod('has');\n IS_MAP && fixMethod('get');\n }\n if (BUGGY_ZERO || HASNT_CHAINING) fixMethod(ADDER);\n // weak collections should not contains .clear method\n if (IS_WEAK && proto.clear) delete proto.clear;\n }\n\n setToStringTag(C, NAME);\n\n O[NAME] = C;\n $export($export.G + $export.W + $export.F * (C != Base), O);\n\n if (!IS_WEAK) common.setStrong(C, NAME, IS_MAP);\n\n return C;\n};\n","var global = require('./_global');\nvar hide = require('./_hide');\nvar uid = require('./_uid');\nvar TYPED = uid('typed_array');\nvar VIEW = uid('view');\nvar ABV = !!(global.ArrayBuffer && global.DataView);\nvar CONSTR = ABV;\nvar i = 0;\nvar l = 9;\nvar Typed;\n\nvar TypedArrayConstructors = (\n 'Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array'\n).split(',');\n\nwhile (i < l) {\n if (Typed = global[TypedArrayConstructors[i++]]) {\n hide(Typed.prototype, TYPED, true);\n hide(Typed.prototype, VIEW, true);\n } else CONSTR = false;\n}\n\nmodule.exports = {\n ABV: ABV,\n CONSTR: CONSTR,\n TYPED: TYPED,\n VIEW: VIEW\n};\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","var isObject = require('./_is-object');\nvar document = require('./_global').document;\n// typeof document.createElement is 'object' in old IE\nvar is = isObject(document) && isObject(document.createElement);\nmodule.exports = function (it) {\n return is ? document.createElement(it) : {};\n};\n","exports.f = require('./_wks');\n","var shared = require('./_shared')('keys');\nvar uid = require('./_uid');\nmodule.exports = function (key) {\n return shared[key] || (shared[key] = uid(key));\n};\n","// IE 8- don't enum bug keys\nmodule.exports = (\n 'constructor,hasOwnProperty,isPrototypeOf,propertyIsEnumerable,toLocaleString,toString,valueOf'\n).split(',');\n","var document = require('./_global').document;\nmodule.exports = document && document.documentElement;\n","// Works with __proto__ only. Old v8 can't work with null proto objects.\n/* eslint-disable no-proto */\nvar isObject = require('./_is-object');\nvar anObject = require('./_an-object');\nvar check = function (O, proto) {\n anObject(O);\n if (!isObject(proto) && proto !== null) throw TypeError(proto + \": can't set as prototype!\");\n};\nmodule.exports = {\n set: Object.setPrototypeOf || ('__proto__' in {} ? // eslint-disable-line\n function (test, buggy, set) {\n try {\n set = require('./_ctx')(Function.call, require('./_object-gopd').f(Object.prototype, '__proto__').set, 2);\n set(test, []);\n buggy = !(test instanceof Array);\n } catch (e) { buggy = true; }\n return function setPrototypeOf(O, proto) {\n check(O, proto);\n if (buggy) O.__proto__ = proto;\n else set(O, proto);\n return O;\n };\n }({}, false) : undefined),\n check: check\n};\n","module.exports = '\\x09\\x0A\\x0B\\x0C\\x0D\\x20\\xA0\\u1680\\u180E\\u2000\\u2001\\u2002\\u2003' +\n '\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200A\\u202F\\u205F\\u3000\\u2028\\u2029\\uFEFF';\n","var isObject = require('./_is-object');\nvar setPrototypeOf = require('./_set-proto').set;\nmodule.exports = function (that, target, C) {\n var S = target.constructor;\n var P;\n if (S !== C && typeof S == 'function' && (P = S.prototype) !== C.prototype && isObject(P) && setPrototypeOf) {\n setPrototypeOf(that, P);\n } return that;\n};\n","'use strict';\nvar toInteger = require('./_to-integer');\nvar defined = require('./_defined');\n\nmodule.exports = function repeat(count) {\n var str = String(defined(this));\n var res = '';\n var n = toInteger(count);\n if (n < 0 || n == Infinity) throw RangeError(\"Count can't be negative\");\n for (;n > 0; (n >>>= 1) && (str += str)) if (n & 1) res += str;\n return res;\n};\n","// 20.2.2.28 Math.sign(x)\nmodule.exports = Math.sign || function sign(x) {\n // eslint-disable-next-line no-self-compare\n return (x = +x) == 0 || x != x ? x : x < 0 ? -1 : 1;\n};\n","// 20.2.2.14 Math.expm1(x)\nvar $expm1 = Math.expm1;\nmodule.exports = (!$expm1\n // Old FF bug\n || $expm1(10) > 22025.465794806719 || $expm1(10) < 22025.4657948067165168\n // Tor Browser bug\n || $expm1(-2e-17) != -2e-17\n) ? function expm1(x) {\n return (x = +x) == 0 ? x : x > -1e-6 && x < 1e-6 ? x + x * x / 2 : Math.exp(x) - 1;\n} : $expm1;\n","var toInteger = require('./_to-integer');\nvar defined = require('./_defined');\n// true -> String#at\n// false -> String#codePointAt\nmodule.exports = function (TO_STRING) {\n return function (that, pos) {\n var s = String(defined(that));\n var i = toInteger(pos);\n var l = s.length;\n var a, b;\n if (i < 0 || i >= l) return TO_STRING ? '' : undefined;\n a = s.charCodeAt(i);\n return a < 0xd800 || a > 0xdbff || i + 1 === l || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\n ? TO_STRING ? s.charAt(i) : a\n : TO_STRING ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\n };\n};\n","'use strict';\nvar LIBRARY = require('./_library');\nvar $export = require('./_export');\nvar redefine = require('./_redefine');\nvar hide = require('./_hide');\nvar Iterators = require('./_iterators');\nvar $iterCreate = require('./_iter-create');\nvar setToStringTag = require('./_set-to-string-tag');\nvar getPrototypeOf = require('./_object-gpo');\nvar ITERATOR = require('./_wks')('iterator');\nvar BUGGY = !([].keys && 'next' in [].keys()); // Safari has buggy iterators w/o `next`\nvar FF_ITERATOR = '@@iterator';\nvar KEYS = 'keys';\nvar VALUES = 'values';\n\nvar returnThis = function () { return this; };\n\nmodule.exports = function (Base, NAME, Constructor, next, DEFAULT, IS_SET, FORCED) {\n $iterCreate(Constructor, NAME, next);\n var getMethod = function (kind) {\n if (!BUGGY && kind in proto) return proto[kind];\n switch (kind) {\n case KEYS: return function keys() { return new Constructor(this, kind); };\n case VALUES: return function values() { return new Constructor(this, kind); };\n } return function entries() { return new Constructor(this, kind); };\n };\n var TAG = NAME + ' Iterator';\n var DEF_VALUES = DEFAULT == VALUES;\n var VALUES_BUG = false;\n var proto = Base.prototype;\n var $native = proto[ITERATOR] || proto[FF_ITERATOR] || DEFAULT && proto[DEFAULT];\n var $default = $native || getMethod(DEFAULT);\n var $entries = DEFAULT ? !DEF_VALUES ? $default : getMethod('entries') : undefined;\n var $anyNative = NAME == 'Array' ? proto.entries || $native : $native;\n var methods, key, IteratorPrototype;\n // Fix native\n if ($anyNative) {\n IteratorPrototype = getPrototypeOf($anyNative.call(new Base()));\n if (IteratorPrototype !== Object.prototype && IteratorPrototype.next) {\n // Set @@toStringTag to native iterators\n setToStringTag(IteratorPrototype, TAG, true);\n // fix for some old engines\n if (!LIBRARY && typeof IteratorPrototype[ITERATOR] != 'function') hide(IteratorPrototype, ITERATOR, returnThis);\n }\n }\n // fix Array#{values, @@iterator}.name in V8 / FF\n if (DEF_VALUES && $native && $native.name !== VALUES) {\n VALUES_BUG = true;\n $default = function values() { return $native.call(this); };\n }\n // Define iterator\n if ((!LIBRARY || FORCED) && (BUGGY || VALUES_BUG || !proto[ITERATOR])) {\n hide(proto, ITERATOR, $default);\n }\n // Plug for library\n Iterators[NAME] = $default;\n Iterators[TAG] = returnThis;\n if (DEFAULT) {\n methods = {\n values: DEF_VALUES ? $default : getMethod(VALUES),\n keys: IS_SET ? $default : getMethod(KEYS),\n entries: $entries\n };\n if (FORCED) for (key in methods) {\n if (!(key in proto)) redefine(proto, key, methods[key]);\n } else $export($export.P + $export.F * (BUGGY || VALUES_BUG), NAME, methods);\n }\n return methods;\n};\n","// helper for String#{startsWith, endsWith, includes}\nvar isRegExp = require('./_is-regexp');\nvar defined = require('./_defined');\n\nmodule.exports = function (that, searchString, NAME) {\n if (isRegExp(searchString)) throw TypeError('String#' + NAME + \" doesn't accept regex!\");\n return String(defined(that));\n};\n","// 7.2.8 IsRegExp(argument)\nvar isObject = require('./_is-object');\nvar cof = require('./_cof');\nvar MATCH = require('./_wks')('match');\nmodule.exports = function (it) {\n var isRegExp;\n return isObject(it) && ((isRegExp = it[MATCH]) !== undefined ? !!isRegExp : cof(it) == 'RegExp');\n};\n","var MATCH = require('./_wks')('match');\nmodule.exports = function (KEY) {\n var re = /./;\n try {\n '/./'[KEY](re);\n } catch (e) {\n try {\n re[MATCH] = false;\n return !'/./'[KEY](re);\n } catch (f) { /* empty */ }\n } return true;\n};\n","// check on default Array iterator\nvar Iterators = require('./_iterators');\nvar ITERATOR = require('./_wks')('iterator');\nvar ArrayProto = Array.prototype;\n\nmodule.exports = function (it) {\n return it !== undefined && (Iterators.Array === it || ArrayProto[ITERATOR] === it);\n};\n","'use strict';\nvar $defineProperty = require('./_object-dp');\nvar createDesc = require('./_property-desc');\n\nmodule.exports = function (object, index, value) {\n if (index in object) $defineProperty.f(object, index, createDesc(0, value));\n else object[index] = value;\n};\n","var classof = require('./_classof');\nvar ITERATOR = require('./_wks')('iterator');\nvar Iterators = require('./_iterators');\nmodule.exports = require('./_core').getIteratorMethod = function (it) {\n if (it != undefined) return it[ITERATOR]\n || it['@@iterator']\n || Iterators[classof(it)];\n};\n","// 22.1.3.6 Array.prototype.fill(value, start = 0, end = this.length)\n'use strict';\nvar toObject = require('./_to-object');\nvar toAbsoluteIndex = require('./_to-absolute-index');\nvar toLength = require('./_to-length');\nmodule.exports = function fill(value /* , start = 0, end = @length */) {\n var O = toObject(this);\n var length = toLength(O.length);\n var aLen = arguments.length;\n var index = toAbsoluteIndex(aLen > 1 ? arguments[1] : undefined, length);\n var end = aLen > 2 ? arguments[2] : undefined;\n var endPos = end === undefined ? length : toAbsoluteIndex(end, length);\n while (endPos > index) O[index++] = value;\n return O;\n};\n","'use strict';\nvar addToUnscopables = require('./_add-to-unscopables');\nvar step = require('./_iter-step');\nvar Iterators = require('./_iterators');\nvar toIObject = require('./_to-iobject');\n\n// 22.1.3.4 Array.prototype.entries()\n// 22.1.3.13 Array.prototype.keys()\n// 22.1.3.29 Array.prototype.values()\n// 22.1.3.30 Array.prototype[@@iterator]()\nmodule.exports = require('./_iter-define')(Array, 'Array', function (iterated, kind) {\n this._t = toIObject(iterated); // target\n this._i = 0; // next index\n this._k = kind; // kind\n// 22.1.5.2.1 %ArrayIteratorPrototype%.next()\n}, function () {\n var O = this._t;\n var kind = this._k;\n var index = this._i++;\n if (!O || index >= O.length) {\n this._t = undefined;\n return step(1);\n }\n if (kind == 'keys') return step(0, index);\n if (kind == 'values') return step(0, O[index]);\n return step(0, [index, O[index]]);\n}, 'values');\n\n// argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\nIterators.Arguments = Iterators.Array;\n\naddToUnscopables('keys');\naddToUnscopables('values');\naddToUnscopables('entries');\n","'use strict';\n\nvar regexpFlags = require('./_flags');\n\nvar nativeExec = RegExp.prototype.exec;\n// This always refers to the native implementation, because the\n// String#replace polyfill uses ./fix-regexp-well-known-symbol-logic.js,\n// which loads this file before patching the method.\nvar nativeReplace = String.prototype.replace;\n\nvar patchedExec = nativeExec;\n\nvar LAST_INDEX = 'lastIndex';\n\nvar UPDATES_LAST_INDEX_WRONG = (function () {\n var re1 = /a/,\n re2 = /b*/g;\n nativeExec.call(re1, 'a');\n nativeExec.call(re2, 'a');\n return re1[LAST_INDEX] !== 0 || re2[LAST_INDEX] !== 0;\n})();\n\n// nonparticipating capturing group, copied from es5-shim's String#split patch.\nvar NPCG_INCLUDED = /()??/.exec('')[1] !== undefined;\n\nvar PATCH = UPDATES_LAST_INDEX_WRONG || NPCG_INCLUDED;\n\nif (PATCH) {\n patchedExec = function exec(str) {\n var re = this;\n var lastIndex, reCopy, match, i;\n\n if (NPCG_INCLUDED) {\n reCopy = new RegExp('^' + re.source + '$(?!\\\\s)', regexpFlags.call(re));\n }\n if (UPDATES_LAST_INDEX_WRONG) lastIndex = re[LAST_INDEX];\n\n match = nativeExec.call(re, str);\n\n if (UPDATES_LAST_INDEX_WRONG && match) {\n re[LAST_INDEX] = re.global ? match.index + match[0].length : lastIndex;\n }\n if (NPCG_INCLUDED && match && match.length > 1) {\n // Fix browsers whose `exec` methods don't consistently return `undefined`\n // for NPCG, like IE8. NOTE: This doesn' work for /(.?)?/\n // eslint-disable-next-line no-loop-func\n nativeReplace.call(match[0], reCopy, function () {\n for (i = 1; i < arguments.length - 2; i++) {\n if (arguments[i] === undefined) match[i] = undefined;\n }\n });\n }\n\n return match;\n };\n}\n\nmodule.exports = patchedExec;\n","'use strict';\nvar at = require('./_string-at')(true);\n\n // `AdvanceStringIndex` abstract operation\n// https://tc39.github.io/ecma262/#sec-advancestringindex\nmodule.exports = function (S, index, unicode) {\n return index + (unicode ? at(S, index).length : 1);\n};\n","var ctx = require('./_ctx');\nvar invoke = require('./_invoke');\nvar html = require('./_html');\nvar cel = require('./_dom-create');\nvar global = require('./_global');\nvar process = global.process;\nvar setTask = global.setImmediate;\nvar clearTask = global.clearImmediate;\nvar MessageChannel = global.MessageChannel;\nvar Dispatch = global.Dispatch;\nvar counter = 0;\nvar queue = {};\nvar ONREADYSTATECHANGE = 'onreadystatechange';\nvar defer, channel, port;\nvar run = function () {\n var id = +this;\n // eslint-disable-next-line no-prototype-builtins\n if (queue.hasOwnProperty(id)) {\n var fn = queue[id];\n delete queue[id];\n fn();\n }\n};\nvar listener = function (event) {\n run.call(event.data);\n};\n// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\nif (!setTask || !clearTask) {\n setTask = function setImmediate(fn) {\n var args = [];\n var i = 1;\n while (arguments.length > i) args.push(arguments[i++]);\n queue[++counter] = function () {\n // eslint-disable-next-line no-new-func\n invoke(typeof fn == 'function' ? fn : Function(fn), args);\n };\n defer(counter);\n return counter;\n };\n clearTask = function clearImmediate(id) {\n delete queue[id];\n };\n // Node.js 0.8-\n if (require('./_cof')(process) == 'process') {\n defer = function (id) {\n process.nextTick(ctx(run, id, 1));\n };\n // Sphere (JS game engine) Dispatch API\n } else if (Dispatch && Dispatch.now) {\n defer = function (id) {\n Dispatch.now(ctx(run, id, 1));\n };\n // Browsers with MessageChannel, includes WebWorkers\n } else if (MessageChannel) {\n channel = new MessageChannel();\n port = channel.port2;\n channel.port1.onmessage = listener;\n defer = ctx(port.postMessage, port, 1);\n // Browsers with postMessage, skip WebWorkers\n // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n } else if (global.addEventListener && typeof postMessage == 'function' && !global.importScripts) {\n defer = function (id) {\n global.postMessage(id + '', '*');\n };\n global.addEventListener('message', listener, false);\n // IE8-\n } else if (ONREADYSTATECHANGE in cel('script')) {\n defer = function (id) {\n html.appendChild(cel('script'))[ONREADYSTATECHANGE] = function () {\n html.removeChild(this);\n run.call(id);\n };\n };\n // Rest old browsers\n } else {\n defer = function (id) {\n setTimeout(ctx(run, id, 1), 0);\n };\n }\n}\nmodule.exports = {\n set: setTask,\n clear: clearTask\n};\n","'use strict';\nvar global = require('./_global');\nvar DESCRIPTORS = require('./_descriptors');\nvar LIBRARY = require('./_library');\nvar $typed = require('./_typed');\nvar hide = require('./_hide');\nvar redefineAll = require('./_redefine-all');\nvar fails = require('./_fails');\nvar anInstance = require('./_an-instance');\nvar toInteger = require('./_to-integer');\nvar toLength = require('./_to-length');\nvar toIndex = require('./_to-index');\nvar gOPN = require('./_object-gopn').f;\nvar dP = require('./_object-dp').f;\nvar arrayFill = require('./_array-fill');\nvar setToStringTag = require('./_set-to-string-tag');\nvar ARRAY_BUFFER = 'ArrayBuffer';\nvar DATA_VIEW = 'DataView';\nvar PROTOTYPE = 'prototype';\nvar WRONG_LENGTH = 'Wrong length!';\nvar WRONG_INDEX = 'Wrong index!';\nvar $ArrayBuffer = global[ARRAY_BUFFER];\nvar $DataView = global[DATA_VIEW];\nvar Math = global.Math;\nvar RangeError = global.RangeError;\n// eslint-disable-next-line no-shadow-restricted-names\nvar Infinity = global.Infinity;\nvar BaseBuffer = $ArrayBuffer;\nvar abs = Math.abs;\nvar pow = Math.pow;\nvar floor = Math.floor;\nvar log = Math.log;\nvar LN2 = Math.LN2;\nvar BUFFER = 'buffer';\nvar BYTE_LENGTH = 'byteLength';\nvar BYTE_OFFSET = 'byteOffset';\nvar $BUFFER = DESCRIPTORS ? '_b' : BUFFER;\nvar $LENGTH = DESCRIPTORS ? '_l' : BYTE_LENGTH;\nvar $OFFSET = DESCRIPTORS ? '_o' : BYTE_OFFSET;\n\n// IEEE754 conversions based on https://github.com/feross/ieee754\nfunction packIEEE754(value, mLen, nBytes) {\n var buffer = new Array(nBytes);\n var eLen = nBytes * 8 - mLen - 1;\n var eMax = (1 << eLen) - 1;\n var eBias = eMax >> 1;\n var rt = mLen === 23 ? pow(2, -24) - pow(2, -77) : 0;\n var i = 0;\n var s = value < 0 || value === 0 && 1 / value < 0 ? 1 : 0;\n var e, m, c;\n value = abs(value);\n // eslint-disable-next-line no-self-compare\n if (value != value || value === Infinity) {\n // eslint-disable-next-line no-self-compare\n m = value != value ? 1 : 0;\n e = eMax;\n } else {\n e = floor(log(value) / LN2);\n if (value * (c = pow(2, -e)) < 1) {\n e--;\n c *= 2;\n }\n if (e + eBias >= 1) {\n value += rt / c;\n } else {\n value += rt * pow(2, 1 - eBias);\n }\n if (value * c >= 2) {\n e++;\n c /= 2;\n }\n if (e + eBias >= eMax) {\n m = 0;\n e = eMax;\n } else if (e + eBias >= 1) {\n m = (value * c - 1) * pow(2, mLen);\n e = e + eBias;\n } else {\n m = value * pow(2, eBias - 1) * pow(2, mLen);\n e = 0;\n }\n }\n for (; mLen >= 8; buffer[i++] = m & 255, m /= 256, mLen -= 8);\n e = e << mLen | m;\n eLen += mLen;\n for (; eLen > 0; buffer[i++] = e & 255, e /= 256, eLen -= 8);\n buffer[--i] |= s * 128;\n return buffer;\n}\nfunction unpackIEEE754(buffer, mLen, nBytes) {\n var eLen = nBytes * 8 - mLen - 1;\n var eMax = (1 << eLen) - 1;\n var eBias = eMax >> 1;\n var nBits = eLen - 7;\n var i = nBytes - 1;\n var s = buffer[i--];\n var e = s & 127;\n var m;\n s >>= 7;\n for (; nBits > 0; e = e * 256 + buffer[i], i--, nBits -= 8);\n m = e & (1 << -nBits) - 1;\n e >>= -nBits;\n nBits += mLen;\n for (; nBits > 0; m = m * 256 + buffer[i], i--, nBits -= 8);\n if (e === 0) {\n e = 1 - eBias;\n } else if (e === eMax) {\n return m ? NaN : s ? -Infinity : Infinity;\n } else {\n m = m + pow(2, mLen);\n e = e - eBias;\n } return (s ? -1 : 1) * m * pow(2, e - mLen);\n}\n\nfunction unpackI32(bytes) {\n return bytes[3] << 24 | bytes[2] << 16 | bytes[1] << 8 | bytes[0];\n}\nfunction packI8(it) {\n return [it & 0xff];\n}\nfunction packI16(it) {\n return [it & 0xff, it >> 8 & 0xff];\n}\nfunction packI32(it) {\n return [it & 0xff, it >> 8 & 0xff, it >> 16 & 0xff, it >> 24 & 0xff];\n}\nfunction packF64(it) {\n return packIEEE754(it, 52, 8);\n}\nfunction packF32(it) {\n return packIEEE754(it, 23, 4);\n}\n\nfunction addGetter(C, key, internal) {\n dP(C[PROTOTYPE], key, { get: function () { return this[internal]; } });\n}\n\nfunction get(view, bytes, index, isLittleEndian) {\n var numIndex = +index;\n var intIndex = toIndex(numIndex);\n if (intIndex + bytes > view[$LENGTH]) throw RangeError(WRONG_INDEX);\n var store = view[$BUFFER]._b;\n var start = intIndex + view[$OFFSET];\n var pack = store.slice(start, start + bytes);\n return isLittleEndian ? pack : pack.reverse();\n}\nfunction set(view, bytes, index, conversion, value, isLittleEndian) {\n var numIndex = +index;\n var intIndex = toIndex(numIndex);\n if (intIndex + bytes > view[$LENGTH]) throw RangeError(WRONG_INDEX);\n var store = view[$BUFFER]._b;\n var start = intIndex + view[$OFFSET];\n var pack = conversion(+value);\n for (var i = 0; i < bytes; i++) store[start + i] = pack[isLittleEndian ? i : bytes - i - 1];\n}\n\nif (!$typed.ABV) {\n $ArrayBuffer = function ArrayBuffer(length) {\n anInstance(this, $ArrayBuffer, ARRAY_BUFFER);\n var byteLength = toIndex(length);\n this._b = arrayFill.call(new Array(byteLength), 0);\n this[$LENGTH] = byteLength;\n };\n\n $DataView = function DataView(buffer, byteOffset, byteLength) {\n anInstance(this, $DataView, DATA_VIEW);\n anInstance(buffer, $ArrayBuffer, DATA_VIEW);\n var bufferLength = buffer[$LENGTH];\n var offset = toInteger(byteOffset);\n if (offset < 0 || offset > bufferLength) throw RangeError('Wrong offset!');\n byteLength = byteLength === undefined ? bufferLength - offset : toLength(byteLength);\n if (offset + byteLength > bufferLength) throw RangeError(WRONG_LENGTH);\n this[$BUFFER] = buffer;\n this[$OFFSET] = offset;\n this[$LENGTH] = byteLength;\n };\n\n if (DESCRIPTORS) {\n addGetter($ArrayBuffer, BYTE_LENGTH, '_l');\n addGetter($DataView, BUFFER, '_b');\n addGetter($DataView, BYTE_LENGTH, '_l');\n addGetter($DataView, BYTE_OFFSET, '_o');\n }\n\n redefineAll($DataView[PROTOTYPE], {\n getInt8: function getInt8(byteOffset) {\n return get(this, 1, byteOffset)[0] << 24 >> 24;\n },\n getUint8: function getUint8(byteOffset) {\n return get(this, 1, byteOffset)[0];\n },\n getInt16: function getInt16(byteOffset /* , littleEndian */) {\n var bytes = get(this, 2, byteOffset, arguments[1]);\n return (bytes[1] << 8 | bytes[0]) << 16 >> 16;\n },\n getUint16: function getUint16(byteOffset /* , littleEndian */) {\n var bytes = get(this, 2, byteOffset, arguments[1]);\n return bytes[1] << 8 | bytes[0];\n },\n getInt32: function getInt32(byteOffset /* , littleEndian */) {\n return unpackI32(get(this, 4, byteOffset, arguments[1]));\n },\n getUint32: function getUint32(byteOffset /* , littleEndian */) {\n return unpackI32(get(this, 4, byteOffset, arguments[1])) >>> 0;\n },\n getFloat32: function getFloat32(byteOffset /* , littleEndian */) {\n return unpackIEEE754(get(this, 4, byteOffset, arguments[1]), 23, 4);\n },\n getFloat64: function getFloat64(byteOffset /* , littleEndian */) {\n return unpackIEEE754(get(this, 8, byteOffset, arguments[1]), 52, 8);\n },\n setInt8: function setInt8(byteOffset, value) {\n set(this, 1, byteOffset, packI8, value);\n },\n setUint8: function setUint8(byteOffset, value) {\n set(this, 1, byteOffset, packI8, value);\n },\n setInt16: function setInt16(byteOffset, value /* , littleEndian */) {\n set(this, 2, byteOffset, packI16, value, arguments[2]);\n },\n setUint16: function setUint16(byteOffset, value /* , littleEndian */) {\n set(this, 2, byteOffset, packI16, value, arguments[2]);\n },\n setInt32: function setInt32(byteOffset, value /* , littleEndian */) {\n set(this, 4, byteOffset, packI32, value, arguments[2]);\n },\n setUint32: function setUint32(byteOffset, value /* , littleEndian */) {\n set(this, 4, byteOffset, packI32, value, arguments[2]);\n },\n setFloat32: function setFloat32(byteOffset, value /* , littleEndian */) {\n set(this, 4, byteOffset, packF32, value, arguments[2]);\n },\n setFloat64: function setFloat64(byteOffset, value /* , littleEndian */) {\n set(this, 8, byteOffset, packF64, value, arguments[2]);\n }\n });\n} else {\n if (!fails(function () {\n $ArrayBuffer(1);\n }) || !fails(function () {\n new $ArrayBuffer(-1); // eslint-disable-line no-new\n }) || fails(function () {\n new $ArrayBuffer(); // eslint-disable-line no-new\n new $ArrayBuffer(1.5); // eslint-disable-line no-new\n new $ArrayBuffer(NaN); // eslint-disable-line no-new\n return $ArrayBuffer.name != ARRAY_BUFFER;\n })) {\n $ArrayBuffer = function ArrayBuffer(length) {\n anInstance(this, $ArrayBuffer);\n return new BaseBuffer(toIndex(length));\n };\n var ArrayBufferProto = $ArrayBuffer[PROTOTYPE] = BaseBuffer[PROTOTYPE];\n for (var keys = gOPN(BaseBuffer), j = 0, key; keys.length > j;) {\n if (!((key = keys[j++]) in $ArrayBuffer)) hide($ArrayBuffer, key, BaseBuffer[key]);\n }\n if (!LIBRARY) ArrayBufferProto.constructor = $ArrayBuffer;\n }\n // iOS Safari 7.x bug\n var view = new $DataView(new $ArrayBuffer(2));\n var $setInt8 = $DataView[PROTOTYPE].setInt8;\n view.setInt8(0, 2147483648);\n view.setInt8(1, 2147483649);\n if (view.getInt8(0) || !view.getInt8(1)) redefineAll($DataView[PROTOTYPE], {\n setInt8: function setInt8(byteOffset, value) {\n $setInt8.call(this, byteOffset, value << 24 >> 24);\n },\n setUint8: function setUint8(byteOffset, value) {\n $setInt8.call(this, byteOffset, value << 24 >> 24);\n }\n }, true);\n}\nsetToStringTag($ArrayBuffer, ARRAY_BUFFER);\nsetToStringTag($DataView, DATA_VIEW);\nhide($DataView[PROTOTYPE], $typed.VIEW, true);\nexports[ARRAY_BUFFER] = $ArrayBuffer;\nexports[DATA_VIEW] = $DataView;\n","// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar global = module.exports = typeof window != 'undefined' && window.Math == Math\n ? window : typeof self != 'undefined' && self.Math == Math ? self\n // eslint-disable-next-line no-new-func\n : Function('return this')();\nif (typeof __g == 'number') __g = global; // eslint-disable-line no-undef\n","module.exports = function (it) {\n return typeof it === 'object' ? it !== null : typeof it === 'function';\n};\n","// Thank's IE8 for his funny defineProperty\nmodule.exports = !require('./_fails')(function () {\n return Object.defineProperty({}, 'a', { get: function () { return 7; } }).a != 7;\n});\n","/**\r\n * Created by richie on 15/7/8.\r\n */\r\n/**\r\n * 初始化BI对象\r\n */\r\n_global = undefined;\r\nif (typeof window !== \"undefined\") {\r\n _global = window;\r\n} else if (typeof global !== \"undefined\") {\r\n _global = global;\r\n} else if (typeof self !== \"undefined\") {\r\n _global = self;\r\n} else {\r\n _global = this;\r\n}\r\nif (_global.BI == null) {\r\n _global.BI = {prepares: []};\r\n}\r\nif(_global.BI.prepares == null) {\r\n _global.BI.prepares = [];\r\n}","require(\"!!E:\\\\Jenkins\\\\workspace\\\\auto-pack\\\\fineui\\\\node_modules\\\\script-loader\\\\addScript.js\")(require(\"!!E:\\\\Jenkins\\\\workspace\\\\auto-pack\\\\fineui\\\\node_modules\\\\raw-loader\\\\index.js!E:\\\\Jenkins\\\\workspace\\\\auto-pack\\\\fineui\\\\src\\\\core\\\\lodash.js\"))","/*\n\tMIT License http://www.opensource.org/licenses/mit-license.php\n\tAuthor Tobias Koppers @sokra\n*/\nmodule.exports = function(src) {\n\tfunction log(error) {\n\t\t(typeof console !== \"undefined\")\n\t\t&& (console.error || console.log)(\"[Script Loader]\", error);\n\t}\n\n\t// Check for IE =< 8\n\tfunction isIE() {\n\t\treturn typeof attachEvent !== \"undefined\" && typeof addEventListener === \"undefined\";\n\t}\n\n\ttry {\n\t\tif (typeof execScript !== \"undefined\" && isIE()) {\n\t\t\texecScript(src);\n\t\t} else if (typeof eval !== \"undefined\") {\n\t\t\teval.call(null, src);\n\t\t} else {\n\t\t\tlog(\"EvalError: No eval function available\");\n\t\t}\n\t} catch (error) {\n\t\tlog(error);\n\t}\n}\n","module.exports = \"/**\\r\\n * @license\\r\\n * Lodash (Custom Build) \\r\\n * Build: `lodash core plus=\\\"debounce,throttle,get,set,findIndex,findLastIndex,findKey,findLastKey,isArrayLike,invert,invertBy,uniq,uniqBy,omit,omitBy,zip,unzip,rest,range,random,reject,intersection,drop,countBy,union,zipObject,initial,cloneDeep,clamp,isPlainObject,take,takeRight,without,difference,defaultsDeep,trim,merge,groupBy,uniqBy,before,after\\\"`\\r\\n * Copyright JS Foundation and other contributors \\r\\n * Released under MIT license \\r\\n * Based on Underscore.js 1.8.3 \\r\\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\\r\\n */\\r\\n;(function() {\\r\\n\\r\\n /** Used as a safe reference for `undefined` in pre-ES5 environments. */\\r\\n var undefined;\\r\\n\\r\\n /** Used as the semantic version number. */\\r\\n var VERSION = '4.17.5';\\r\\n\\r\\n /** Used as the size to enable large array optimizations. */\\r\\n var LARGE_ARRAY_SIZE = 200;\\r\\n\\r\\n /** Error message constants. */\\r\\n var FUNC_ERROR_TEXT = 'Expected a function';\\r\\n\\r\\n /** Used to stand-in for `undefined` hash values. */\\r\\n var HASH_UNDEFINED = '__lodash_hash_undefined__';\\r\\n\\r\\n /** Used as the maximum memoize cache size. */\\r\\n var MAX_MEMOIZE_SIZE = 500;\\r\\n\\r\\n /** Used as the internal argument placeholder. */\\r\\n var PLACEHOLDER = '__lodash_placeholder__';\\r\\n\\r\\n /** Used to compose bitmasks for cloning. */\\r\\n var CLONE_DEEP_FLAG = 1,\\r\\n CLONE_FLAT_FLAG = 2,\\r\\n CLONE_SYMBOLS_FLAG = 4;\\r\\n\\r\\n /** Used to compose bitmasks for value comparisons. */\\r\\n var COMPARE_PARTIAL_FLAG = 1,\\r\\n COMPARE_UNORDERED_FLAG = 2;\\r\\n\\r\\n /** Used to compose bitmasks for function metadata. */\\r\\n var WRAP_BIND_FLAG = 1,\\r\\n WRAP_BIND_KEY_FLAG = 2,\\r\\n WRAP_CURRY_BOUND_FLAG = 4,\\r\\n WRAP_CURRY_FLAG = 8,\\r\\n WRAP_CURRY_RIGHT_FLAG = 16,\\r\\n WRAP_PARTIAL_FLAG = 32,\\r\\n WRAP_PARTIAL_RIGHT_FLAG = 64,\\r\\n WRAP_ARY_FLAG = 128,\\r\\n WRAP_REARG_FLAG = 256,\\r\\n WRAP_FLIP_FLAG = 512;\\r\\n\\r\\n /** Used to detect hot functions by number of calls within a span of milliseconds. */\\r\\n var HOT_COUNT = 800,\\r\\n HOT_SPAN = 16;\\r\\n\\r\\n /** Used to indicate the type of lazy iteratees. */\\r\\n var LAZY_FILTER_FLAG = 1,\\r\\n LAZY_MAP_FLAG = 2,\\r\\n LAZY_WHILE_FLAG = 3;\\r\\n\\r\\n /** Used as references for various `Number` constants. */\\r\\n var INFINITY = 1 / 0,\\r\\n MAX_SAFE_INTEGER = 9007199254740991,\\r\\n MAX_INTEGER = 1.7976931348623157e+308,\\r\\n NAN = 0 / 0;\\r\\n\\r\\n /** Used as references for the maximum length and index of an array. */\\r\\n var MAX_ARRAY_LENGTH = 4294967295;\\r\\n\\r\\n /** Used to associate wrap methods with their bit flags. */\\r\\n var wrapFlags = [\\r\\n ['ary', WRAP_ARY_FLAG],\\r\\n ['bind', WRAP_BIND_FLAG],\\r\\n ['bindKey', WRAP_BIND_KEY_FLAG],\\r\\n ['curry', WRAP_CURRY_FLAG],\\r\\n ['curryRight', WRAP_CURRY_RIGHT_FLAG],\\r\\n ['flip', WRAP_FLIP_FLAG],\\r\\n ['partial', WRAP_PARTIAL_FLAG],\\r\\n ['partialRight', WRAP_PARTIAL_RIGHT_FLAG],\\r\\n ['rearg', WRAP_REARG_FLAG]\\r\\n ];\\r\\n\\r\\n /** `Object#toString` result references. */\\r\\n var argsTag = '[object Arguments]',\\r\\n arrayTag = '[object Array]',\\r\\n asyncTag = '[object AsyncFunction]',\\r\\n boolTag = '[object Boolean]',\\r\\n dateTag = '[object Date]',\\r\\n errorTag = '[object Error]',\\r\\n funcTag = '[object Function]',\\r\\n genTag = '[object GeneratorFunction]',\\r\\n mapTag = '[object Map]',\\r\\n numberTag = '[object Number]',\\r\\n nullTag = '[object Null]',\\r\\n objectTag = '[object Object]',\\r\\n promiseTag = '[object Promise]',\\r\\n proxyTag = '[object Proxy]',\\r\\n regexpTag = '[object RegExp]',\\r\\n setTag = '[object Set]',\\r\\n stringTag = '[object String]',\\r\\n symbolTag = '[object Symbol]',\\r\\n undefinedTag = '[object Undefined]',\\r\\n weakMapTag = '[object WeakMap]';\\r\\n\\r\\n var arrayBufferTag = '[object ArrayBuffer]',\\r\\n dataViewTag = '[object DataView]',\\r\\n float32Tag = '[object Float32Array]',\\r\\n float64Tag = '[object Float64Array]',\\r\\n int8Tag = '[object Int8Array]',\\r\\n int16Tag = '[object Int16Array]',\\r\\n int32Tag = '[object Int32Array]',\\r\\n uint8Tag = '[object Uint8Array]',\\r\\n uint8ClampedTag = '[object Uint8ClampedArray]',\\r\\n uint16Tag = '[object Uint16Array]',\\r\\n uint32Tag = '[object Uint32Array]';\\r\\n\\r\\n /** Used to match HTML entities and HTML characters. */\\r\\n var reUnescapedHtml = /[&<>\\\"']/g,\\r\\n reHasUnescapedHtml = RegExp(reUnescapedHtml.source);\\r\\n\\r\\n /** Used to match property names within property paths. */\\r\\n var reIsDeepProp = /\\\\.|\\\\[(?:[^[\\\\]]*|([\\\"'])(?:(?!\\\\1)[^\\\\\\\\]|\\\\\\\\.)*?\\\\1)\\\\]/,\\r\\n reIsPlainProp = /^\\\\w*$/,\\r\\n rePropName = /[^.[\\\\]]+|\\\\[(?:(-?\\\\d+(?:\\\\.\\\\d+)?)|([\\\"'])((?:(?!\\\\2)[^\\\\\\\\]|\\\\\\\\.)*?)\\\\2)\\\\]|(?=(?:\\\\.|\\\\[\\\\])(?:\\\\.|\\\\[\\\\]|$))/g;\\r\\n\\r\\n /**\\r\\n * Used to match `RegExp`\\r\\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\\r\\n */\\r\\n var reRegExpChar = /[\\\\\\\\^$.*+?()[\\\\]{}|]/g;\\r\\n\\r\\n /** Used to match leading and trailing whitespace. */\\r\\n var reTrim = /^\\\\s+|\\\\s+$/g;\\r\\n\\r\\n /** Used to match wrap detail comments. */\\r\\n var reWrapComment = /\\\\{(?:\\\\n\\\\/\\\\* \\\\[wrapped with .+\\\\] \\\\*\\\\/)?\\\\n?/,\\r\\n reWrapDetails = /\\\\{\\\\n\\\\/\\\\* \\\\[wrapped with (.+)\\\\] \\\\*/,\\r\\n reSplitDetails = /,? & /;\\r\\n\\r\\n /** Used to match backslashes in property paths. */\\r\\n var reEscapeChar = /\\\\\\\\(\\\\\\\\)?/g;\\r\\n\\r\\n /** Used to match `RegExp` flags from their coerced string values. */\\r\\n var reFlags = /\\\\w*$/;\\r\\n\\r\\n /** Used to detect bad signed hexadecimal string values. */\\r\\n var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\\r\\n\\r\\n /** Used to detect binary string values. */\\r\\n var reIsBinary = /^0b[01]+$/i;\\r\\n\\r\\n /** Used to detect host constructors (Safari). */\\r\\n var reIsHostCtor = /^\\\\[object .+?Constructor\\\\]$/;\\r\\n\\r\\n /** Used to detect octal string values. */\\r\\n var reIsOctal = /^0o[0-7]+$/i;\\r\\n\\r\\n /** Used to detect unsigned integer values. */\\r\\n var reIsUint = /^(?:0|[1-9]\\\\d*)$/;\\r\\n\\r\\n /** Used to compose unicode character classes. */\\r\\n var rsAstralRange = '\\\\\\\\ud800-\\\\\\\\udfff',\\r\\n rsComboMarksRange = '\\\\\\\\u0300-\\\\\\\\u036f',\\r\\n reComboHalfMarksRange = '\\\\\\\\ufe20-\\\\\\\\ufe2f',\\r\\n rsComboSymbolsRange = '\\\\\\\\u20d0-\\\\\\\\u20ff',\\r\\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\\r\\n rsVarRange = '\\\\\\\\ufe0e\\\\\\\\ufe0f';\\r\\n\\r\\n /** Used to compose unicode capture groups. */\\r\\n var rsAstral = '[' + rsAstralRange + ']',\\r\\n rsCombo = '[' + rsComboRange + ']',\\r\\n rsFitz = '\\\\\\\\ud83c[\\\\\\\\udffb-\\\\\\\\udfff]',\\r\\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\\r\\n rsNonAstral = '[^' + rsAstralRange + ']',\\r\\n rsRegional = '(?:\\\\\\\\ud83c[\\\\\\\\udde6-\\\\\\\\uddff]){2}',\\r\\n rsSurrPair = '[\\\\\\\\ud800-\\\\\\\\udbff][\\\\\\\\udc00-\\\\\\\\udfff]',\\r\\n rsZWJ = '\\\\\\\\u200d';\\r\\n\\r\\n /** Used to compose unicode regexes. */\\r\\n var reOptMod = rsModifier + '?',\\r\\n rsOptVar = '[' + rsVarRange + ']?',\\r\\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\\r\\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\\r\\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\\r\\n\\r\\n /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\\r\\n var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\\r\\n\\r\\n /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\\r\\n var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\\r\\n\\r\\n /** Used to identify `toStringTag` values of typed arrays. */\\r\\n var typedArrayTags = {};\\r\\n typedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\\r\\n typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\\r\\n typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\\r\\n typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\\r\\n typedArrayTags[uint32Tag] = true;\\r\\n typedArrayTags[argsTag] = typedArrayTags[arrayTag] =\\r\\n typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\\r\\n typedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\\r\\n typedArrayTags[errorTag] = typedArrayTags[funcTag] =\\r\\n typedArrayTags[mapTag] = typedArrayTags[numberTag] =\\r\\n typedArrayTags[objectTag] = typedArrayTags[regexpTag] =\\r\\n typedArrayTags[setTag] = typedArrayTags[stringTag] =\\r\\n typedArrayTags[weakMapTag] = false;\\r\\n\\r\\n /** Used to identify `toStringTag` values supported by `_.clone`. */\\r\\n var cloneableTags = {};\\r\\n cloneableTags[argsTag] = cloneableTags[arrayTag] =\\r\\n cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\\r\\n cloneableTags[boolTag] = cloneableTags[dateTag] =\\r\\n cloneableTags[float32Tag] = cloneableTags[float64Tag] =\\r\\n cloneableTags[int8Tag] = cloneableTags[int16Tag] =\\r\\n cloneableTags[int32Tag] = cloneableTags[mapTag] =\\r\\n cloneableTags[numberTag] = cloneableTags[objectTag] =\\r\\n cloneableTags[regexpTag] = cloneableTags[setTag] =\\r\\n cloneableTags[stringTag] = cloneableTags[symbolTag] =\\r\\n cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\\r\\n cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\\r\\n cloneableTags[errorTag] = cloneableTags[funcTag] =\\r\\n cloneableTags[weakMapTag] = false;\\r\\n\\r\\n /** Used to map characters to HTML entities. */\\r\\n var htmlEscapes = {\\r\\n '&': '&',\\r\\n '<': '<',\\r\\n '>': '>',\\r\\n '\\\"': '"',\\r\\n \\\"'\\\": '''\\r\\n };\\r\\n\\r\\n /** Built-in method references without a dependency on `root`. */\\r\\n var freeParseFloat = parseFloat,\\r\\n freeParseInt = parseInt;\\r\\n\\r\\n /** Detect free variable `global` from Node.js. */\\r\\n var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\\r\\n\\r\\n /** Detect free variable `self`. */\\r\\n var freeSelf = typeof self == 'object' && self && self.Object === Object && self;\\r\\n\\r\\n /** Used as a reference to the global object. */\\r\\n var root = freeGlobal || freeSelf || Function('return this')();\\r\\n\\r\\n /** Detect free variable `exports`. */\\r\\n var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\\r\\n\\r\\n /** Detect free variable `module`. */\\r\\n var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\\r\\n\\r\\n /** Detect the popular CommonJS extension `module.exports`. */\\r\\n var moduleExports = freeModule && freeModule.exports === freeExports;\\r\\n\\r\\n /** Detect free variable `process` from Node.js. */\\r\\n var freeProcess = moduleExports && freeGlobal.process;\\r\\n\\r\\n /** Used to access faster Node.js helpers. */\\r\\n var nodeUtil = (function() {\\r\\n try {\\r\\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\\r\\n } catch (e) {}\\r\\n }());\\r\\n\\r\\n /* Node.js helper references. */\\r\\n var nodeIsDate = nodeUtil && nodeUtil.isDate,\\r\\n nodeIsMap = nodeUtil && nodeUtil.isMap,\\r\\n nodeIsRegExp = nodeUtil && nodeUtil.isRegExp,\\r\\n nodeIsSet = nodeUtil && nodeUtil.isSet,\\r\\n nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\\r\\n\\r\\n /*--------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * A faster alternative to `Function#apply`, this function invokes `func`\\r\\n * with the `this` binding of `thisArg` and the arguments of `args`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to invoke.\\r\\n * @param {*} thisArg The `this` binding of `func`.\\r\\n * @param {Array} args The arguments to invoke `func` with.\\r\\n * @returns {*} Returns the result of `func`.\\r\\n */\\r\\n function apply(func, thisArg, args) {\\r\\n switch (args.length) {\\r\\n case 0: return func.call(thisArg);\\r\\n case 1: return func.call(thisArg, args[0]);\\r\\n case 2: return func.call(thisArg, args[0], args[1]);\\r\\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\\r\\n }\\r\\n return func.apply(thisArg, args);\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseAggregator` for arrays.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to iterate over.\\r\\n * @param {Function} setter The function to set `accumulator` values.\\r\\n * @param {Function} iteratee The iteratee to transform keys.\\r\\n * @param {Object} accumulator The initial aggregated object.\\r\\n * @returns {Function} Returns `accumulator`.\\r\\n */\\r\\n function arrayAggregator(array, setter, iteratee, accumulator) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length;\\r\\n\\r\\n while (++index < length) {\\r\\n var value = array[index];\\r\\n setter(accumulator, value, iteratee(value), array);\\r\\n }\\r\\n return accumulator;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.forEach` for arrays without support for\\r\\n * iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @returns {Array} Returns `array`.\\r\\n */\\r\\n function arrayEach(array, iteratee) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length;\\r\\n\\r\\n while (++index < length) {\\r\\n if (iteratee(array[index], index, array) === false) {\\r\\n break;\\r\\n }\\r\\n }\\r\\n return array;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.every` for arrays without support for\\r\\n * iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to iterate over.\\r\\n * @param {Function} predicate The function invoked per iteration.\\r\\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\\r\\n * else `false`.\\r\\n */\\r\\n function arrayEvery(array, predicate) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length;\\r\\n\\r\\n while (++index < length) {\\r\\n if (!predicate(array[index], index, array)) {\\r\\n return false;\\r\\n }\\r\\n }\\r\\n return true;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.filter` for arrays without support for\\r\\n * iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to iterate over.\\r\\n * @param {Function} predicate The function invoked per iteration.\\r\\n * @returns {Array} Returns the new filtered array.\\r\\n */\\r\\n function arrayFilter(array, predicate) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length,\\r\\n resIndex = 0,\\r\\n result = [];\\r\\n\\r\\n while (++index < length) {\\r\\n var value = array[index];\\r\\n if (predicate(value, index, array)) {\\r\\n result[resIndex++] = value;\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.includes` for arrays without support for\\r\\n * specifying an index to search from.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to inspect.\\r\\n * @param {*} target The value to search for.\\r\\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\\r\\n */\\r\\n function arrayIncludes(array, value) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n return !!length && baseIndexOf(array, value, 0) > -1;\\r\\n }\\r\\n\\r\\n /**\\r\\n * This function is like `arrayIncludes` except that it accepts a comparator.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to inspect.\\r\\n * @param {*} target The value to search for.\\r\\n * @param {Function} comparator The comparator invoked per element.\\r\\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\\r\\n */\\r\\n function arrayIncludesWith(array, value, comparator) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length;\\r\\n\\r\\n while (++index < length) {\\r\\n if (comparator(value, array[index])) {\\r\\n return true;\\r\\n }\\r\\n }\\r\\n return false;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.map` for arrays without support for iteratee\\r\\n * shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @returns {Array} Returns the new mapped array.\\r\\n */\\r\\n function arrayMap(array, iteratee) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length,\\r\\n result = Array(length);\\r\\n\\r\\n while (++index < length) {\\r\\n result[index] = iteratee(array[index], index, array);\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Appends the elements of `values` to `array`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to modify.\\r\\n * @param {Array} values The values to append.\\r\\n * @returns {Array} Returns `array`.\\r\\n */\\r\\n function arrayPush(array, values) {\\r\\n var index = -1,\\r\\n length = values.length,\\r\\n offset = array.length;\\r\\n\\r\\n while (++index < length) {\\r\\n array[offset + index] = values[index];\\r\\n }\\r\\n return array;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.reduce` for arrays without support for\\r\\n * iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @param {*} [accumulator] The initial value.\\r\\n * @param {boolean} [initAccum] Specify using the first element of `array` as\\r\\n * the initial value.\\r\\n * @returns {*} Returns the accumulated value.\\r\\n */\\r\\n function arrayReduce(array, iteratee, accumulator, initAccum) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length;\\r\\n\\r\\n if (initAccum && length) {\\r\\n accumulator = array[++index];\\r\\n }\\r\\n while (++index < length) {\\r\\n accumulator = iteratee(accumulator, array[index], index, array);\\r\\n }\\r\\n return accumulator;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.some` for arrays without support for iteratee\\r\\n * shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} [array] The array to iterate over.\\r\\n * @param {Function} predicate The function invoked per iteration.\\r\\n * @returns {boolean} Returns `true` if any element passes the predicate check,\\r\\n * else `false`.\\r\\n */\\r\\n function arraySome(array, predicate) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length;\\r\\n\\r\\n while (++index < length) {\\r\\n if (predicate(array[index], index, array)) {\\r\\n return true;\\r\\n }\\r\\n }\\r\\n return false;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the size of an ASCII `string`.\\r\\n *\\r\\n * @private\\r\\n * @param {string} string The string inspect.\\r\\n * @returns {number} Returns the string size.\\r\\n */\\r\\n var asciiSize = baseProperty('length');\\r\\n\\r\\n /**\\r\\n * Converts an ASCII `string` to an array.\\r\\n *\\r\\n * @private\\r\\n * @param {string} string The string to convert.\\r\\n * @returns {Array} Returns the converted array.\\r\\n */\\r\\n function asciiToArray(string) {\\r\\n return string.split('');\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of methods like `_.findKey` and `_.findLastKey`,\\r\\n * without support for iteratee shorthands, which iterates over `collection`\\r\\n * using `eachFunc`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to inspect.\\r\\n * @param {Function} predicate The function invoked per iteration.\\r\\n * @param {Function} eachFunc The function to iterate over `collection`.\\r\\n * @returns {*} Returns the found element or its key, else `undefined`.\\r\\n */\\r\\n function baseFindKey(collection, predicate, eachFunc) {\\r\\n var result;\\r\\n eachFunc(collection, function(value, key, collection) {\\r\\n if (predicate(value, key, collection)) {\\r\\n result = key;\\r\\n return false;\\r\\n }\\r\\n });\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\\r\\n * support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {Function} predicate The function invoked per iteration.\\r\\n * @param {number} fromIndex The index to search from.\\r\\n * @param {boolean} [fromRight] Specify iterating from right to left.\\r\\n * @returns {number} Returns the index of the matched value, else `-1`.\\r\\n */\\r\\n function baseFindIndex(array, predicate, fromIndex, fromRight) {\\r\\n var length = array.length,\\r\\n index = fromIndex + (fromRight ? 1 : -1);\\r\\n\\r\\n while ((fromRight ? index-- : ++index < length)) {\\r\\n if (predicate(array[index], index, array)) {\\r\\n return index;\\r\\n }\\r\\n }\\r\\n return -1;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {*} value The value to search for.\\r\\n * @param {number} fromIndex The index to search from.\\r\\n * @returns {number} Returns the index of the matched value, else `-1`.\\r\\n */\\r\\n function baseIndexOf(array, value, fromIndex) {\\r\\n return value === value\\r\\n ? strictIndexOf(array, value, fromIndex)\\r\\n : baseFindIndex(array, baseIsNaN, fromIndex);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isNaN` without support for number objects.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\\r\\n */\\r\\n function baseIsNaN(value) {\\r\\n return value !== value;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.property` without support for deep paths.\\r\\n *\\r\\n * @private\\r\\n * @param {string} key The key of the property to get.\\r\\n * @returns {Function} Returns the new accessor function.\\r\\n */\\r\\n function baseProperty(key) {\\r\\n return function(object) {\\r\\n return object == null ? undefined : object[key];\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.propertyOf` without support for deep paths.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Function} Returns the new accessor function.\\r\\n */\\r\\n function basePropertyOf(object) {\\r\\n return function(key) {\\r\\n return object == null ? undefined : object[key];\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\\r\\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @param {*} accumulator The initial value.\\r\\n * @param {boolean} initAccum Specify using the first or last element of\\r\\n * `collection` as the initial value.\\r\\n * @param {Function} eachFunc The function to iterate over `collection`.\\r\\n * @returns {*} Returns the accumulated value.\\r\\n */\\r\\n function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\\r\\n eachFunc(collection, function(value, index, collection) {\\r\\n accumulator = initAccum\\r\\n ? (initAccum = false, value)\\r\\n : iteratee(accumulator, value, index, collection);\\r\\n });\\r\\n return accumulator;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.sortBy` which uses `comparer` to define the\\r\\n * sort order of `array` and replaces criteria objects with their corresponding\\r\\n * values.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to sort.\\r\\n * @param {Function} comparer The function to define sort order.\\r\\n * @returns {Array} Returns `array`.\\r\\n */\\r\\n function baseSortBy(array, comparer) {\\r\\n var length = array.length;\\r\\n\\r\\n array.sort(comparer);\\r\\n while (length--) {\\r\\n array[length] = array[length].value;\\r\\n }\\r\\n return array;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.times` without support for iteratee shorthands\\r\\n * or max array length checks.\\r\\n *\\r\\n * @private\\r\\n * @param {number} n The number of times to invoke `iteratee`.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @returns {Array} Returns the array of results.\\r\\n */\\r\\n function baseTimes(n, iteratee) {\\r\\n var index = -1,\\r\\n result = Array(n);\\r\\n\\r\\n while (++index < n) {\\r\\n result[index] = iteratee(index);\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.unary` without support for storing metadata.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to cap arguments for.\\r\\n * @returns {Function} Returns the new capped function.\\r\\n */\\r\\n function baseUnary(func) {\\r\\n return function(value) {\\r\\n return func(value);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.values` and `_.valuesIn` which creates an\\r\\n * array of `object` property values corresponding to the property names\\r\\n * of `props`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array} props The property names to get values for.\\r\\n * @returns {Object} Returns the array of property values.\\r\\n */\\r\\n function baseValues(object, props) {\\r\\n return arrayMap(props, function(key) {\\r\\n return object[key];\\r\\n });\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if a `cache` value for `key` exists.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} cache The cache to query.\\r\\n * @param {string} key The key of the entry to check.\\r\\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\\r\\n */\\r\\n function cacheHas(cache, key) {\\r\\n return cache.has(key);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol\\r\\n * that is not found in the character symbols.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} strSymbols The string symbols to inspect.\\r\\n * @param {Array} chrSymbols The character symbols to find.\\r\\n * @returns {number} Returns the index of the first unmatched string symbol.\\r\\n */\\r\\n function charsStartIndex(strSymbols, chrSymbols) {\\r\\n var index = -1,\\r\\n length = strSymbols.length;\\r\\n\\r\\n while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\\r\\n return index;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol\\r\\n * that is not found in the character symbols.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} strSymbols The string symbols to inspect.\\r\\n * @param {Array} chrSymbols The character symbols to find.\\r\\n * @returns {number} Returns the index of the last unmatched string symbol.\\r\\n */\\r\\n function charsEndIndex(strSymbols, chrSymbols) {\\r\\n var index = strSymbols.length;\\r\\n\\r\\n while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\\r\\n return index;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the number of `placeholder` occurrences in `array`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {*} placeholder The placeholder to search for.\\r\\n * @returns {number} Returns the placeholder count.\\r\\n */\\r\\n function countHolders(array, placeholder) {\\r\\n var length = array.length,\\r\\n result = 0;\\r\\n\\r\\n while (length--) {\\r\\n if (array[length] === placeholder) {\\r\\n ++result;\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Used by `_.escape` to convert characters to HTML entities.\\r\\n *\\r\\n * @private\\r\\n * @param {string} chr The matched character to escape.\\r\\n * @returns {string} Returns the escaped character.\\r\\n */\\r\\n var escapeHtmlChar = basePropertyOf(htmlEscapes);\\r\\n\\r\\n /**\\r\\n * Gets the value at `key` of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} [object] The object to query.\\r\\n * @param {string} key The key of the property to get.\\r\\n * @returns {*} Returns the property value.\\r\\n */\\r\\n function getValue(object, key) {\\r\\n return object == null ? undefined : object[key];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `string` contains Unicode symbols.\\r\\n *\\r\\n * @private\\r\\n * @param {string} string The string to inspect.\\r\\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\\r\\n */\\r\\n function hasUnicode(string) {\\r\\n return reHasUnicode.test(string);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `iterator` to an array.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} iterator The iterator to convert.\\r\\n * @returns {Array} Returns the converted array.\\r\\n */\\r\\n function iteratorToArray(iterator) {\\r\\n var data,\\r\\n result = [];\\r\\n\\r\\n while (!(data = iterator.next()).done) {\\r\\n result.push(data.value);\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `map` to its key-value pairs.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} map The map to convert.\\r\\n * @returns {Array} Returns the key-value pairs.\\r\\n */\\r\\n function mapToArray(map) {\\r\\n var index = -1,\\r\\n result = Array(map.size);\\r\\n\\r\\n map.forEach(function(value, key) {\\r\\n result[++index] = [key, value];\\r\\n });\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a unary function that invokes `func` with its argument transformed.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to wrap.\\r\\n * @param {Function} transform The argument transform.\\r\\n * @returns {Function} Returns the new function.\\r\\n */\\r\\n function overArg(func, transform) {\\r\\n return function(arg) {\\r\\n return func(transform(arg));\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Replaces all `placeholder` elements in `array` with an internal placeholder\\r\\n * and returns an array of their indexes.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to modify.\\r\\n * @param {*} placeholder The placeholder to replace.\\r\\n * @returns {Array} Returns the new array of placeholder indexes.\\r\\n */\\r\\n function replaceHolders(array, placeholder) {\\r\\n var index = -1,\\r\\n length = array.length,\\r\\n resIndex = 0,\\r\\n result = [];\\r\\n\\r\\n while (++index < length) {\\r\\n var value = array[index];\\r\\n if (value === placeholder || value === PLACEHOLDER) {\\r\\n array[index] = PLACEHOLDER;\\r\\n result[resIndex++] = index;\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the value at `key`, unless `key` is \\\"__proto__\\\".\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @param {string} key The key of the property to get.\\r\\n * @returns {*} Returns the property value.\\r\\n */\\r\\n function safeGet(object, key) {\\r\\n return key == '__proto__'\\r\\n ? undefined\\r\\n : object[key];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `set` to an array of its values.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} set The set to convert.\\r\\n * @returns {Array} Returns the values.\\r\\n */\\r\\n function setToArray(set) {\\r\\n var index = -1,\\r\\n result = Array(set.size);\\r\\n\\r\\n set.forEach(function(value) {\\r\\n result[++index] = value;\\r\\n });\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.indexOf` which performs strict equality\\r\\n * comparisons of values, i.e. `===`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {*} value The value to search for.\\r\\n * @param {number} fromIndex The index to search from.\\r\\n * @returns {number} Returns the index of the matched value, else `-1`.\\r\\n */\\r\\n function strictIndexOf(array, value, fromIndex) {\\r\\n var index = fromIndex - 1,\\r\\n length = array.length;\\r\\n\\r\\n while (++index < length) {\\r\\n if (array[index] === value) {\\r\\n return index;\\r\\n }\\r\\n }\\r\\n return -1;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the number of symbols in `string`.\\r\\n *\\r\\n * @private\\r\\n * @param {string} string The string to inspect.\\r\\n * @returns {number} Returns the string size.\\r\\n */\\r\\n function stringSize(string) {\\r\\n return hasUnicode(string)\\r\\n ? unicodeSize(string)\\r\\n : asciiSize(string);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `string` to an array.\\r\\n *\\r\\n * @private\\r\\n * @param {string} string The string to convert.\\r\\n * @returns {Array} Returns the converted array.\\r\\n */\\r\\n function stringToArray(string) {\\r\\n return hasUnicode(string)\\r\\n ? unicodeToArray(string)\\r\\n : asciiToArray(string);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the size of a Unicode `string`.\\r\\n *\\r\\n * @private\\r\\n * @param {string} string The string inspect.\\r\\n * @returns {number} Returns the string size.\\r\\n */\\r\\n function unicodeSize(string) {\\r\\n var result = reUnicode.lastIndex = 0;\\r\\n while (reUnicode.test(string)) {\\r\\n ++result;\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts a Unicode `string` to an array.\\r\\n *\\r\\n * @private\\r\\n * @param {string} string The string to convert.\\r\\n * @returns {Array} Returns the converted array.\\r\\n */\\r\\n function unicodeToArray(string) {\\r\\n return string.match(reUnicode) || [];\\r\\n }\\r\\n\\r\\n /*--------------------------------------------------------------------------*/\\r\\n\\r\\n /** Used for built-in method references. */\\r\\n var arrayProto = Array.prototype,\\r\\n funcProto = Function.prototype,\\r\\n objectProto = Object.prototype;\\r\\n\\r\\n /** Used to detect overreaching core-js shims. */\\r\\n var coreJsData = root['__core-js_shared__'];\\r\\n\\r\\n /** Used to resolve the decompiled source of functions. */\\r\\n var funcToString = funcProto.toString;\\r\\n\\r\\n /** Used to check objects for own properties. */\\r\\n var hasOwnProperty = objectProto.hasOwnProperty;\\r\\n\\r\\n /** Used to generate unique IDs. */\\r\\n var idCounter = 0;\\r\\n\\r\\n /** Used to detect methods masquerading as native. */\\r\\n var maskSrcKey = (function() {\\r\\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\\r\\n return uid ? ('Symbol(src)_1.' + uid) : '';\\r\\n }());\\r\\n\\r\\n /**\\r\\n * Used to resolve the\\r\\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\\r\\n * of values.\\r\\n */\\r\\n var nativeObjectToString = objectProto.toString;\\r\\n\\r\\n /** Used to infer the `Object` constructor. */\\r\\n var objectCtorString = funcToString.call(Object);\\r\\n\\r\\n /** Used to restore the original `_` reference in `_.noConflict`. */\\r\\n var oldDash = root._;\\r\\n\\r\\n /** Used to detect if a method is native. */\\r\\n var reIsNative = RegExp('^' +\\r\\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\\\\\$&')\\r\\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\\\\\\\()| for .+?(?=\\\\\\\\\\\\])/g, '$1.*?') + '$'\\r\\n );\\r\\n\\r\\n /** Built-in value references. */\\r\\n var Buffer = moduleExports ? root.Buffer : undefined,\\r\\n Symbol = root.Symbol,\\r\\n Uint8Array = root.Uint8Array,\\r\\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined,\\r\\n getPrototype = overArg(Object.getPrototypeOf, Object),\\r\\n objectCreate = Object.create,\\r\\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\\r\\n splice = arrayProto.splice,\\r\\n spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined,\\r\\n symIterator = Symbol ? Symbol.iterator : undefined,\\r\\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\\r\\n\\r\\n var defineProperty = (function() {\\r\\n try {\\r\\n var func = getNative(Object, 'defineProperty');\\r\\n func({}, '', {});\\r\\n return func;\\r\\n } catch (e) {}\\r\\n }());\\r\\n\\r\\n /* Built-in method references for those with the same name as other `lodash` methods. */\\r\\n var nativeCeil = Math.ceil,\\r\\n nativeFloor = Math.floor,\\r\\n nativeGetSymbols = Object.getOwnPropertySymbols,\\r\\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\\r\\n nativeIsFinite = root.isFinite,\\r\\n nativeKeys = overArg(Object.keys, Object),\\r\\n nativeMax = Math.max,\\r\\n nativeMin = Math.min,\\r\\n nativeNow = Date.now,\\r\\n nativeRandom = Math.random,\\r\\n nativeReverse = arrayProto.reverse;\\r\\n\\r\\n /* Built-in method references that are verified to be native. */\\r\\n var DataView = getNative(root, 'DataView'),\\r\\n Map = getNative(root, 'Map'),\\r\\n Promise = getNative(root, 'Promise'),\\r\\n Set = getNative(root, 'Set'),\\r\\n WeakMap = getNative(root, 'WeakMap'),\\r\\n nativeCreate = getNative(Object, 'create');\\r\\n\\r\\n /** Used to store function metadata. */\\r\\n var metaMap = WeakMap && new WeakMap;\\r\\n\\r\\n /** Used to lookup unminified function names. */\\r\\n var realNames = {};\\r\\n\\r\\n /** Used to detect maps, sets, and weakmaps. */\\r\\n var dataViewCtorString = toSource(DataView),\\r\\n mapCtorString = toSource(Map),\\r\\n promiseCtorString = toSource(Promise),\\r\\n setCtorString = toSource(Set),\\r\\n weakMapCtorString = toSource(WeakMap);\\r\\n\\r\\n /** Used to convert symbols to primitives and strings. */\\r\\n var symbolProto = Symbol ? Symbol.prototype : undefined,\\r\\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined,\\r\\n symbolToString = symbolProto ? symbolProto.toString : undefined;\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates a `lodash` object which wraps `value` to enable implicit method\\r\\n * chain sequences. Methods that operate on and return arrays, collections,\\r\\n * and functions can be chained together. Methods that retrieve a single value\\r\\n * or may return a primitive value will automatically end the chain sequence\\r\\n * and return the unwrapped value. Otherwise, the value must be unwrapped\\r\\n * with `_#value`.\\r\\n *\\r\\n * Explicit chain sequences, which must be unwrapped with `_#value`, may be\\r\\n * enabled using `_.chain`.\\r\\n *\\r\\n * The execution of chained methods is lazy, that is, it's deferred until\\r\\n * `_#value` is implicitly or explicitly called.\\r\\n *\\r\\n * Lazy evaluation allows several methods to support shortcut fusion.\\r\\n * Shortcut fusion is an optimization to merge iteratee calls; this avoids\\r\\n * the creation of intermediate arrays and can greatly reduce the number of\\r\\n * iteratee executions. Sections of a chain sequence qualify for shortcut\\r\\n * fusion if the section is applied to an array and iteratees accept only\\r\\n * one argument. The heuristic for whether a section qualifies for shortcut\\r\\n * fusion is subject to change.\\r\\n *\\r\\n * Chaining is supported in custom builds as long as the `_#value` method is\\r\\n * directly or indirectly included in the build.\\r\\n *\\r\\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\\r\\n *\\r\\n * The wrapper `Array` methods are:\\r\\n * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`\\r\\n *\\r\\n * The wrapper `String` methods are:\\r\\n * `replace` and `split`\\r\\n *\\r\\n * The wrapper methods that support shortcut fusion are:\\r\\n * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,\\r\\n * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,\\r\\n * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`\\r\\n *\\r\\n * The chainable wrapper methods are:\\r\\n * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,\\r\\n * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,\\r\\n * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,\\r\\n * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,\\r\\n * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,\\r\\n * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,\\r\\n * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,\\r\\n * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,\\r\\n * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,\\r\\n * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,\\r\\n * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,\\r\\n * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,\\r\\n * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,\\r\\n * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,\\r\\n * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,\\r\\n * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,\\r\\n * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,\\r\\n * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,\\r\\n * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,\\r\\n * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,\\r\\n * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,\\r\\n * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,\\r\\n * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,\\r\\n * `zipObject`, `zipObjectDeep`, and `zipWith`\\r\\n *\\r\\n * The wrapper methods that are **not** chainable by default are:\\r\\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,\\r\\n * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,\\r\\n * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,\\r\\n * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,\\r\\n * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,\\r\\n * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,\\r\\n * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,\\r\\n * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,\\r\\n * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,\\r\\n * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,\\r\\n * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,\\r\\n * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,\\r\\n * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,\\r\\n * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,\\r\\n * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,\\r\\n * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,\\r\\n * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,\\r\\n * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,\\r\\n * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,\\r\\n * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,\\r\\n * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,\\r\\n * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,\\r\\n * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,\\r\\n * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,\\r\\n * `upperFirst`, `value`, and `words`\\r\\n *\\r\\n * @name _\\r\\n * @constructor\\r\\n * @category Seq\\r\\n * @param {*} value The value to wrap in a `lodash` instance.\\r\\n * @returns {Object} Returns the new `lodash` wrapper instance.\\r\\n * @example\\r\\n *\\r\\n * function square(n) {\\r\\n * return n * n;\\r\\n * }\\r\\n *\\r\\n * var wrapped = _([1, 2, 3]);\\r\\n *\\r\\n * // Returns an unwrapped value.\\r\\n * wrapped.reduce(_.add);\\r\\n * // => 6\\r\\n *\\r\\n * // Returns a wrapped value.\\r\\n * var squares = wrapped.map(square);\\r\\n *\\r\\n * _.isArray(squares);\\r\\n * // => false\\r\\n *\\r\\n * _.isArray(squares.value());\\r\\n * // => true\\r\\n */\\r\\n function lodash(value) {\\r\\n if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\\r\\n if (value instanceof LodashWrapper) {\\r\\n return value;\\r\\n }\\r\\n if (hasOwnProperty.call(value, '__wrapped__')) {\\r\\n return wrapperClone(value);\\r\\n }\\r\\n }\\r\\n return new LodashWrapper(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.create` without support for assigning\\r\\n * properties to the created object.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} proto The object to inherit from.\\r\\n * @returns {Object} Returns the new object.\\r\\n */\\r\\n var baseCreate = (function() {\\r\\n function object() {}\\r\\n return function(proto) {\\r\\n if (!isObject(proto)) {\\r\\n return {};\\r\\n }\\r\\n if (objectCreate) {\\r\\n return objectCreate(proto);\\r\\n }\\r\\n object.prototype = proto;\\r\\n var result = new object;\\r\\n object.prototype = undefined;\\r\\n return result;\\r\\n };\\r\\n }());\\r\\n\\r\\n /**\\r\\n * The function whose prototype chain sequence wrappers inherit from.\\r\\n *\\r\\n * @private\\r\\n */\\r\\n function baseLodash() {\\r\\n // No operation performed.\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base constructor for creating `lodash` wrapper objects.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to wrap.\\r\\n * @param {boolean} [chainAll] Enable explicit method chain sequences.\\r\\n */\\r\\n function LodashWrapper(value, chainAll) {\\r\\n this.__wrapped__ = value;\\r\\n this.__actions__ = [];\\r\\n this.__chain__ = !!chainAll;\\r\\n this.__index__ = 0;\\r\\n this.__values__ = undefined;\\r\\n }\\r\\n\\r\\n // Ensure wrappers are instances of `baseLodash`.\\r\\n lodash.prototype = baseLodash.prototype;\\r\\n lodash.prototype.constructor = lodash;\\r\\n\\r\\n LodashWrapper.prototype = baseCreate(baseLodash.prototype);\\r\\n LodashWrapper.prototype.constructor = LodashWrapper;\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\\r\\n *\\r\\n * @private\\r\\n * @constructor\\r\\n * @param {*} value The value to wrap.\\r\\n */\\r\\n function LazyWrapper(value) {\\r\\n this.__wrapped__ = value;\\r\\n this.__actions__ = [];\\r\\n this.__dir__ = 1;\\r\\n this.__filtered__ = false;\\r\\n this.__iteratees__ = [];\\r\\n this.__takeCount__ = MAX_ARRAY_LENGTH;\\r\\n this.__views__ = [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of the lazy wrapper object.\\r\\n *\\r\\n * @private\\r\\n * @name clone\\r\\n * @memberOf LazyWrapper\\r\\n * @returns {Object} Returns the cloned `LazyWrapper` object.\\r\\n */\\r\\n function lazyClone() {\\r\\n var result = new LazyWrapper(this.__wrapped__);\\r\\n result.__actions__ = copyArray(this.__actions__);\\r\\n result.__dir__ = this.__dir__;\\r\\n result.__filtered__ = this.__filtered__;\\r\\n result.__iteratees__ = copyArray(this.__iteratees__);\\r\\n result.__takeCount__ = this.__takeCount__;\\r\\n result.__views__ = copyArray(this.__views__);\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Reverses the direction of lazy iteration.\\r\\n *\\r\\n * @private\\r\\n * @name reverse\\r\\n * @memberOf LazyWrapper\\r\\n * @returns {Object} Returns the new reversed `LazyWrapper` object.\\r\\n */\\r\\n function lazyReverse() {\\r\\n if (this.__filtered__) {\\r\\n var result = new LazyWrapper(this);\\r\\n result.__dir__ = -1;\\r\\n result.__filtered__ = true;\\r\\n } else {\\r\\n result = this.clone();\\r\\n result.__dir__ *= -1;\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Extracts the unwrapped value from its lazy wrapper.\\r\\n *\\r\\n * @private\\r\\n * @name value\\r\\n * @memberOf LazyWrapper\\r\\n * @returns {*} Returns the unwrapped value.\\r\\n */\\r\\n function lazyValue() {\\r\\n var array = this.__wrapped__.value(),\\r\\n dir = this.__dir__,\\r\\n isArr = isArray(array),\\r\\n isRight = dir < 0,\\r\\n arrLength = isArr ? array.length : 0,\\r\\n view = getView(0, arrLength, this.__views__),\\r\\n start = view.start,\\r\\n end = view.end,\\r\\n length = end - start,\\r\\n index = isRight ? end : (start - 1),\\r\\n iteratees = this.__iteratees__,\\r\\n iterLength = iteratees.length,\\r\\n resIndex = 0,\\r\\n takeCount = nativeMin(length, this.__takeCount__);\\r\\n\\r\\n if (!isArr || (!isRight && arrLength == length && takeCount == length)) {\\r\\n return baseWrapperValue(array, this.__actions__);\\r\\n }\\r\\n var result = [];\\r\\n\\r\\n outer:\\r\\n while (length-- && resIndex < takeCount) {\\r\\n index += dir;\\r\\n\\r\\n var iterIndex = -1,\\r\\n value = array[index];\\r\\n\\r\\n while (++iterIndex < iterLength) {\\r\\n var data = iteratees[iterIndex],\\r\\n iteratee = data.iteratee,\\r\\n type = data.type,\\r\\n computed = iteratee(value);\\r\\n\\r\\n if (type == LAZY_MAP_FLAG) {\\r\\n value = computed;\\r\\n } else if (!computed) {\\r\\n if (type == LAZY_FILTER_FLAG) {\\r\\n continue outer;\\r\\n } else {\\r\\n break outer;\\r\\n }\\r\\n }\\r\\n }\\r\\n result[resIndex++] = value;\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n // Ensure `LazyWrapper` is an instance of `baseLodash`.\\r\\n LazyWrapper.prototype = baseCreate(baseLodash.prototype);\\r\\n LazyWrapper.prototype.constructor = LazyWrapper;\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates a hash object.\\r\\n *\\r\\n * @private\\r\\n * @constructor\\r\\n * @param {Array} [entries] The key-value pairs to cache.\\r\\n */\\r\\n function Hash(entries) {\\r\\n var index = -1,\\r\\n length = entries == null ? 0 : entries.length;\\r\\n\\r\\n this.clear();\\r\\n while (++index < length) {\\r\\n var entry = entries[index];\\r\\n this.set(entry[0], entry[1]);\\r\\n }\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes all key-value entries from the hash.\\r\\n *\\r\\n * @private\\r\\n * @name clear\\r\\n * @memberOf Hash\\r\\n */\\r\\n function hashClear() {\\r\\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\\r\\n this.size = 0;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes `key` and its value from the hash.\\r\\n *\\r\\n * @private\\r\\n * @name delete\\r\\n * @memberOf Hash\\r\\n * @param {Object} hash The hash to modify.\\r\\n * @param {string} key The key of the value to remove.\\r\\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\\r\\n */\\r\\n function hashDelete(key) {\\r\\n var result = this.has(key) && delete this.__data__[key];\\r\\n this.size -= result ? 1 : 0;\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the hash value for `key`.\\r\\n *\\r\\n * @private\\r\\n * @name get\\r\\n * @memberOf Hash\\r\\n * @param {string} key The key of the value to get.\\r\\n * @returns {*} Returns the entry value.\\r\\n */\\r\\n function hashGet(key) {\\r\\n var data = this.__data__;\\r\\n if (nativeCreate) {\\r\\n var result = data[key];\\r\\n return result === HASH_UNDEFINED ? undefined : result;\\r\\n }\\r\\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if a hash value for `key` exists.\\r\\n *\\r\\n * @private\\r\\n * @name has\\r\\n * @memberOf Hash\\r\\n * @param {string} key The key of the entry to check.\\r\\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\\r\\n */\\r\\n function hashHas(key) {\\r\\n var data = this.__data__;\\r\\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Sets the hash `key` to `value`.\\r\\n *\\r\\n * @private\\r\\n * @name set\\r\\n * @memberOf Hash\\r\\n * @param {string} key The key of the value to set.\\r\\n * @param {*} value The value to set.\\r\\n * @returns {Object} Returns the hash instance.\\r\\n */\\r\\n function hashSet(key, value) {\\r\\n var data = this.__data__;\\r\\n this.size += this.has(key) ? 0 : 1;\\r\\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\\r\\n return this;\\r\\n }\\r\\n\\r\\n // Add methods to `Hash`.\\r\\n Hash.prototype.clear = hashClear;\\r\\n Hash.prototype['delete'] = hashDelete;\\r\\n Hash.prototype.get = hashGet;\\r\\n Hash.prototype.has = hashHas;\\r\\n Hash.prototype.set = hashSet;\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates an list cache object.\\r\\n *\\r\\n * @private\\r\\n * @constructor\\r\\n * @param {Array} [entries] The key-value pairs to cache.\\r\\n */\\r\\n function ListCache(entries) {\\r\\n var index = -1,\\r\\n length = entries == null ? 0 : entries.length;\\r\\n\\r\\n this.clear();\\r\\n while (++index < length) {\\r\\n var entry = entries[index];\\r\\n this.set(entry[0], entry[1]);\\r\\n }\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes all key-value entries from the list cache.\\r\\n *\\r\\n * @private\\r\\n * @name clear\\r\\n * @memberOf ListCache\\r\\n */\\r\\n function listCacheClear() {\\r\\n this.__data__ = [];\\r\\n this.size = 0;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes `key` and its value from the list cache.\\r\\n *\\r\\n * @private\\r\\n * @name delete\\r\\n * @memberOf ListCache\\r\\n * @param {string} key The key of the value to remove.\\r\\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\\r\\n */\\r\\n function listCacheDelete(key) {\\r\\n var data = this.__data__,\\r\\n index = assocIndexOf(data, key);\\r\\n\\r\\n if (index < 0) {\\r\\n return false;\\r\\n }\\r\\n var lastIndex = data.length - 1;\\r\\n if (index == lastIndex) {\\r\\n data.pop();\\r\\n } else {\\r\\n splice.call(data, index, 1);\\r\\n }\\r\\n --this.size;\\r\\n return true;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the list cache value for `key`.\\r\\n *\\r\\n * @private\\r\\n * @name get\\r\\n * @memberOf ListCache\\r\\n * @param {string} key The key of the value to get.\\r\\n * @returns {*} Returns the entry value.\\r\\n */\\r\\n function listCacheGet(key) {\\r\\n var data = this.__data__,\\r\\n index = assocIndexOf(data, key);\\r\\n\\r\\n return index < 0 ? undefined : data[index][1];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if a list cache value for `key` exists.\\r\\n *\\r\\n * @private\\r\\n * @name has\\r\\n * @memberOf ListCache\\r\\n * @param {string} key The key of the entry to check.\\r\\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\\r\\n */\\r\\n function listCacheHas(key) {\\r\\n return assocIndexOf(this.__data__, key) > -1;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Sets the list cache `key` to `value`.\\r\\n *\\r\\n * @private\\r\\n * @name set\\r\\n * @memberOf ListCache\\r\\n * @param {string} key The key of the value to set.\\r\\n * @param {*} value The value to set.\\r\\n * @returns {Object} Returns the list cache instance.\\r\\n */\\r\\n function listCacheSet(key, value) {\\r\\n var data = this.__data__,\\r\\n index = assocIndexOf(data, key);\\r\\n\\r\\n if (index < 0) {\\r\\n ++this.size;\\r\\n data.push([key, value]);\\r\\n } else {\\r\\n data[index][1] = value;\\r\\n }\\r\\n return this;\\r\\n }\\r\\n\\r\\n // Add methods to `ListCache`.\\r\\n ListCache.prototype.clear = listCacheClear;\\r\\n ListCache.prototype['delete'] = listCacheDelete;\\r\\n ListCache.prototype.get = listCacheGet;\\r\\n ListCache.prototype.has = listCacheHas;\\r\\n ListCache.prototype.set = listCacheSet;\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates a map cache object to store key-value pairs.\\r\\n *\\r\\n * @private\\r\\n * @constructor\\r\\n * @param {Array} [entries] The key-value pairs to cache.\\r\\n */\\r\\n function MapCache(entries) {\\r\\n var index = -1,\\r\\n length = entries == null ? 0 : entries.length;\\r\\n\\r\\n this.clear();\\r\\n while (++index < length) {\\r\\n var entry = entries[index];\\r\\n this.set(entry[0], entry[1]);\\r\\n }\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes all key-value entries from the map.\\r\\n *\\r\\n * @private\\r\\n * @name clear\\r\\n * @memberOf MapCache\\r\\n */\\r\\n function mapCacheClear() {\\r\\n this.size = 0;\\r\\n this.__data__ = {\\r\\n 'hash': new Hash,\\r\\n 'map': new (Map || ListCache),\\r\\n 'string': new Hash\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes `key` and its value from the map.\\r\\n *\\r\\n * @private\\r\\n * @name delete\\r\\n * @memberOf MapCache\\r\\n * @param {string} key The key of the value to remove.\\r\\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\\r\\n */\\r\\n function mapCacheDelete(key) {\\r\\n var result = getMapData(this, key)['delete'](key);\\r\\n this.size -= result ? 1 : 0;\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the map value for `key`.\\r\\n *\\r\\n * @private\\r\\n * @name get\\r\\n * @memberOf MapCache\\r\\n * @param {string} key The key of the value to get.\\r\\n * @returns {*} Returns the entry value.\\r\\n */\\r\\n function mapCacheGet(key) {\\r\\n return getMapData(this, key).get(key);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if a map value for `key` exists.\\r\\n *\\r\\n * @private\\r\\n * @name has\\r\\n * @memberOf MapCache\\r\\n * @param {string} key The key of the entry to check.\\r\\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\\r\\n */\\r\\n function mapCacheHas(key) {\\r\\n return getMapData(this, key).has(key);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Sets the map `key` to `value`.\\r\\n *\\r\\n * @private\\r\\n * @name set\\r\\n * @memberOf MapCache\\r\\n * @param {string} key The key of the value to set.\\r\\n * @param {*} value The value to set.\\r\\n * @returns {Object} Returns the map cache instance.\\r\\n */\\r\\n function mapCacheSet(key, value) {\\r\\n var data = getMapData(this, key),\\r\\n size = data.size;\\r\\n\\r\\n data.set(key, value);\\r\\n this.size += data.size == size ? 0 : 1;\\r\\n return this;\\r\\n }\\r\\n\\r\\n // Add methods to `MapCache`.\\r\\n MapCache.prototype.clear = mapCacheClear;\\r\\n MapCache.prototype['delete'] = mapCacheDelete;\\r\\n MapCache.prototype.get = mapCacheGet;\\r\\n MapCache.prototype.has = mapCacheHas;\\r\\n MapCache.prototype.set = mapCacheSet;\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n *\\r\\n * Creates an array cache object to store unique values.\\r\\n *\\r\\n * @private\\r\\n * @constructor\\r\\n * @param {Array} [values] The values to cache.\\r\\n */\\r\\n function SetCache(values) {\\r\\n var index = -1,\\r\\n length = values == null ? 0 : values.length;\\r\\n\\r\\n this.__data__ = new MapCache;\\r\\n while (++index < length) {\\r\\n this.add(values[index]);\\r\\n }\\r\\n }\\r\\n\\r\\n /**\\r\\n * Adds `value` to the array cache.\\r\\n *\\r\\n * @private\\r\\n * @name add\\r\\n * @memberOf SetCache\\r\\n * @alias push\\r\\n * @param {*} value The value to cache.\\r\\n * @returns {Object} Returns the cache instance.\\r\\n */\\r\\n function setCacheAdd(value) {\\r\\n this.__data__.set(value, HASH_UNDEFINED);\\r\\n return this;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is in the array cache.\\r\\n *\\r\\n * @private\\r\\n * @name has\\r\\n * @memberOf SetCache\\r\\n * @param {*} value The value to search for.\\r\\n * @returns {number} Returns `true` if `value` is found, else `false`.\\r\\n */\\r\\n function setCacheHas(value) {\\r\\n return this.__data__.has(value);\\r\\n }\\r\\n\\r\\n // Add methods to `SetCache`.\\r\\n SetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\\r\\n SetCache.prototype.has = setCacheHas;\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates a stack cache object to store key-value pairs.\\r\\n *\\r\\n * @private\\r\\n * @constructor\\r\\n * @param {Array} [entries] The key-value pairs to cache.\\r\\n */\\r\\n function Stack(entries) {\\r\\n var data = this.__data__ = new ListCache(entries);\\r\\n this.size = data.size;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes all key-value entries from the stack.\\r\\n *\\r\\n * @private\\r\\n * @name clear\\r\\n * @memberOf Stack\\r\\n */\\r\\n function stackClear() {\\r\\n this.__data__ = new ListCache;\\r\\n this.size = 0;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes `key` and its value from the stack.\\r\\n *\\r\\n * @private\\r\\n * @name delete\\r\\n * @memberOf Stack\\r\\n * @param {string} key The key of the value to remove.\\r\\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\\r\\n */\\r\\n function stackDelete(key) {\\r\\n var data = this.__data__,\\r\\n result = data['delete'](key);\\r\\n\\r\\n this.size = data.size;\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the stack value for `key`.\\r\\n *\\r\\n * @private\\r\\n * @name get\\r\\n * @memberOf Stack\\r\\n * @param {string} key The key of the value to get.\\r\\n * @returns {*} Returns the entry value.\\r\\n */\\r\\n function stackGet(key) {\\r\\n return this.__data__.get(key);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if a stack value for `key` exists.\\r\\n *\\r\\n * @private\\r\\n * @name has\\r\\n * @memberOf Stack\\r\\n * @param {string} key The key of the entry to check.\\r\\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\\r\\n */\\r\\n function stackHas(key) {\\r\\n return this.__data__.has(key);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Sets the stack `key` to `value`.\\r\\n *\\r\\n * @private\\r\\n * @name set\\r\\n * @memberOf Stack\\r\\n * @param {string} key The key of the value to set.\\r\\n * @param {*} value The value to set.\\r\\n * @returns {Object} Returns the stack cache instance.\\r\\n */\\r\\n function stackSet(key, value) {\\r\\n var data = this.__data__;\\r\\n if (data instanceof ListCache) {\\r\\n var pairs = data.__data__;\\r\\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\\r\\n pairs.push([key, value]);\\r\\n this.size = ++data.size;\\r\\n return this;\\r\\n }\\r\\n data = this.__data__ = new MapCache(pairs);\\r\\n }\\r\\n data.set(key, value);\\r\\n this.size = data.size;\\r\\n return this;\\r\\n }\\r\\n\\r\\n // Add methods to `Stack`.\\r\\n Stack.prototype.clear = stackClear;\\r\\n Stack.prototype['delete'] = stackDelete;\\r\\n Stack.prototype.get = stackGet;\\r\\n Stack.prototype.has = stackHas;\\r\\n Stack.prototype.set = stackSet;\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates an array of the enumerable property names of the array-like `value`.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to query.\\r\\n * @param {boolean} inherited Specify returning inherited property names.\\r\\n * @returns {Array} Returns the array of property names.\\r\\n */\\r\\n function arrayLikeKeys(value, inherited) {\\r\\n var isArr = isArray(value),\\r\\n isArg = !isArr && isArguments(value),\\r\\n isBuff = !isArr && !isArg && isBuffer(value),\\r\\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\\r\\n skipIndexes = isArr || isArg || isBuff || isType,\\r\\n result = skipIndexes ? baseTimes(value.length, String) : [],\\r\\n length = result.length;\\r\\n\\r\\n for (var key in value) {\\r\\n if ((inherited || hasOwnProperty.call(value, key)) &&\\r\\n !(skipIndexes && (\\r\\n // Safari 9 has enumerable `arguments.length` in strict mode.\\r\\n key == 'length' ||\\r\\n // Node.js 0.10 has enumerable non-index properties on buffers.\\r\\n (isBuff && (key == 'offset' || key == 'parent')) ||\\r\\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\\r\\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\\r\\n // Skip index properties.\\r\\n isIndex(key, length)\\r\\n ))) {\\r\\n result.push(key);\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * This function is like `assignValue` except that it doesn't assign\\r\\n * `undefined` values.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to modify.\\r\\n * @param {string} key The key of the property to assign.\\r\\n * @param {*} value The value to assign.\\r\\n */\\r\\n function assignMergeValue(object, key, value) {\\r\\n if ((value !== undefined && !eq(object[key], value)) ||\\r\\n (value === undefined && !(key in object))) {\\r\\n baseAssignValue(object, key, value);\\r\\n }\\r\\n }\\r\\n\\r\\n /**\\r\\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\\r\\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\\r\\n * for equality comparisons.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to modify.\\r\\n * @param {string} key The key of the property to assign.\\r\\n * @param {*} value The value to assign.\\r\\n */\\r\\n function assignValue(object, key, value) {\\r\\n var objValue = object[key];\\r\\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\\r\\n (value === undefined && !(key in object))) {\\r\\n baseAssignValue(object, key, value);\\r\\n }\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the index at which the `key` is found in `array` of key-value pairs.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {*} key The key to search for.\\r\\n * @returns {number} Returns the index of the matched value, else `-1`.\\r\\n */\\r\\n function assocIndexOf(array, key) {\\r\\n var length = array.length;\\r\\n while (length--) {\\r\\n if (eq(array[length][0], key)) {\\r\\n return length;\\r\\n }\\r\\n }\\r\\n return -1;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Aggregates elements of `collection` on `accumulator` with keys transformed\\r\\n * by `iteratee` and values set by `setter`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} setter The function to set `accumulator` values.\\r\\n * @param {Function} iteratee The iteratee to transform keys.\\r\\n * @param {Object} accumulator The initial aggregated object.\\r\\n * @returns {Function} Returns `accumulator`.\\r\\n */\\r\\n function baseAggregator(collection, setter, iteratee, accumulator) {\\r\\n baseEach(collection, function(value, key, collection) {\\r\\n setter(accumulator, value, iteratee(value), collection);\\r\\n });\\r\\n return accumulator;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.assign` without support for multiple sources\\r\\n * or `customizer` functions.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The destination object.\\r\\n * @param {Object} source The source object.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n function baseAssign(object, source) {\\r\\n return object && copyObject(source, keys(source), object);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.assignIn` without support for multiple sources\\r\\n * or `customizer` functions.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The destination object.\\r\\n * @param {Object} source The source object.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n function baseAssignIn(object, source) {\\r\\n return object && copyObject(source, keysIn(source), object);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `assignValue` and `assignMergeValue` without\\r\\n * value checks.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to modify.\\r\\n * @param {string} key The key of the property to assign.\\r\\n * @param {*} value The value to assign.\\r\\n */\\r\\n function baseAssignValue(object, key, value) {\\r\\n if (key == '__proto__' && defineProperty) {\\r\\n defineProperty(object, key, {\\r\\n 'configurable': true,\\r\\n 'enumerable': true,\\r\\n 'value': value,\\r\\n 'writable': true\\r\\n });\\r\\n } else {\\r\\n object[key] = value;\\r\\n }\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.at` without support for individual paths.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to iterate over.\\r\\n * @param {string[]} paths The property paths to pick.\\r\\n * @returns {Array} Returns the picked elements.\\r\\n */\\r\\n function baseAt(object, paths) {\\r\\n var index = -1,\\r\\n length = paths.length,\\r\\n result = Array(length),\\r\\n skip = object == null;\\r\\n\\r\\n while (++index < length) {\\r\\n result[index] = skip ? undefined : get(object, paths[index]);\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.clamp` which doesn't coerce arguments.\\r\\n *\\r\\n * @private\\r\\n * @param {number} number The number to clamp.\\r\\n * @param {number} [lower] The lower bound.\\r\\n * @param {number} upper The upper bound.\\r\\n * @returns {number} Returns the clamped number.\\r\\n */\\r\\n function baseClamp(number, lower, upper) {\\r\\n if (number === number) {\\r\\n if (upper !== undefined) {\\r\\n number = number <= upper ? number : upper;\\r\\n }\\r\\n if (lower !== undefined) {\\r\\n number = number >= lower ? number : lower;\\r\\n }\\r\\n }\\r\\n return number;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\\r\\n * traversed objects.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to clone.\\r\\n * @param {boolean} bitmask The bitmask flags.\\r\\n * 1 - Deep clone\\r\\n * 2 - Flatten inherited properties\\r\\n * 4 - Clone symbols\\r\\n * @param {Function} [customizer] The function to customize cloning.\\r\\n * @param {string} [key] The key of `value`.\\r\\n * @param {Object} [object] The parent object of `value`.\\r\\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\\r\\n * @returns {*} Returns the cloned value.\\r\\n */\\r\\n function baseClone(value, bitmask, customizer, key, object, stack) {\\r\\n var result,\\r\\n isDeep = bitmask & CLONE_DEEP_FLAG,\\r\\n isFlat = bitmask & CLONE_FLAT_FLAG,\\r\\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\\r\\n\\r\\n if (customizer) {\\r\\n result = object ? customizer(value, key, object, stack) : customizer(value);\\r\\n }\\r\\n if (result !== undefined) {\\r\\n return result;\\r\\n }\\r\\n if (!isObject(value)) {\\r\\n return value;\\r\\n }\\r\\n var isArr = isArray(value);\\r\\n if (isArr) {\\r\\n result = initCloneArray(value);\\r\\n if (!isDeep) {\\r\\n return copyArray(value, result);\\r\\n }\\r\\n } else {\\r\\n var tag = getTag(value),\\r\\n isFunc = tag == funcTag || tag == genTag;\\r\\n\\r\\n if (isBuffer(value)) {\\r\\n return cloneBuffer(value, isDeep);\\r\\n }\\r\\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\\r\\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\\r\\n if (!isDeep) {\\r\\n return isFlat\\r\\n ? copySymbolsIn(value, baseAssignIn(result, value))\\r\\n : copySymbols(value, baseAssign(result, value));\\r\\n }\\r\\n } else {\\r\\n if (!cloneableTags[tag]) {\\r\\n return object ? value : {};\\r\\n }\\r\\n result = initCloneByTag(value, tag, isDeep);\\r\\n }\\r\\n }\\r\\n // Check for circular references and return its corresponding clone.\\r\\n stack || (stack = new Stack);\\r\\n var stacked = stack.get(value);\\r\\n if (stacked) {\\r\\n return stacked;\\r\\n }\\r\\n stack.set(value, result);\\r\\n\\r\\n if (isSet(value)) {\\r\\n value.forEach(function(subValue) {\\r\\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\\r\\n });\\r\\n\\r\\n return result;\\r\\n }\\r\\n\\r\\n if (isMap(value)) {\\r\\n value.forEach(function(subValue, key) {\\r\\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\\r\\n });\\r\\n\\r\\n return result;\\r\\n }\\r\\n\\r\\n var keysFunc = isFull\\r\\n ? (isFlat ? getAllKeysIn : getAllKeys)\\r\\n : (isFlat ? keysIn : keys);\\r\\n\\r\\n var props = isArr ? undefined : keysFunc(value);\\r\\n arrayEach(props || value, function(subValue, key) {\\r\\n if (props) {\\r\\n key = subValue;\\r\\n subValue = value[key];\\r\\n }\\r\\n // Recursively populate clone (susceptible to call stack limits).\\r\\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\\r\\n });\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.delay` and `_.defer` which accepts `args`\\r\\n * to provide to `func`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to delay.\\r\\n * @param {number} wait The number of milliseconds to delay invocation.\\r\\n * @param {Array} args The arguments to provide to `func`.\\r\\n * @returns {number|Object} Returns the timer id or timeout object.\\r\\n */\\r\\n function baseDelay(func, wait, args) {\\r\\n if (typeof func != 'function') {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n return setTimeout(function() { func.apply(undefined, args); }, wait);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of methods like `_.difference` without support\\r\\n * for excluding multiple arrays or iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {Array} values The values to exclude.\\r\\n * @param {Function} [iteratee] The iteratee invoked per element.\\r\\n * @param {Function} [comparator] The comparator invoked per element.\\r\\n * @returns {Array} Returns the new array of filtered values.\\r\\n */\\r\\n function baseDifference(array, values, iteratee, comparator) {\\r\\n var index = -1,\\r\\n includes = arrayIncludes,\\r\\n isCommon = true,\\r\\n length = array.length,\\r\\n result = [],\\r\\n valuesLength = values.length;\\r\\n\\r\\n if (!length) {\\r\\n return result;\\r\\n }\\r\\n if (iteratee) {\\r\\n values = arrayMap(values, baseUnary(iteratee));\\r\\n }\\r\\n if (comparator) {\\r\\n includes = arrayIncludesWith;\\r\\n isCommon = false;\\r\\n }\\r\\n else if (values.length >= LARGE_ARRAY_SIZE) {\\r\\n includes = cacheHas;\\r\\n isCommon = false;\\r\\n values = new SetCache(values);\\r\\n }\\r\\n outer:\\r\\n while (++index < length) {\\r\\n var value = array[index],\\r\\n computed = iteratee == null ? value : iteratee(value);\\r\\n\\r\\n value = (comparator || value !== 0) ? value : 0;\\r\\n if (isCommon && computed === computed) {\\r\\n var valuesIndex = valuesLength;\\r\\n while (valuesIndex--) {\\r\\n if (values[valuesIndex] === computed) {\\r\\n continue outer;\\r\\n }\\r\\n }\\r\\n result.push(value);\\r\\n }\\r\\n else if (!includes(values, computed, comparator)) {\\r\\n result.push(value);\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.forEach` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @returns {Array|Object} Returns `collection`.\\r\\n */\\r\\n var baseEach = createBaseEach(baseForOwn);\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.every` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} predicate The function invoked per iteration.\\r\\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\\r\\n * else `false`\\r\\n */\\r\\n function baseEvery(collection, predicate) {\\r\\n var result = true;\\r\\n baseEach(collection, function(value, index, collection) {\\r\\n result = !!predicate(value, index, collection);\\r\\n return result;\\r\\n });\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of methods like `_.max` and `_.min` which accepts a\\r\\n * `comparator` to determine the extremum value.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to iterate over.\\r\\n * @param {Function} iteratee The iteratee invoked per iteration.\\r\\n * @param {Function} comparator The comparator used to compare values.\\r\\n * @returns {*} Returns the extremum value.\\r\\n */\\r\\n function baseExtremum(array, iteratee, comparator) {\\r\\n var index = -1,\\r\\n length = array.length;\\r\\n\\r\\n while (++index < length) {\\r\\n var value = array[index],\\r\\n current = iteratee(value);\\r\\n\\r\\n if (current != null && (computed === undefined\\r\\n ? (current === current && !isSymbol(current))\\r\\n : comparator(current, computed)\\r\\n )) {\\r\\n var computed = current,\\r\\n result = value;\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.filter` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} predicate The function invoked per iteration.\\r\\n * @returns {Array} Returns the new filtered array.\\r\\n */\\r\\n function baseFilter(collection, predicate) {\\r\\n var result = [];\\r\\n baseEach(collection, function(value, index, collection) {\\r\\n if (predicate(value, index, collection)) {\\r\\n result.push(value);\\r\\n }\\r\\n });\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.flatten` with support for restricting flattening.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to flatten.\\r\\n * @param {number} depth The maximum recursion depth.\\r\\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\\r\\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\\r\\n * @param {Array} [result=[]] The initial result value.\\r\\n * @returns {Array} Returns the new flattened array.\\r\\n */\\r\\n function baseFlatten(array, depth, predicate, isStrict, result) {\\r\\n var index = -1,\\r\\n length = array.length;\\r\\n\\r\\n predicate || (predicate = isFlattenable);\\r\\n result || (result = []);\\r\\n\\r\\n while (++index < length) {\\r\\n var value = array[index];\\r\\n if (depth > 0 && predicate(value)) {\\r\\n if (depth > 1) {\\r\\n // Recursively flatten arrays (susceptible to call stack limits).\\r\\n baseFlatten(value, depth - 1, predicate, isStrict, result);\\r\\n } else {\\r\\n arrayPush(result, value);\\r\\n }\\r\\n } else if (!isStrict) {\\r\\n result[result.length] = value;\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `baseForOwn` which iterates over `object`\\r\\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\\r\\n * Iteratee functions may exit iteration early by explicitly returning `false`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @param {Function} keysFunc The function to get the keys of `object`.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n var baseFor = createBaseFor();\\r\\n\\r\\n /**\\r\\n * This function is like `baseFor` except that it iterates over properties\\r\\n * in the opposite order.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @param {Function} keysFunc The function to get the keys of `object`.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n var baseForRight = createBaseFor(true);\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n function baseForOwn(object, iteratee) {\\r\\n return object && baseFor(object, iteratee, keys);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.forOwnRight` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n function baseForOwnRight(object, iteratee) {\\r\\n return object && baseForRight(object, iteratee, keys);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.functions` which creates an array of\\r\\n * `object` function property names filtered from `props`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to inspect.\\r\\n * @param {Array} props The property names to filter.\\r\\n * @returns {Array} Returns the function names.\\r\\n */\\r\\n function baseFunctions(object, props) {\\r\\n return arrayFilter(props, function(key) {\\r\\n return isFunction(object[key]);\\r\\n });\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.get` without support for default values.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array|string} path The path of the property to get.\\r\\n * @returns {*} Returns the resolved value.\\r\\n */\\r\\n function baseGet(object, path) {\\r\\n path = castPath(path, object);\\r\\n\\r\\n var index = 0,\\r\\n length = path.length;\\r\\n\\r\\n while (object != null && index < length) {\\r\\n object = object[toKey(path[index++])];\\r\\n }\\r\\n return (index && index == length) ? object : undefined;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\\r\\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\\r\\n * symbols of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Function} keysFunc The function to get the keys of `object`.\\r\\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\\r\\n * @returns {Array} Returns the array of property names and symbols.\\r\\n */\\r\\n function baseGetAllKeys(object, keysFunc, symbolsFunc) {\\r\\n var result = keysFunc(object);\\r\\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `getTag` without fallbacks for buggy environments.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to query.\\r\\n * @returns {string} Returns the `toStringTag`.\\r\\n */\\r\\n function baseGetTag(value) {\\r\\n if (value == null) {\\r\\n return value === undefined ? undefinedTag : nullTag;\\r\\n }\\r\\n return (symToStringTag && symToStringTag in Object(value))\\r\\n ? getRawTag(value)\\r\\n : objectToString(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.gt` which doesn't coerce arguments.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to compare.\\r\\n * @param {*} other The other value to compare.\\r\\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\\r\\n * else `false`.\\r\\n */\\r\\n function baseGt(value, other) {\\r\\n return value > other;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.has` without support for deep paths.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} [object] The object to query.\\r\\n * @param {Array|string} key The key to check.\\r\\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\\r\\n */\\r\\n function baseHas(object, key) {\\r\\n return object != null && hasOwnProperty.call(object, key);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.hasIn` without support for deep paths.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} [object] The object to query.\\r\\n * @param {Array|string} key The key to check.\\r\\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\\r\\n */\\r\\n function baseHasIn(object, key) {\\r\\n return object != null && key in Object(object);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of methods like `_.intersection`, without support\\r\\n * for iteratee shorthands, that accepts an array of arrays to inspect.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} arrays The arrays to inspect.\\r\\n * @param {Function} [iteratee] The iteratee invoked per element.\\r\\n * @param {Function} [comparator] The comparator invoked per element.\\r\\n * @returns {Array} Returns the new array of shared values.\\r\\n */\\r\\n function baseIntersection(arrays, iteratee, comparator) {\\r\\n var includes = comparator ? arrayIncludesWith : arrayIncludes,\\r\\n length = arrays[0].length,\\r\\n othLength = arrays.length,\\r\\n othIndex = othLength,\\r\\n caches = Array(othLength),\\r\\n maxLength = Infinity,\\r\\n result = [];\\r\\n\\r\\n while (othIndex--) {\\r\\n var array = arrays[othIndex];\\r\\n if (othIndex && iteratee) {\\r\\n array = arrayMap(array, baseUnary(iteratee));\\r\\n }\\r\\n maxLength = nativeMin(array.length, maxLength);\\r\\n caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120))\\r\\n ? new SetCache(othIndex && array)\\r\\n : undefined;\\r\\n }\\r\\n array = arrays[0];\\r\\n\\r\\n var index = -1,\\r\\n seen = caches[0];\\r\\n\\r\\n outer:\\r\\n while (++index < length && result.length < maxLength) {\\r\\n var value = array[index],\\r\\n computed = iteratee ? iteratee(value) : value;\\r\\n\\r\\n value = (comparator || value !== 0) ? value : 0;\\r\\n if (!(seen\\r\\n ? cacheHas(seen, computed)\\r\\n : includes(result, computed, comparator)\\r\\n )) {\\r\\n othIndex = othLength;\\r\\n while (--othIndex) {\\r\\n var cache = caches[othIndex];\\r\\n if (!(cache\\r\\n ? cacheHas(cache, computed)\\r\\n : includes(arrays[othIndex], computed, comparator))\\r\\n ) {\\r\\n continue outer;\\r\\n }\\r\\n }\\r\\n if (seen) {\\r\\n seen.push(computed);\\r\\n }\\r\\n result.push(value);\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.invert` and `_.invertBy` which inverts\\r\\n * `object` with values transformed by `iteratee` and set by `setter`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to iterate over.\\r\\n * @param {Function} setter The function to set `accumulator` values.\\r\\n * @param {Function} iteratee The iteratee to transform values.\\r\\n * @param {Object} accumulator The initial inverted object.\\r\\n * @returns {Function} Returns `accumulator`.\\r\\n */\\r\\n function baseInverter(object, setter, iteratee, accumulator) {\\r\\n baseForOwn(object, function(value, key, object) {\\r\\n setter(accumulator, iteratee(value), key, object);\\r\\n });\\r\\n return accumulator;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.invoke` without support for individual\\r\\n * method arguments.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array|string} path The path of the method to invoke.\\r\\n * @param {Array} args The arguments to invoke the method with.\\r\\n * @returns {*} Returns the result of the invoked method.\\r\\n */\\r\\n function baseInvoke(object, path, args) {\\r\\n path = castPath(path, object);\\r\\n object = parent(object, path);\\r\\n var func = object == null ? object : object[toKey(last(path))];\\r\\n return func == null ? undefined : apply(func, object, args);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isArguments`.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\\r\\n */\\r\\n function baseIsArguments(value) {\\r\\n return isObjectLike(value) && baseGetTag(value) == argsTag;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isDate` without Node.js optimizations.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\\r\\n */\\r\\n function baseIsDate(value) {\\r\\n return isObjectLike(value) && baseGetTag(value) == dateTag;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isEqual` which supports partial comparisons\\r\\n * and tracks traversed objects.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to compare.\\r\\n * @param {*} other The other value to compare.\\r\\n * @param {boolean} bitmask The bitmask flags.\\r\\n * 1 - Unordered comparison\\r\\n * 2 - Partial comparison\\r\\n * @param {Function} [customizer] The function to customize comparisons.\\r\\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\\r\\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\\r\\n */\\r\\n function baseIsEqual(value, other, bitmask, customizer, stack) {\\r\\n if (value === other) {\\r\\n return true;\\r\\n }\\r\\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\\r\\n return value !== value && other !== other;\\r\\n }\\r\\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseIsEqual` for arrays and objects which performs\\r\\n * deep comparisons and tracks traversed objects enabling objects with circular\\r\\n * references to be compared.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to compare.\\r\\n * @param {Object} other The other object to compare.\\r\\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\\r\\n * @param {Function} customizer The function to customize comparisons.\\r\\n * @param {Function} equalFunc The function to determine equivalents of values.\\r\\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\\r\\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\\r\\n */\\r\\n function baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\\r\\n var objIsArr = isArray(object),\\r\\n othIsArr = isArray(other),\\r\\n objTag = objIsArr ? arrayTag : getTag(object),\\r\\n othTag = othIsArr ? arrayTag : getTag(other);\\r\\n\\r\\n objTag = objTag == argsTag ? objectTag : objTag;\\r\\n othTag = othTag == argsTag ? objectTag : othTag;\\r\\n\\r\\n var objIsObj = objTag == objectTag,\\r\\n othIsObj = othTag == objectTag,\\r\\n isSameTag = objTag == othTag;\\r\\n\\r\\n if (isSameTag && isBuffer(object)) {\\r\\n if (!isBuffer(other)) {\\r\\n return false;\\r\\n }\\r\\n objIsArr = true;\\r\\n objIsObj = false;\\r\\n }\\r\\n if (isSameTag && !objIsObj) {\\r\\n stack || (stack = new Stack);\\r\\n return (objIsArr || isTypedArray(object))\\r\\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\\r\\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\\r\\n }\\r\\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\\r\\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\\r\\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\\r\\n\\r\\n if (objIsWrapped || othIsWrapped) {\\r\\n var objUnwrapped = objIsWrapped ? object.value() : object,\\r\\n othUnwrapped = othIsWrapped ? other.value() : other;\\r\\n\\r\\n stack || (stack = new Stack);\\r\\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\\r\\n }\\r\\n }\\r\\n if (!isSameTag) {\\r\\n return false;\\r\\n }\\r\\n stack || (stack = new Stack);\\r\\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isMap` without Node.js optimizations.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\\r\\n */\\r\\n function baseIsMap(value) {\\r\\n return isObjectLike(value) && getTag(value) == mapTag;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to inspect.\\r\\n * @param {Object} source The object of property values to match.\\r\\n * @param {Array} matchData The property names, values, and compare flags to match.\\r\\n * @param {Function} [customizer] The function to customize comparisons.\\r\\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\\r\\n */\\r\\n function baseIsMatch(object, source, matchData, customizer) {\\r\\n var index = matchData.length,\\r\\n length = index,\\r\\n noCustomizer = !customizer;\\r\\n\\r\\n if (object == null) {\\r\\n return !length;\\r\\n }\\r\\n object = Object(object);\\r\\n while (index--) {\\r\\n var data = matchData[index];\\r\\n if ((noCustomizer && data[2])\\r\\n ? data[1] !== object[data[0]]\\r\\n : !(data[0] in object)\\r\\n ) {\\r\\n return false;\\r\\n }\\r\\n }\\r\\n while (++index < length) {\\r\\n data = matchData[index];\\r\\n var key = data[0],\\r\\n objValue = object[key],\\r\\n srcValue = data[1];\\r\\n\\r\\n if (noCustomizer && data[2]) {\\r\\n if (objValue === undefined && !(key in object)) {\\r\\n return false;\\r\\n }\\r\\n } else {\\r\\n var stack = new Stack;\\r\\n if (customizer) {\\r\\n var result = customizer(objValue, srcValue, key, object, source, stack);\\r\\n }\\r\\n if (!(result === undefined\\r\\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\\r\\n : result\\r\\n )) {\\r\\n return false;\\r\\n }\\r\\n }\\r\\n }\\r\\n return true;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isNative` without bad shim checks.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a native function,\\r\\n * else `false`.\\r\\n */\\r\\n function baseIsNative(value) {\\r\\n if (!isObject(value) || isMasked(value)) {\\r\\n return false;\\r\\n }\\r\\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\\r\\n return pattern.test(toSource(value));\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isRegExp` without Node.js optimizations.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\\r\\n */\\r\\n function baseIsRegExp(value) {\\r\\n return isObjectLike(value) && baseGetTag(value) == regexpTag;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isSet` without Node.js optimizations.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\\r\\n */\\r\\n function baseIsSet(value) {\\r\\n return isObjectLike(value) && getTag(value) == setTag;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\\r\\n */\\r\\n function baseIsTypedArray(value) {\\r\\n return isObjectLike(value) &&\\r\\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.iteratee`.\\r\\n *\\r\\n * @private\\r\\n * @param {*} [value=_.identity] The value to convert to an iteratee.\\r\\n * @returns {Function} Returns the iteratee.\\r\\n */\\r\\n function baseIteratee(value) {\\r\\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\\r\\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\\r\\n if (typeof value == 'function') {\\r\\n return value;\\r\\n }\\r\\n if (value == null) {\\r\\n return identity;\\r\\n }\\r\\n if (typeof value == 'object') {\\r\\n return isArray(value)\\r\\n ? baseMatchesProperty(value[0], value[1])\\r\\n : baseMatches(value);\\r\\n }\\r\\n return property(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of property names.\\r\\n */\\r\\n function baseKeys(object) {\\r\\n if (!isPrototype(object)) {\\r\\n return nativeKeys(object);\\r\\n }\\r\\n var result = [];\\r\\n for (var key in Object(object)) {\\r\\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\\r\\n result.push(key);\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of property names.\\r\\n */\\r\\n function baseKeysIn(object) {\\r\\n if (!isObject(object)) {\\r\\n return nativeKeysIn(object);\\r\\n }\\r\\n var isProto = isPrototype(object),\\r\\n result = [];\\r\\n\\r\\n for (var key in object) {\\r\\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\\r\\n result.push(key);\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.lt` which doesn't coerce arguments.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to compare.\\r\\n * @param {*} other The other value to compare.\\r\\n * @returns {boolean} Returns `true` if `value` is less than `other`,\\r\\n * else `false`.\\r\\n */\\r\\n function baseLt(value, other) {\\r\\n return value < other;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.map` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} iteratee The function invoked per iteration.\\r\\n * @returns {Array} Returns the new mapped array.\\r\\n */\\r\\n function baseMap(collection, iteratee) {\\r\\n var index = -1,\\r\\n result = isArrayLike(collection) ? Array(collection.length) : [];\\r\\n\\r\\n baseEach(collection, function(value, key, collection) {\\r\\n result[++index] = iteratee(value, key, collection);\\r\\n });\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.matches` which doesn't clone `source`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} source The object of property values to match.\\r\\n * @returns {Function} Returns the new spec function.\\r\\n */\\r\\n function baseMatches(source) {\\r\\n var matchData = getMatchData(source);\\r\\n if (matchData.length == 1 && matchData[0][2]) {\\r\\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\\r\\n }\\r\\n return function(object) {\\r\\n return object === source || baseIsMatch(object, source, matchData);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\\r\\n *\\r\\n * @private\\r\\n * @param {string} path The path of the property to get.\\r\\n * @param {*} srcValue The value to match.\\r\\n * @returns {Function} Returns the new spec function.\\r\\n */\\r\\n function baseMatchesProperty(path, srcValue) {\\r\\n if (isKey(path) && isStrictComparable(srcValue)) {\\r\\n return matchesStrictComparable(toKey(path), srcValue);\\r\\n }\\r\\n return function(object) {\\r\\n var objValue = get(object, path);\\r\\n return (objValue === undefined && objValue === srcValue)\\r\\n ? hasIn(object, path)\\r\\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.merge` without support for multiple sources.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The destination object.\\r\\n * @param {Object} source The source object.\\r\\n * @param {number} srcIndex The index of `source`.\\r\\n * @param {Function} [customizer] The function to customize merged values.\\r\\n * @param {Object} [stack] Tracks traversed source values and their merged\\r\\n * counterparts.\\r\\n */\\r\\n function baseMerge(object, source, srcIndex, customizer, stack) {\\r\\n if (object === source) {\\r\\n return;\\r\\n }\\r\\n baseFor(source, function(srcValue, key) {\\r\\n if (isObject(srcValue)) {\\r\\n stack || (stack = new Stack);\\r\\n baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\\r\\n }\\r\\n else {\\r\\n var newValue = customizer\\r\\n ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\\r\\n : undefined;\\r\\n\\r\\n if (newValue === undefined) {\\r\\n newValue = srcValue;\\r\\n }\\r\\n assignMergeValue(object, key, newValue);\\r\\n }\\r\\n }, keysIn);\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseMerge` for arrays and objects which performs\\r\\n * deep merges and tracks traversed objects enabling objects with circular\\r\\n * references to be merged.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The destination object.\\r\\n * @param {Object} source The source object.\\r\\n * @param {string} key The key of the value to merge.\\r\\n * @param {number} srcIndex The index of `source`.\\r\\n * @param {Function} mergeFunc The function to merge values.\\r\\n * @param {Function} [customizer] The function to customize assigned values.\\r\\n * @param {Object} [stack] Tracks traversed source values and their merged\\r\\n * counterparts.\\r\\n */\\r\\n function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\\r\\n var objValue = safeGet(object, key),\\r\\n srcValue = safeGet(source, key),\\r\\n stacked = stack.get(srcValue);\\r\\n\\r\\n if (stacked) {\\r\\n assignMergeValue(object, key, stacked);\\r\\n return;\\r\\n }\\r\\n var newValue = customizer\\r\\n ? customizer(objValue, srcValue, (key + ''), object, source, stack)\\r\\n : undefined;\\r\\n\\r\\n var isCommon = newValue === undefined;\\r\\n\\r\\n if (isCommon) {\\r\\n var isArr = isArray(srcValue),\\r\\n isBuff = !isArr && isBuffer(srcValue),\\r\\n isTyped = !isArr && !isBuff && isTypedArray(srcValue);\\r\\n\\r\\n newValue = srcValue;\\r\\n if (isArr || isBuff || isTyped) {\\r\\n if (isArray(objValue)) {\\r\\n newValue = objValue;\\r\\n }\\r\\n else if (isArrayLikeObject(objValue)) {\\r\\n newValue = copyArray(objValue);\\r\\n }\\r\\n else if (isBuff) {\\r\\n isCommon = false;\\r\\n newValue = cloneBuffer(srcValue, true);\\r\\n }\\r\\n else if (isTyped) {\\r\\n isCommon = false;\\r\\n newValue = cloneTypedArray(srcValue, true);\\r\\n }\\r\\n else {\\r\\n newValue = [];\\r\\n }\\r\\n }\\r\\n else if (isPlainObject(srcValue) || isArguments(srcValue)) {\\r\\n newValue = objValue;\\r\\n if (isArguments(objValue)) {\\r\\n newValue = toPlainObject(objValue);\\r\\n }\\r\\n else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) {\\r\\n newValue = initCloneObject(srcValue);\\r\\n }\\r\\n }\\r\\n else {\\r\\n isCommon = false;\\r\\n }\\r\\n }\\r\\n if (isCommon) {\\r\\n // Recursively merge objects and arrays (susceptible to call stack limits).\\r\\n stack.set(srcValue, newValue);\\r\\n mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\\r\\n stack['delete'](srcValue);\\r\\n }\\r\\n assignMergeValue(object, key, newValue);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.orderBy` without param guards.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.\\r\\n * @param {string[]} orders The sort orders of `iteratees`.\\r\\n * @returns {Array} Returns the new sorted array.\\r\\n */\\r\\n function baseOrderBy(collection, iteratees, orders) {\\r\\n var index = -1;\\r\\n iteratees = arrayMap(iteratees.length ? iteratees : [identity], baseUnary(baseIteratee));\\r\\n\\r\\n var result = baseMap(collection, function(value, key, collection) {\\r\\n var criteria = arrayMap(iteratees, function(iteratee) {\\r\\n return iteratee(value);\\r\\n });\\r\\n return { 'criteria': criteria, 'index': ++index, 'value': value };\\r\\n });\\r\\n\\r\\n return baseSortBy(result, function(object, other) {\\r\\n return compareMultiple(object, other, orders);\\r\\n });\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.pick` without support for individual\\r\\n * property identifiers.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The source object.\\r\\n * @param {string[]} paths The property paths to pick.\\r\\n * @returns {Object} Returns the new object.\\r\\n */\\r\\n function basePick(object, paths) {\\r\\n return basePickBy(object, paths, function(value, path) {\\r\\n return hasIn(object, path);\\r\\n });\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The source object.\\r\\n * @param {string[]} paths The property paths to pick.\\r\\n * @param {Function} predicate The function invoked per property.\\r\\n * @returns {Object} Returns the new object.\\r\\n */\\r\\n function basePickBy(object, paths, predicate) {\\r\\n var index = -1,\\r\\n length = paths.length,\\r\\n result = {};\\r\\n\\r\\n while (++index < length) {\\r\\n var path = paths[index],\\r\\n value = baseGet(object, path);\\r\\n\\r\\n if (predicate(value, path)) {\\r\\n baseSet(result, castPath(path, object), value);\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseProperty` which supports deep paths.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|string} path The path of the property to get.\\r\\n * @returns {Function} Returns the new accessor function.\\r\\n */\\r\\n function basePropertyDeep(path) {\\r\\n return function(object) {\\r\\n return baseGet(object, path);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.random` without support for returning\\r\\n * floating-point numbers.\\r\\n *\\r\\n * @private\\r\\n * @param {number} lower The lower bound.\\r\\n * @param {number} upper The upper bound.\\r\\n * @returns {number} Returns the random number.\\r\\n */\\r\\n function baseRandom(lower, upper) {\\r\\n return lower + nativeFloor(nativeRandom() * (upper - lower + 1));\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\\r\\n * coerce arguments.\\r\\n *\\r\\n * @private\\r\\n * @param {number} start The start of the range.\\r\\n * @param {number} end The end of the range.\\r\\n * @param {number} step The value to increment or decrement by.\\r\\n * @param {boolean} [fromRight] Specify iterating from right to left.\\r\\n * @returns {Array} Returns the range of numbers.\\r\\n */\\r\\n function baseRange(start, end, step, fromRight) {\\r\\n var index = -1,\\r\\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\\r\\n result = Array(length);\\r\\n\\r\\n while (length--) {\\r\\n result[fromRight ? length : ++index] = start;\\r\\n start += step;\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to apply a rest parameter to.\\r\\n * @param {number} [start=func.length-1] The start position of the rest parameter.\\r\\n * @returns {Function} Returns the new function.\\r\\n */\\r\\n function baseRest(func, start) {\\r\\n return setToString(overRest(func, start, identity), func + '');\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.set`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to modify.\\r\\n * @param {Array|string} path The path of the property to set.\\r\\n * @param {*} value The value to set.\\r\\n * @param {Function} [customizer] The function to customize path creation.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n function baseSet(object, path, value, customizer) {\\r\\n if (!isObject(object)) {\\r\\n return object;\\r\\n }\\r\\n path = castPath(path, object);\\r\\n\\r\\n var index = -1,\\r\\n length = path.length,\\r\\n lastIndex = length - 1,\\r\\n nested = object;\\r\\n\\r\\n while (nested != null && ++index < length) {\\r\\n var key = toKey(path[index]),\\r\\n newValue = value;\\r\\n\\r\\n if (index != lastIndex) {\\r\\n var objValue = nested[key];\\r\\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\\r\\n if (newValue === undefined) {\\r\\n newValue = isObject(objValue)\\r\\n ? objValue\\r\\n : (isIndex(path[index + 1]) ? [] : {});\\r\\n }\\r\\n }\\r\\n assignValue(nested, key, newValue);\\r\\n nested = nested[key];\\r\\n }\\r\\n return object;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `setData` without support for hot loop shorting.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to associate metadata with.\\r\\n * @param {*} data The metadata.\\r\\n * @returns {Function} Returns `func`.\\r\\n */\\r\\n var baseSetData = !metaMap ? identity : function(func, data) {\\r\\n metaMap.set(func, data);\\r\\n return func;\\r\\n };\\r\\n\\r\\n /**\\r\\n * The base implementation of `setToString` without support for hot loop shorting.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to modify.\\r\\n * @param {Function} string The `toString` result.\\r\\n * @returns {Function} Returns `func`.\\r\\n */\\r\\n var baseSetToString = !defineProperty ? identity : function(func, string) {\\r\\n return defineProperty(func, 'toString', {\\r\\n 'configurable': true,\\r\\n 'enumerable': false,\\r\\n 'value': constant(string),\\r\\n 'writable': true\\r\\n });\\r\\n };\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.slice` without an iteratee call guard.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to slice.\\r\\n * @param {number} [start=0] The start position.\\r\\n * @param {number} [end=array.length] The end position.\\r\\n * @returns {Array} Returns the slice of `array`.\\r\\n */\\r\\n function baseSlice(array, start, end) {\\r\\n var index = -1,\\r\\n length = array.length;\\r\\n\\r\\n if (start < 0) {\\r\\n start = -start > length ? 0 : (length + start);\\r\\n }\\r\\n end = end > length ? length : end;\\r\\n if (end < 0) {\\r\\n end += length;\\r\\n }\\r\\n length = start > end ? 0 : ((end - start) >>> 0);\\r\\n start >>>= 0;\\r\\n\\r\\n var result = Array(length);\\r\\n while (++index < length) {\\r\\n result[index] = array[index + start];\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.some` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} predicate The function invoked per iteration.\\r\\n * @returns {boolean} Returns `true` if any element passes the predicate check,\\r\\n * else `false`.\\r\\n */\\r\\n function baseSome(collection, predicate) {\\r\\n var result;\\r\\n\\r\\n baseEach(collection, function(value, index, collection) {\\r\\n result = predicate(value, index, collection);\\r\\n return !result;\\r\\n });\\r\\n return !!result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.toString` which doesn't convert nullish\\r\\n * values to empty strings.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to process.\\r\\n * @returns {string} Returns the string.\\r\\n */\\r\\n function baseToString(value) {\\r\\n // Exit early for strings to avoid a performance hit in some environments.\\r\\n if (typeof value == 'string') {\\r\\n return value;\\r\\n }\\r\\n if (isArray(value)) {\\r\\n // Recursively convert values (susceptible to call stack limits).\\r\\n return arrayMap(value, baseToString) + '';\\r\\n }\\r\\n if (isSymbol(value)) {\\r\\n return symbolToString ? symbolToString.call(value) : '';\\r\\n }\\r\\n var result = (value + '');\\r\\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {Function} [iteratee] The iteratee invoked per element.\\r\\n * @param {Function} [comparator] The comparator invoked per element.\\r\\n * @returns {Array} Returns the new duplicate free array.\\r\\n */\\r\\n function baseUniq(array, iteratee, comparator) {\\r\\n var index = -1,\\r\\n includes = arrayIncludes,\\r\\n length = array.length,\\r\\n isCommon = true,\\r\\n result = [],\\r\\n seen = result;\\r\\n\\r\\n if (comparator) {\\r\\n isCommon = false;\\r\\n includes = arrayIncludesWith;\\r\\n }\\r\\n else if (length >= LARGE_ARRAY_SIZE) {\\r\\n var set = iteratee ? null : createSet(array);\\r\\n if (set) {\\r\\n return setToArray(set);\\r\\n }\\r\\n isCommon = false;\\r\\n includes = cacheHas;\\r\\n seen = new SetCache;\\r\\n }\\r\\n else {\\r\\n seen = iteratee ? [] : result;\\r\\n }\\r\\n outer:\\r\\n while (++index < length) {\\r\\n var value = array[index],\\r\\n computed = iteratee ? iteratee(value) : value;\\r\\n\\r\\n value = (comparator || value !== 0) ? value : 0;\\r\\n if (isCommon && computed === computed) {\\r\\n var seenIndex = seen.length;\\r\\n while (seenIndex--) {\\r\\n if (seen[seenIndex] === computed) {\\r\\n continue outer;\\r\\n }\\r\\n }\\r\\n if (iteratee) {\\r\\n seen.push(computed);\\r\\n }\\r\\n result.push(value);\\r\\n }\\r\\n else if (!includes(seen, computed, comparator)) {\\r\\n if (seen !== result) {\\r\\n seen.push(computed);\\r\\n }\\r\\n result.push(value);\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `_.unset`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to modify.\\r\\n * @param {Array|string} path The property path to unset.\\r\\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\\r\\n */\\r\\n function baseUnset(object, path) {\\r\\n path = castPath(path, object);\\r\\n object = parent(object, path);\\r\\n return object == null || delete object[toKey(last(path))];\\r\\n }\\r\\n\\r\\n /**\\r\\n * The base implementation of `wrapperValue` which returns the result of\\r\\n * performing a sequence of actions on the unwrapped `value`, where each\\r\\n * successive action is supplied the return value of the previous.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The unwrapped value.\\r\\n * @param {Array} actions Actions to perform to resolve the unwrapped value.\\r\\n * @returns {*} Returns the resolved value.\\r\\n */\\r\\n function baseWrapperValue(value, actions) {\\r\\n var result = value;\\r\\n if (result instanceof LazyWrapper) {\\r\\n result = result.value();\\r\\n }\\r\\n return arrayReduce(actions, function(result, action) {\\r\\n return action.func.apply(action.thisArg, arrayPush([result], action.args));\\r\\n }, result);\\r\\n }\\r\\n\\r\\n /**\\r\\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} props The property identifiers.\\r\\n * @param {Array} values The property values.\\r\\n * @param {Function} assignFunc The function to assign values.\\r\\n * @returns {Object} Returns the new object.\\r\\n */\\r\\n function baseZipObject(props, values, assignFunc) {\\r\\n var index = -1,\\r\\n length = props.length,\\r\\n valsLength = values.length,\\r\\n result = {};\\r\\n\\r\\n while (++index < length) {\\r\\n var value = index < valsLength ? values[index] : undefined;\\r\\n assignFunc(result, props[index], value);\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Casts `value` to an empty array if it's not an array like object.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to inspect.\\r\\n * @returns {Array|Object} Returns the cast array-like object.\\r\\n */\\r\\n function castArrayLikeObject(value) {\\r\\n return isArrayLikeObject(value) ? value : [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Casts `value` to a path array if it's not one.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to inspect.\\r\\n * @param {Object} [object] The object to query keys on.\\r\\n * @returns {Array} Returns the cast property path array.\\r\\n */\\r\\n function castPath(value, object) {\\r\\n if (isArray(value)) {\\r\\n return value;\\r\\n }\\r\\n return isKey(value, object) ? [value] : stringToPath(toString(value));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Casts `array` to a slice if it's needed.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {number} start The start position.\\r\\n * @param {number} [end=array.length] The end position.\\r\\n * @returns {Array} Returns the cast slice.\\r\\n */\\r\\n function castSlice(array, start, end) {\\r\\n var length = array.length;\\r\\n end = end === undefined ? length : end;\\r\\n return (!start && end >= length) ? array : baseSlice(array, start, end);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of `buffer`.\\r\\n *\\r\\n * @private\\r\\n * @param {Buffer} buffer The buffer to clone.\\r\\n * @param {boolean} [isDeep] Specify a deep clone.\\r\\n * @returns {Buffer} Returns the cloned buffer.\\r\\n */\\r\\n function cloneBuffer(buffer, isDeep) {\\r\\n if (isDeep) {\\r\\n return buffer.slice();\\r\\n }\\r\\n var length = buffer.length,\\r\\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\\r\\n\\r\\n buffer.copy(result);\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of `arrayBuffer`.\\r\\n *\\r\\n * @private\\r\\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\\r\\n * @returns {ArrayBuffer} Returns the cloned array buffer.\\r\\n */\\r\\n function cloneArrayBuffer(arrayBuffer) {\\r\\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\\r\\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of `dataView`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} dataView The data view to clone.\\r\\n * @param {boolean} [isDeep] Specify a deep clone.\\r\\n * @returns {Object} Returns the cloned data view.\\r\\n */\\r\\n function cloneDataView(dataView, isDeep) {\\r\\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\\r\\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of `regexp`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} regexp The regexp to clone.\\r\\n * @returns {Object} Returns the cloned regexp.\\r\\n */\\r\\n function cloneRegExp(regexp) {\\r\\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\\r\\n result.lastIndex = regexp.lastIndex;\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of the `symbol` object.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} symbol The symbol object to clone.\\r\\n * @returns {Object} Returns the cloned symbol object.\\r\\n */\\r\\n function cloneSymbol(symbol) {\\r\\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of `typedArray`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} typedArray The typed array to clone.\\r\\n * @param {boolean} [isDeep] Specify a deep clone.\\r\\n * @returns {Object} Returns the cloned typed array.\\r\\n */\\r\\n function cloneTypedArray(typedArray, isDeep) {\\r\\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\\r\\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Compares values to sort them in ascending order.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to compare.\\r\\n * @param {*} other The other value to compare.\\r\\n * @returns {number} Returns the sort order indicator for `value`.\\r\\n */\\r\\n function compareAscending(value, other) {\\r\\n if (value !== other) {\\r\\n var valIsDefined = value !== undefined,\\r\\n valIsNull = value === null,\\r\\n valIsReflexive = value === value,\\r\\n valIsSymbol = isSymbol(value);\\r\\n\\r\\n var othIsDefined = other !== undefined,\\r\\n othIsNull = other === null,\\r\\n othIsReflexive = other === other,\\r\\n othIsSymbol = isSymbol(other);\\r\\n\\r\\n if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) ||\\r\\n (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) ||\\r\\n (valIsNull && othIsDefined && othIsReflexive) ||\\r\\n (!valIsDefined && othIsReflexive) ||\\r\\n !valIsReflexive) {\\r\\n return 1;\\r\\n }\\r\\n if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) ||\\r\\n (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) ||\\r\\n (othIsNull && valIsDefined && valIsReflexive) ||\\r\\n (!othIsDefined && valIsReflexive) ||\\r\\n !othIsReflexive) {\\r\\n return -1;\\r\\n }\\r\\n }\\r\\n return 0;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Used by `_.orderBy` to compare multiple properties of a value to another\\r\\n * and stable sort them.\\r\\n *\\r\\n * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,\\r\\n * specify an order of \\\"desc\\\" for descending or \\\"asc\\\" for ascending sort order\\r\\n * of corresponding values.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to compare.\\r\\n * @param {Object} other The other object to compare.\\r\\n * @param {boolean[]|string[]} orders The order to sort by for each property.\\r\\n * @returns {number} Returns the sort order indicator for `object`.\\r\\n */\\r\\n function compareMultiple(object, other, orders) {\\r\\n var index = -1,\\r\\n objCriteria = object.criteria,\\r\\n othCriteria = other.criteria,\\r\\n length = objCriteria.length,\\r\\n ordersLength = orders.length;\\r\\n\\r\\n while (++index < length) {\\r\\n var result = compareAscending(objCriteria[index], othCriteria[index]);\\r\\n if (result) {\\r\\n if (index >= ordersLength) {\\r\\n return result;\\r\\n }\\r\\n var order = orders[index];\\r\\n return result * (order == 'desc' ? -1 : 1);\\r\\n }\\r\\n }\\r\\n // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications\\r\\n // that causes it, under certain circumstances, to provide the same value for\\r\\n // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247\\r\\n // for more details.\\r\\n //\\r\\n // This also ensures a stable sort in V8 and other engines.\\r\\n // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\\r\\n return object.index - other.index;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array that is the composition of partially applied arguments,\\r\\n * placeholders, and provided arguments into a single array of arguments.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} args The provided arguments.\\r\\n * @param {Array} partials The arguments to prepend to those provided.\\r\\n * @param {Array} holders The `partials` placeholder indexes.\\r\\n * @params {boolean} [isCurried] Specify composing for a curried function.\\r\\n * @returns {Array} Returns the new array of composed arguments.\\r\\n */\\r\\n function composeArgs(args, partials, holders, isCurried) {\\r\\n var argsIndex = -1,\\r\\n argsLength = args.length,\\r\\n holdersLength = holders.length,\\r\\n leftIndex = -1,\\r\\n leftLength = partials.length,\\r\\n rangeLength = nativeMax(argsLength - holdersLength, 0),\\r\\n result = Array(leftLength + rangeLength),\\r\\n isUncurried = !isCurried;\\r\\n\\r\\n while (++leftIndex < leftLength) {\\r\\n result[leftIndex] = partials[leftIndex];\\r\\n }\\r\\n while (++argsIndex < holdersLength) {\\r\\n if (isUncurried || argsIndex < argsLength) {\\r\\n result[holders[argsIndex]] = args[argsIndex];\\r\\n }\\r\\n }\\r\\n while (rangeLength--) {\\r\\n result[leftIndex++] = args[argsIndex++];\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * This function is like `composeArgs` except that the arguments composition\\r\\n * is tailored for `_.partialRight`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} args The provided arguments.\\r\\n * @param {Array} partials The arguments to append to those provided.\\r\\n * @param {Array} holders The `partials` placeholder indexes.\\r\\n * @params {boolean} [isCurried] Specify composing for a curried function.\\r\\n * @returns {Array} Returns the new array of composed arguments.\\r\\n */\\r\\n function composeArgsRight(args, partials, holders, isCurried) {\\r\\n var argsIndex = -1,\\r\\n argsLength = args.length,\\r\\n holdersIndex = -1,\\r\\n holdersLength = holders.length,\\r\\n rightIndex = -1,\\r\\n rightLength = partials.length,\\r\\n rangeLength = nativeMax(argsLength - holdersLength, 0),\\r\\n result = Array(rangeLength + rightLength),\\r\\n isUncurried = !isCurried;\\r\\n\\r\\n while (++argsIndex < rangeLength) {\\r\\n result[argsIndex] = args[argsIndex];\\r\\n }\\r\\n var offset = argsIndex;\\r\\n while (++rightIndex < rightLength) {\\r\\n result[offset + rightIndex] = partials[rightIndex];\\r\\n }\\r\\n while (++holdersIndex < holdersLength) {\\r\\n if (isUncurried || argsIndex < argsLength) {\\r\\n result[offset + holders[holdersIndex]] = args[argsIndex++];\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Copies the values of `source` to `array`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} source The array to copy values from.\\r\\n * @param {Array} [array=[]] The array to copy values to.\\r\\n * @returns {Array} Returns `array`.\\r\\n */\\r\\n function copyArray(source, array) {\\r\\n var index = -1,\\r\\n length = source.length;\\r\\n\\r\\n array || (array = Array(length));\\r\\n while (++index < length) {\\r\\n array[index] = source[index];\\r\\n }\\r\\n return array;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Copies properties of `source` to `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} source The object to copy properties from.\\r\\n * @param {Array} props The property identifiers to copy.\\r\\n * @param {Object} [object={}] The object to copy properties to.\\r\\n * @param {Function} [customizer] The function to customize copied values.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n function copyObject(source, props, object, customizer) {\\r\\n var isNew = !object;\\r\\n object || (object = {});\\r\\n\\r\\n var index = -1,\\r\\n length = props.length;\\r\\n\\r\\n while (++index < length) {\\r\\n var key = props[index];\\r\\n\\r\\n var newValue = customizer\\r\\n ? customizer(object[key], source[key], key, object, source)\\r\\n : undefined;\\r\\n\\r\\n if (newValue === undefined) {\\r\\n newValue = source[key];\\r\\n }\\r\\n if (isNew) {\\r\\n baseAssignValue(object, key, newValue);\\r\\n } else {\\r\\n assignValue(object, key, newValue);\\r\\n }\\r\\n }\\r\\n return object;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Copies own symbols of `source` to `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} source The object to copy symbols from.\\r\\n * @param {Object} [object={}] The object to copy symbols to.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n function copySymbols(source, object) {\\r\\n return copyObject(source, getSymbols(source), object);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Copies own and inherited symbols of `source` to `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} source The object to copy symbols from.\\r\\n * @param {Object} [object={}] The object to copy symbols to.\\r\\n * @returns {Object} Returns `object`.\\r\\n */\\r\\n function copySymbolsIn(source, object) {\\r\\n return copyObject(source, getSymbolsIn(source), object);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function like `_.groupBy`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} setter The function to set accumulator values.\\r\\n * @param {Function} [initializer] The accumulator object initializer.\\r\\n * @returns {Function} Returns the new aggregator function.\\r\\n */\\r\\n function createAggregator(setter, initializer) {\\r\\n return function(collection, iteratee) {\\r\\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\\r\\n accumulator = initializer ? initializer() : {};\\r\\n\\r\\n return func(collection, setter, baseIteratee(iteratee, 2), accumulator);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function like `_.assign`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} assigner The function to assign values.\\r\\n * @returns {Function} Returns the new assigner function.\\r\\n */\\r\\n function createAssigner(assigner) {\\r\\n return baseRest(function(object, sources) {\\r\\n var index = -1,\\r\\n length = sources.length,\\r\\n customizer = length > 1 ? sources[length - 1] : undefined,\\r\\n guard = length > 2 ? sources[2] : undefined;\\r\\n\\r\\n customizer = (assigner.length > 3 && typeof customizer == 'function')\\r\\n ? (length--, customizer)\\r\\n : undefined;\\r\\n\\r\\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\\r\\n customizer = length < 3 ? undefined : customizer;\\r\\n length = 1;\\r\\n }\\r\\n object = Object(object);\\r\\n while (++index < length) {\\r\\n var source = sources[index];\\r\\n if (source) {\\r\\n assigner(object, source, index, customizer);\\r\\n }\\r\\n }\\r\\n return object;\\r\\n });\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a `baseEach` or `baseEachRight` function.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} eachFunc The function to iterate over a collection.\\r\\n * @param {boolean} [fromRight] Specify iterating from right to left.\\r\\n * @returns {Function} Returns the new base function.\\r\\n */\\r\\n function createBaseEach(eachFunc, fromRight) {\\r\\n return function(collection, iteratee) {\\r\\n if (collection == null) {\\r\\n return collection;\\r\\n }\\r\\n if (!isArrayLike(collection)) {\\r\\n return eachFunc(collection, iteratee);\\r\\n }\\r\\n var length = collection.length,\\r\\n index = fromRight ? length : -1,\\r\\n iterable = Object(collection);\\r\\n\\r\\n while ((fromRight ? index-- : ++index < length)) {\\r\\n if (iteratee(iterable[index], index, iterable) === false) {\\r\\n break;\\r\\n }\\r\\n }\\r\\n return collection;\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\\r\\n *\\r\\n * @private\\r\\n * @param {boolean} [fromRight] Specify iterating from right to left.\\r\\n * @returns {Function} Returns the new base function.\\r\\n */\\r\\n function createBaseFor(fromRight) {\\r\\n return function(object, iteratee, keysFunc) {\\r\\n var index = -1,\\r\\n iterable = Object(object),\\r\\n props = keysFunc(object),\\r\\n length = props.length;\\r\\n\\r\\n while (length--) {\\r\\n var key = props[fromRight ? length : ++index];\\r\\n if (iteratee(iterable[key], key, iterable) === false) {\\r\\n break;\\r\\n }\\r\\n }\\r\\n return object;\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that wraps `func` to invoke it with the optional `this`\\r\\n * binding of `thisArg`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to wrap.\\r\\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\\r\\n * @param {*} [thisArg] The `this` binding of `func`.\\r\\n * @returns {Function} Returns the new wrapped function.\\r\\n */\\r\\n function createBind(func, bitmask, thisArg) {\\r\\n var isBind = bitmask & WRAP_BIND_FLAG,\\r\\n Ctor = createCtor(func);\\r\\n\\r\\n function wrapper() {\\r\\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\\r\\n return fn.apply(isBind ? thisArg : this, arguments);\\r\\n }\\r\\n return wrapper;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that produces an instance of `Ctor` regardless of\\r\\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} Ctor The constructor to wrap.\\r\\n * @returns {Function} Returns the new wrapped function.\\r\\n */\\r\\n function createCtor(Ctor) {\\r\\n return function() {\\r\\n // Use a `switch` statement to work with class constructors. See\\r\\n // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\\r\\n // for more details.\\r\\n var args = arguments;\\r\\n switch (args.length) {\\r\\n case 0: return new Ctor;\\r\\n case 1: return new Ctor(args[0]);\\r\\n case 2: return new Ctor(args[0], args[1]);\\r\\n case 3: return new Ctor(args[0], args[1], args[2]);\\r\\n case 4: return new Ctor(args[0], args[1], args[2], args[3]);\\r\\n case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\\r\\n case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\\r\\n case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\\r\\n }\\r\\n var thisBinding = baseCreate(Ctor.prototype),\\r\\n result = Ctor.apply(thisBinding, args);\\r\\n\\r\\n // Mimic the constructor's `return` behavior.\\r\\n // See https://es5.github.io/#x13.2.2 for more details.\\r\\n return isObject(result) ? result : thisBinding;\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that wraps `func` to enable currying.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to wrap.\\r\\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\\r\\n * @param {number} arity The arity of `func`.\\r\\n * @returns {Function} Returns the new wrapped function.\\r\\n */\\r\\n function createCurry(func, bitmask, arity) {\\r\\n var Ctor = createCtor(func);\\r\\n\\r\\n function wrapper() {\\r\\n var length = arguments.length,\\r\\n args = Array(length),\\r\\n index = length,\\r\\n placeholder = getHolder(wrapper);\\r\\n\\r\\n while (index--) {\\r\\n args[index] = arguments[index];\\r\\n }\\r\\n var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder)\\r\\n ? []\\r\\n : replaceHolders(args, placeholder);\\r\\n\\r\\n length -= holders.length;\\r\\n if (length < arity) {\\r\\n return createRecurry(\\r\\n func, bitmask, createHybrid, wrapper.placeholder, undefined,\\r\\n args, holders, undefined, undefined, arity - length);\\r\\n }\\r\\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\\r\\n return apply(fn, this, args);\\r\\n }\\r\\n return wrapper;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a `_.find` or `_.findLast` function.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} findIndexFunc The function to find the collection index.\\r\\n * @returns {Function} Returns the new find function.\\r\\n */\\r\\n function createFind(findIndexFunc) {\\r\\n return function(collection, predicate, fromIndex) {\\r\\n var iterable = Object(collection);\\r\\n if (!isArrayLike(collection)) {\\r\\n var iteratee = baseIteratee(predicate, 3);\\r\\n collection = keys(collection);\\r\\n predicate = function(key) { return iteratee(iterable[key], key, iterable); };\\r\\n }\\r\\n var index = findIndexFunc(collection, predicate, fromIndex);\\r\\n return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that wraps `func` to invoke it with optional `this`\\r\\n * binding of `thisArg`, partial application, and currying.\\r\\n *\\r\\n * @private\\r\\n * @param {Function|string} func The function or method name to wrap.\\r\\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\\r\\n * @param {*} [thisArg] The `this` binding of `func`.\\r\\n * @param {Array} [partials] The arguments to prepend to those provided to\\r\\n * the new function.\\r\\n * @param {Array} [holders] The `partials` placeholder indexes.\\r\\n * @param {Array} [partialsRight] The arguments to append to those provided\\r\\n * to the new function.\\r\\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\\r\\n * @param {Array} [argPos] The argument positions of the new function.\\r\\n * @param {number} [ary] The arity cap of `func`.\\r\\n * @param {number} [arity] The arity of `func`.\\r\\n * @returns {Function} Returns the new wrapped function.\\r\\n */\\r\\n function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\\r\\n var isAry = bitmask & WRAP_ARY_FLAG,\\r\\n isBind = bitmask & WRAP_BIND_FLAG,\\r\\n isBindKey = bitmask & WRAP_BIND_KEY_FLAG,\\r\\n isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG),\\r\\n isFlip = bitmask & WRAP_FLIP_FLAG,\\r\\n Ctor = isBindKey ? undefined : createCtor(func);\\r\\n\\r\\n function wrapper() {\\r\\n var length = arguments.length,\\r\\n args = Array(length),\\r\\n index = length;\\r\\n\\r\\n while (index--) {\\r\\n args[index] = arguments[index];\\r\\n }\\r\\n if (isCurried) {\\r\\n var placeholder = getHolder(wrapper),\\r\\n holdersCount = countHolders(args, placeholder);\\r\\n }\\r\\n if (partials) {\\r\\n args = composeArgs(args, partials, holders, isCurried);\\r\\n }\\r\\n if (partialsRight) {\\r\\n args = composeArgsRight(args, partialsRight, holdersRight, isCurried);\\r\\n }\\r\\n length -= holdersCount;\\r\\n if (isCurried && length < arity) {\\r\\n var newHolders = replaceHolders(args, placeholder);\\r\\n return createRecurry(\\r\\n func, bitmask, createHybrid, wrapper.placeholder, thisArg,\\r\\n args, newHolders, argPos, ary, arity - length\\r\\n );\\r\\n }\\r\\n var thisBinding = isBind ? thisArg : this,\\r\\n fn = isBindKey ? thisBinding[func] : func;\\r\\n\\r\\n length = args.length;\\r\\n if (argPos) {\\r\\n args = reorder(args, argPos);\\r\\n } else if (isFlip && length > 1) {\\r\\n args.reverse();\\r\\n }\\r\\n if (isAry && ary < length) {\\r\\n args.length = ary;\\r\\n }\\r\\n if (this && this !== root && this instanceof wrapper) {\\r\\n fn = Ctor || createCtor(fn);\\r\\n }\\r\\n return fn.apply(thisBinding, args);\\r\\n }\\r\\n return wrapper;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function like `_.invertBy`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} setter The function to set accumulator values.\\r\\n * @param {Function} toIteratee The function to resolve iteratees.\\r\\n * @returns {Function} Returns the new inverter function.\\r\\n */\\r\\n function createInverter(setter, toIteratee) {\\r\\n return function(object, iteratee) {\\r\\n return baseInverter(object, setter, toIteratee(iteratee), {});\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that wraps `func` to invoke it with the `this` binding\\r\\n * of `thisArg` and `partials` prepended to the arguments it receives.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to wrap.\\r\\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\\r\\n * @param {*} thisArg The `this` binding of `func`.\\r\\n * @param {Array} partials The arguments to prepend to those provided to\\r\\n * the new function.\\r\\n * @returns {Function} Returns the new wrapped function.\\r\\n */\\r\\n function createPartial(func, bitmask, thisArg, partials) {\\r\\n var isBind = bitmask & WRAP_BIND_FLAG,\\r\\n Ctor = createCtor(func);\\r\\n\\r\\n function wrapper() {\\r\\n var argsIndex = -1,\\r\\n argsLength = arguments.length,\\r\\n leftIndex = -1,\\r\\n leftLength = partials.length,\\r\\n args = Array(leftLength + argsLength),\\r\\n fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\\r\\n\\r\\n while (++leftIndex < leftLength) {\\r\\n args[leftIndex] = partials[leftIndex];\\r\\n }\\r\\n while (argsLength--) {\\r\\n args[leftIndex++] = arguments[++argsIndex];\\r\\n }\\r\\n return apply(fn, isBind ? thisArg : this, args);\\r\\n }\\r\\n return wrapper;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a `_.range` or `_.rangeRight` function.\\r\\n *\\r\\n * @private\\r\\n * @param {boolean} [fromRight] Specify iterating from right to left.\\r\\n * @returns {Function} Returns the new range function.\\r\\n */\\r\\n function createRange(fromRight) {\\r\\n return function(start, end, step) {\\r\\n if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\\r\\n end = step = undefined;\\r\\n }\\r\\n // Ensure the sign of `-0` is preserved.\\r\\n start = toFinite(start);\\r\\n if (end === undefined) {\\r\\n end = start;\\r\\n start = 0;\\r\\n } else {\\r\\n end = toFinite(end);\\r\\n }\\r\\n step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\\r\\n return baseRange(start, end, step, fromRight);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that wraps `func` to continue currying.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to wrap.\\r\\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\\r\\n * @param {Function} wrapFunc The function to create the `func` wrapper.\\r\\n * @param {*} placeholder The placeholder value.\\r\\n * @param {*} [thisArg] The `this` binding of `func`.\\r\\n * @param {Array} [partials] The arguments to prepend to those provided to\\r\\n * the new function.\\r\\n * @param {Array} [holders] The `partials` placeholder indexes.\\r\\n * @param {Array} [argPos] The argument positions of the new function.\\r\\n * @param {number} [ary] The arity cap of `func`.\\r\\n * @param {number} [arity] The arity of `func`.\\r\\n * @returns {Function} Returns the new wrapped function.\\r\\n */\\r\\n function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) {\\r\\n var isCurry = bitmask & WRAP_CURRY_FLAG,\\r\\n newHolders = isCurry ? holders : undefined,\\r\\n newHoldersRight = isCurry ? undefined : holders,\\r\\n newPartials = isCurry ? partials : undefined,\\r\\n newPartialsRight = isCurry ? undefined : partials;\\r\\n\\r\\n bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG);\\r\\n bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG);\\r\\n\\r\\n if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) {\\r\\n bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG);\\r\\n }\\r\\n var newData = [\\r\\n func, bitmask, thisArg, newPartials, newHolders, newPartialsRight,\\r\\n newHoldersRight, argPos, ary, arity\\r\\n ];\\r\\n\\r\\n var result = wrapFunc.apply(undefined, newData);\\r\\n if (isLaziable(func)) {\\r\\n setData(result, newData);\\r\\n }\\r\\n result.placeholder = placeholder;\\r\\n return setWrapToString(result, func, bitmask);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a set object of `values`.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} values The values to add to the set.\\r\\n * @returns {Object} Returns the new set.\\r\\n */\\r\\n var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\\r\\n return new Set(values);\\r\\n };\\r\\n\\r\\n /**\\r\\n * Creates a function that either curries or invokes `func` with optional\\r\\n * `this` binding and partially applied arguments.\\r\\n *\\r\\n * @private\\r\\n * @param {Function|string} func The function or method name to wrap.\\r\\n * @param {number} bitmask The bitmask flags.\\r\\n * 1 - `_.bind`\\r\\n * 2 - `_.bindKey`\\r\\n * 4 - `_.curry` or `_.curryRight` of a bound function\\r\\n * 8 - `_.curry`\\r\\n * 16 - `_.curryRight`\\r\\n * 32 - `_.partial`\\r\\n * 64 - `_.partialRight`\\r\\n * 128 - `_.rearg`\\r\\n * 256 - `_.ary`\\r\\n * 512 - `_.flip`\\r\\n * @param {*} [thisArg] The `this` binding of `func`.\\r\\n * @param {Array} [partials] The arguments to be partially applied.\\r\\n * @param {Array} [holders] The `partials` placeholder indexes.\\r\\n * @param {Array} [argPos] The argument positions of the new function.\\r\\n * @param {number} [ary] The arity cap of `func`.\\r\\n * @param {number} [arity] The arity of `func`.\\r\\n * @returns {Function} Returns the new wrapped function.\\r\\n */\\r\\n function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\\r\\n var isBindKey = bitmask & WRAP_BIND_KEY_FLAG;\\r\\n if (!isBindKey && typeof func != 'function') {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n var length = partials ? partials.length : 0;\\r\\n if (!length) {\\r\\n bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG);\\r\\n partials = holders = undefined;\\r\\n }\\r\\n ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0);\\r\\n arity = arity === undefined ? arity : toInteger(arity);\\r\\n length -= holders ? holders.length : 0;\\r\\n\\r\\n if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) {\\r\\n var partialsRight = partials,\\r\\n holdersRight = holders;\\r\\n\\r\\n partials = holders = undefined;\\r\\n }\\r\\n var data = isBindKey ? undefined : getData(func);\\r\\n\\r\\n var newData = [\\r\\n func, bitmask, thisArg, partials, holders, partialsRight, holdersRight,\\r\\n argPos, ary, arity\\r\\n ];\\r\\n\\r\\n if (data) {\\r\\n mergeData(newData, data);\\r\\n }\\r\\n func = newData[0];\\r\\n bitmask = newData[1];\\r\\n thisArg = newData[2];\\r\\n partials = newData[3];\\r\\n holders = newData[4];\\r\\n arity = newData[9] = newData[9] === undefined\\r\\n ? (isBindKey ? 0 : func.length)\\r\\n : nativeMax(newData[9] - length, 0);\\r\\n\\r\\n if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) {\\r\\n bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG);\\r\\n }\\r\\n if (!bitmask || bitmask == WRAP_BIND_FLAG) {\\r\\n var result = createBind(func, bitmask, thisArg);\\r\\n } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) {\\r\\n result = createCurry(func, bitmask, arity);\\r\\n } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) {\\r\\n result = createPartial(func, bitmask, thisArg, partials);\\r\\n } else {\\r\\n result = createHybrid.apply(undefined, newData);\\r\\n }\\r\\n var setter = data ? baseSetData : setData;\\r\\n return setWrapToString(setter(result, newData), func, bitmask);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source\\r\\n * objects into destination objects that are passed thru.\\r\\n *\\r\\n * @private\\r\\n * @param {*} objValue The destination value.\\r\\n * @param {*} srcValue The source value.\\r\\n * @param {string} key The key of the property to merge.\\r\\n * @param {Object} object The parent object of `objValue`.\\r\\n * @param {Object} source The parent object of `srcValue`.\\r\\n * @param {Object} [stack] Tracks traversed source values and their merged\\r\\n * counterparts.\\r\\n * @returns {*} Returns the value to assign.\\r\\n */\\r\\n function customDefaultsMerge(objValue, srcValue, key, object, source, stack) {\\r\\n if (isObject(objValue) && isObject(srcValue)) {\\r\\n // Recursively merge objects and arrays (susceptible to call stack limits).\\r\\n stack.set(srcValue, objValue);\\r\\n baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack);\\r\\n stack['delete'](srcValue);\\r\\n }\\r\\n return objValue;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain\\r\\n * objects.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to inspect.\\r\\n * @param {string} key The key of the property to inspect.\\r\\n * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.\\r\\n */\\r\\n function customOmitClone(value) {\\r\\n return isPlainObject(value) ? undefined : value;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseIsEqualDeep` for arrays with support for\\r\\n * partial deep comparisons.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to compare.\\r\\n * @param {Array} other The other array to compare.\\r\\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\\r\\n * @param {Function} customizer The function to customize comparisons.\\r\\n * @param {Function} equalFunc The function to determine equivalents of values.\\r\\n * @param {Object} stack Tracks traversed `array` and `other` objects.\\r\\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\\r\\n */\\r\\n function equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\\r\\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\\r\\n arrLength = array.length,\\r\\n othLength = other.length;\\r\\n\\r\\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\\r\\n return false;\\r\\n }\\r\\n // Assume cyclic values are equal.\\r\\n var stacked = stack.get(array);\\r\\n if (stacked && stack.get(other)) {\\r\\n return stacked == other;\\r\\n }\\r\\n var index = -1,\\r\\n result = true,\\r\\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\\r\\n\\r\\n stack.set(array, other);\\r\\n stack.set(other, array);\\r\\n\\r\\n // Ignore non-index properties.\\r\\n while (++index < arrLength) {\\r\\n var arrValue = array[index],\\r\\n othValue = other[index];\\r\\n\\r\\n if (customizer) {\\r\\n var compared = isPartial\\r\\n ? customizer(othValue, arrValue, index, other, array, stack)\\r\\n : customizer(arrValue, othValue, index, array, other, stack);\\r\\n }\\r\\n if (compared !== undefined) {\\r\\n if (compared) {\\r\\n continue;\\r\\n }\\r\\n result = false;\\r\\n break;\\r\\n }\\r\\n // Recursively compare arrays (susceptible to call stack limits).\\r\\n if (seen) {\\r\\n if (!arraySome(other, function(othValue, othIndex) {\\r\\n if (!cacheHas(seen, othIndex) &&\\r\\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\\r\\n return seen.push(othIndex);\\r\\n }\\r\\n })) {\\r\\n result = false;\\r\\n break;\\r\\n }\\r\\n } else if (!(\\r\\n arrValue === othValue ||\\r\\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\\r\\n )) {\\r\\n result = false;\\r\\n break;\\r\\n }\\r\\n }\\r\\n stack['delete'](array);\\r\\n stack['delete'](other);\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseIsEqualDeep` for comparing objects of\\r\\n * the same `toStringTag`.\\r\\n *\\r\\n * **Note:** This function only supports comparing values with tags of\\r\\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to compare.\\r\\n * @param {Object} other The other object to compare.\\r\\n * @param {string} tag The `toStringTag` of the objects to compare.\\r\\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\\r\\n * @param {Function} customizer The function to customize comparisons.\\r\\n * @param {Function} equalFunc The function to determine equivalents of values.\\r\\n * @param {Object} stack Tracks traversed `object` and `other` objects.\\r\\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\\r\\n */\\r\\n function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\\r\\n switch (tag) {\\r\\n case dataViewTag:\\r\\n if ((object.byteLength != other.byteLength) ||\\r\\n (object.byteOffset != other.byteOffset)) {\\r\\n return false;\\r\\n }\\r\\n object = object.buffer;\\r\\n other = other.buffer;\\r\\n\\r\\n case arrayBufferTag:\\r\\n if ((object.byteLength != other.byteLength) ||\\r\\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\\r\\n return false;\\r\\n }\\r\\n return true;\\r\\n\\r\\n case boolTag:\\r\\n case dateTag:\\r\\n case numberTag:\\r\\n // Coerce booleans to `1` or `0` and dates to milliseconds.\\r\\n // Invalid dates are coerced to `NaN`.\\r\\n return eq(+object, +other);\\r\\n\\r\\n case errorTag:\\r\\n return object.name == other.name && object.message == other.message;\\r\\n\\r\\n case regexpTag:\\r\\n case stringTag:\\r\\n // Coerce regexes to strings and treat strings, primitives and objects,\\r\\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\\r\\n // for more details.\\r\\n return object == (other + '');\\r\\n\\r\\n case mapTag:\\r\\n var convert = mapToArray;\\r\\n\\r\\n case setTag:\\r\\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\\r\\n convert || (convert = setToArray);\\r\\n\\r\\n if (object.size != other.size && !isPartial) {\\r\\n return false;\\r\\n }\\r\\n // Assume cyclic values are equal.\\r\\n var stacked = stack.get(object);\\r\\n if (stacked) {\\r\\n return stacked == other;\\r\\n }\\r\\n bitmask |= COMPARE_UNORDERED_FLAG;\\r\\n\\r\\n // Recursively compare objects (susceptible to call stack limits).\\r\\n stack.set(object, other);\\r\\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\\r\\n stack['delete'](object);\\r\\n return result;\\r\\n\\r\\n case symbolTag:\\r\\n if (symbolValueOf) {\\r\\n return symbolValueOf.call(object) == symbolValueOf.call(other);\\r\\n }\\r\\n }\\r\\n return false;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseIsEqualDeep` for objects with support for\\r\\n * partial deep comparisons.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to compare.\\r\\n * @param {Object} other The other object to compare.\\r\\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\\r\\n * @param {Function} customizer The function to customize comparisons.\\r\\n * @param {Function} equalFunc The function to determine equivalents of values.\\r\\n * @param {Object} stack Tracks traversed `object` and `other` objects.\\r\\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\\r\\n */\\r\\n function equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\\r\\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\\r\\n objProps = getAllKeys(object),\\r\\n objLength = objProps.length,\\r\\n othProps = getAllKeys(other),\\r\\n othLength = othProps.length;\\r\\n\\r\\n if (objLength != othLength && !isPartial) {\\r\\n return false;\\r\\n }\\r\\n var index = objLength;\\r\\n while (index--) {\\r\\n var key = objProps[index];\\r\\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\\r\\n return false;\\r\\n }\\r\\n }\\r\\n // Assume cyclic values are equal.\\r\\n var stacked = stack.get(object);\\r\\n if (stacked && stack.get(other)) {\\r\\n return stacked == other;\\r\\n }\\r\\n var result = true;\\r\\n stack.set(object, other);\\r\\n stack.set(other, object);\\r\\n\\r\\n var skipCtor = isPartial;\\r\\n while (++index < objLength) {\\r\\n key = objProps[index];\\r\\n var objValue = object[key],\\r\\n othValue = other[key];\\r\\n\\r\\n if (customizer) {\\r\\n var compared = isPartial\\r\\n ? customizer(othValue, objValue, key, other, object, stack)\\r\\n : customizer(objValue, othValue, key, object, other, stack);\\r\\n }\\r\\n // Recursively compare objects (susceptible to call stack limits).\\r\\n if (!(compared === undefined\\r\\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\\r\\n : compared\\r\\n )) {\\r\\n result = false;\\r\\n break;\\r\\n }\\r\\n skipCtor || (skipCtor = key == 'constructor');\\r\\n }\\r\\n if (result && !skipCtor) {\\r\\n var objCtor = object.constructor,\\r\\n othCtor = other.constructor;\\r\\n\\r\\n // Non `Object` object instances with different constructors are not equal.\\r\\n if (objCtor != othCtor &&\\r\\n ('constructor' in object && 'constructor' in other) &&\\r\\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\\r\\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\\r\\n result = false;\\r\\n }\\r\\n }\\r\\n stack['delete'](object);\\r\\n stack['delete'](other);\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseRest` which flattens the rest array.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to apply a rest parameter to.\\r\\n * @returns {Function} Returns the new function.\\r\\n */\\r\\n function flatRest(func) {\\r\\n return setToString(overRest(func, undefined, flatten), func + '');\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of own enumerable property names and symbols of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of property names and symbols.\\r\\n */\\r\\n function getAllKeys(object) {\\r\\n return baseGetAllKeys(object, keys, getSymbols);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of own and inherited enumerable property names and\\r\\n * symbols of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of property names and symbols.\\r\\n */\\r\\n function getAllKeysIn(object) {\\r\\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets metadata for `func`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to query.\\r\\n * @returns {*} Returns the metadata for `func`.\\r\\n */\\r\\n var getData = !metaMap ? noop : function(func) {\\r\\n return metaMap.get(func);\\r\\n };\\r\\n\\r\\n /**\\r\\n * Gets the name of `func`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to query.\\r\\n * @returns {string} Returns the function name.\\r\\n */\\r\\n function getFuncName(func) {\\r\\n var result = (func.name + ''),\\r\\n array = realNames[result],\\r\\n length = hasOwnProperty.call(realNames, result) ? array.length : 0;\\r\\n\\r\\n while (length--) {\\r\\n var data = array[length],\\r\\n otherFunc = data.func;\\r\\n if (otherFunc == null || otherFunc == func) {\\r\\n return data.name;\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the argument placeholder value for `func`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to inspect.\\r\\n * @returns {*} Returns the placeholder value.\\r\\n */\\r\\n function getHolder(func) {\\r\\n var object = hasOwnProperty.call(lodash, 'placeholder') ? lodash : func;\\r\\n return object.placeholder;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the data for `map`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} map The map to query.\\r\\n * @param {string} key The reference key.\\r\\n * @returns {*} Returns the map data.\\r\\n */\\r\\n function getMapData(map, key) {\\r\\n var data = map.__data__;\\r\\n return isKeyable(key)\\r\\n ? data[typeof key == 'string' ? 'string' : 'hash']\\r\\n : data.map;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the property names, values, and compare flags of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the match data of `object`.\\r\\n */\\r\\n function getMatchData(object) {\\r\\n var result = keys(object),\\r\\n length = result.length;\\r\\n\\r\\n while (length--) {\\r\\n var key = result[length],\\r\\n value = object[key];\\r\\n\\r\\n result[length] = [key, value, isStrictComparable(value)];\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the native function at `key` of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @param {string} key The key of the method to get.\\r\\n * @returns {*} Returns the function if it's native, else `undefined`.\\r\\n */\\r\\n function getNative(object, key) {\\r\\n var value = getValue(object, key);\\r\\n return baseIsNative(value) ? value : undefined;\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to query.\\r\\n * @returns {string} Returns the raw `toStringTag`.\\r\\n */\\r\\n function getRawTag(value) {\\r\\n var isOwn = hasOwnProperty.call(value, symToStringTag),\\r\\n tag = value[symToStringTag];\\r\\n\\r\\n try {\\r\\n value[symToStringTag] = undefined;\\r\\n var unmasked = true;\\r\\n } catch (e) {}\\r\\n\\r\\n var result = nativeObjectToString.call(value);\\r\\n if (unmasked) {\\r\\n if (isOwn) {\\r\\n value[symToStringTag] = tag;\\r\\n } else {\\r\\n delete value[symToStringTag];\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of the own enumerable symbols of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of symbols.\\r\\n */\\r\\n var getSymbols = !nativeGetSymbols ? stubArray : function(object) {\\r\\n if (object == null) {\\r\\n return [];\\r\\n }\\r\\n object = Object(object);\\r\\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\\r\\n return propertyIsEnumerable.call(object, symbol);\\r\\n });\\r\\n };\\r\\n\\r\\n /**\\r\\n * Creates an array of the own and inherited enumerable symbols of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of symbols.\\r\\n */\\r\\n var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\\r\\n var result = [];\\r\\n while (object) {\\r\\n arrayPush(result, getSymbols(object));\\r\\n object = getPrototype(object);\\r\\n }\\r\\n return result;\\r\\n };\\r\\n\\r\\n /**\\r\\n * Gets the `toStringTag` of `value`.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to query.\\r\\n * @returns {string} Returns the `toStringTag`.\\r\\n */\\r\\n var getTag = baseGetTag;\\r\\n\\r\\n // Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\\r\\n if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\\r\\n (Map && getTag(new Map) != mapTag) ||\\r\\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\\r\\n (Set && getTag(new Set) != setTag) ||\\r\\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\\r\\n getTag = function(value) {\\r\\n var result = baseGetTag(value),\\r\\n Ctor = result == objectTag ? value.constructor : undefined,\\r\\n ctorString = Ctor ? toSource(Ctor) : '';\\r\\n\\r\\n if (ctorString) {\\r\\n switch (ctorString) {\\r\\n case dataViewCtorString: return dataViewTag;\\r\\n case mapCtorString: return mapTag;\\r\\n case promiseCtorString: return promiseTag;\\r\\n case setCtorString: return setTag;\\r\\n case weakMapCtorString: return weakMapTag;\\r\\n }\\r\\n }\\r\\n return result;\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the view, applying any `transforms` to the `start` and `end` positions.\\r\\n *\\r\\n * @private\\r\\n * @param {number} start The start of the view.\\r\\n * @param {number} end The end of the view.\\r\\n * @param {Array} transforms The transformations to apply to the view.\\r\\n * @returns {Object} Returns an object containing the `start` and `end`\\r\\n * positions of the view.\\r\\n */\\r\\n function getView(start, end, transforms) {\\r\\n var index = -1,\\r\\n length = transforms.length;\\r\\n\\r\\n while (++index < length) {\\r\\n var data = transforms[index],\\r\\n size = data.size;\\r\\n\\r\\n switch (data.type) {\\r\\n case 'drop': start += size; break;\\r\\n case 'dropRight': end -= size; break;\\r\\n case 'take': end = nativeMin(end, start + size); break;\\r\\n case 'takeRight': start = nativeMax(start, end - size); break;\\r\\n }\\r\\n }\\r\\n return { 'start': start, 'end': end };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Extracts wrapper details from the `source` body comment.\\r\\n *\\r\\n * @private\\r\\n * @param {string} source The source to inspect.\\r\\n * @returns {Array} Returns the wrapper details.\\r\\n */\\r\\n function getWrapDetails(source) {\\r\\n var match = source.match(reWrapDetails);\\r\\n return match ? match[1].split(reSplitDetails) : [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `path` exists on `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array|string} path The path to check.\\r\\n * @param {Function} hasFunc The function to check properties.\\r\\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\\r\\n */\\r\\n function hasPath(object, path, hasFunc) {\\r\\n path = castPath(path, object);\\r\\n\\r\\n var index = -1,\\r\\n length = path.length,\\r\\n result = false;\\r\\n\\r\\n while (++index < length) {\\r\\n var key = toKey(path[index]);\\r\\n if (!(result = object != null && hasFunc(object, key))) {\\r\\n break;\\r\\n }\\r\\n object = object[key];\\r\\n }\\r\\n if (result || ++index != length) {\\r\\n return result;\\r\\n }\\r\\n length = object == null ? 0 : object.length;\\r\\n return !!length && isLength(length) && isIndex(key, length) &&\\r\\n (isArray(object) || isArguments(object));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Initializes an array clone.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to clone.\\r\\n * @returns {Array} Returns the initialized clone.\\r\\n */\\r\\n function initCloneArray(array) {\\r\\n var length = array.length,\\r\\n result = new array.constructor(length);\\r\\n\\r\\n // Add properties assigned by `RegExp#exec`.\\r\\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\\r\\n result.index = array.index;\\r\\n result.input = array.input;\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Initializes an object clone.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to clone.\\r\\n * @returns {Object} Returns the initialized clone.\\r\\n */\\r\\n function initCloneObject(object) {\\r\\n return (typeof object.constructor == 'function' && !isPrototype(object))\\r\\n ? baseCreate(getPrototype(object))\\r\\n : {};\\r\\n }\\r\\n\\r\\n /**\\r\\n * Initializes an object clone based on its `toStringTag`.\\r\\n *\\r\\n * **Note:** This function only supports cloning values with tags of\\r\\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to clone.\\r\\n * @param {string} tag The `toStringTag` of the object to clone.\\r\\n * @param {boolean} [isDeep] Specify a deep clone.\\r\\n * @returns {Object} Returns the initialized clone.\\r\\n */\\r\\n function initCloneByTag(object, tag, isDeep) {\\r\\n var Ctor = object.constructor;\\r\\n switch (tag) {\\r\\n case arrayBufferTag:\\r\\n return cloneArrayBuffer(object);\\r\\n\\r\\n case boolTag:\\r\\n case dateTag:\\r\\n return new Ctor(+object);\\r\\n\\r\\n case dataViewTag:\\r\\n return cloneDataView(object, isDeep);\\r\\n\\r\\n case float32Tag: case float64Tag:\\r\\n case int8Tag: case int16Tag: case int32Tag:\\r\\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\\r\\n return cloneTypedArray(object, isDeep);\\r\\n\\r\\n case mapTag:\\r\\n return new Ctor;\\r\\n\\r\\n case numberTag:\\r\\n case stringTag:\\r\\n return new Ctor(object);\\r\\n\\r\\n case regexpTag:\\r\\n return cloneRegExp(object);\\r\\n\\r\\n case setTag:\\r\\n return new Ctor;\\r\\n\\r\\n case symbolTag:\\r\\n return cloneSymbol(object);\\r\\n }\\r\\n }\\r\\n\\r\\n /**\\r\\n * Inserts wrapper `details` in a comment at the top of the `source` body.\\r\\n *\\r\\n * @private\\r\\n * @param {string} source The source to modify.\\r\\n * @returns {Array} details The details to insert.\\r\\n * @returns {string} Returns the modified source.\\r\\n */\\r\\n function insertWrapDetails(source, details) {\\r\\n var length = details.length;\\r\\n if (!length) {\\r\\n return source;\\r\\n }\\r\\n var lastIndex = length - 1;\\r\\n details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex];\\r\\n details = details.join(length > 2 ? ', ' : ' ');\\r\\n return source.replace(reWrapComment, '{\\\\n/* [wrapped with ' + details + '] */\\\\n');\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is a flattenable `arguments` object or array.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\\r\\n */\\r\\n function isFlattenable(value) {\\r\\n return isArray(value) || isArguments(value) ||\\r\\n !!(spreadableSymbol && value && value[spreadableSymbol]);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is a valid array-like index.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\\r\\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\\r\\n */\\r\\n function isIndex(value, length) {\\r\\n var type = typeof value;\\r\\n length = length == null ? MAX_SAFE_INTEGER : length;\\r\\n\\r\\n return !!length &&\\r\\n (type == 'number' ||\\r\\n (type != 'symbol' && reIsUint.test(value))) &&\\r\\n (value > -1 && value % 1 == 0 && value < length);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if the given arguments are from an iteratee call.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The potential iteratee value argument.\\r\\n * @param {*} index The potential iteratee index or key argument.\\r\\n * @param {*} object The potential iteratee object argument.\\r\\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\\r\\n * else `false`.\\r\\n */\\r\\n function isIterateeCall(value, index, object) {\\r\\n if (!isObject(object)) {\\r\\n return false;\\r\\n }\\r\\n var type = typeof index;\\r\\n if (type == 'number'\\r\\n ? (isArrayLike(object) && isIndex(index, object.length))\\r\\n : (type == 'string' && index in object)\\r\\n ) {\\r\\n return eq(object[index], value);\\r\\n }\\r\\n return false;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is a property name and not a property path.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @param {Object} [object] The object to query keys on.\\r\\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\\r\\n */\\r\\n function isKey(value, object) {\\r\\n if (isArray(value)) {\\r\\n return false;\\r\\n }\\r\\n var type = typeof value;\\r\\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\\r\\n value == null || isSymbol(value)) {\\r\\n return true;\\r\\n }\\r\\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\\r\\n (object != null && value in Object(object));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is suitable for use as unique object key.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\\r\\n */\\r\\n function isKeyable(value) {\\r\\n var type = typeof value;\\r\\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\\r\\n ? (value !== '__proto__')\\r\\n : (value === null);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `func` has a lazy counterpart.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to check.\\r\\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart,\\r\\n * else `false`.\\r\\n */\\r\\n function isLaziable(func) {\\r\\n var funcName = getFuncName(func),\\r\\n other = lodash[funcName];\\r\\n\\r\\n if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\\r\\n return false;\\r\\n }\\r\\n if (func === other) {\\r\\n return true;\\r\\n }\\r\\n var data = getData(other);\\r\\n return !!data && func === data[0];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `func` has its source masked.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to check.\\r\\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\\r\\n */\\r\\n function isMasked(func) {\\r\\n return !!maskSrcKey && (maskSrcKey in func);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is likely a prototype object.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\\r\\n */\\r\\n function isPrototype(value) {\\r\\n var Ctor = value && value.constructor,\\r\\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\\r\\n\\r\\n return value === proto;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` if suitable for strict\\r\\n * equality comparisons, else `false`.\\r\\n */\\r\\n function isStrictComparable(value) {\\r\\n return value === value && !isObject(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `matchesProperty` for source values suitable\\r\\n * for strict equality comparisons, i.e. `===`.\\r\\n *\\r\\n * @private\\r\\n * @param {string} key The key of the property to get.\\r\\n * @param {*} srcValue The value to match.\\r\\n * @returns {Function} Returns the new spec function.\\r\\n */\\r\\n function matchesStrictComparable(key, srcValue) {\\r\\n return function(object) {\\r\\n if (object == null) {\\r\\n return false;\\r\\n }\\r\\n return object[key] === srcValue &&\\r\\n (srcValue !== undefined || (key in Object(object)));\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `_.memoize` which clears the memoized function's\\r\\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to have its output memoized.\\r\\n * @returns {Function} Returns the new memoized function.\\r\\n */\\r\\n function memoizeCapped(func) {\\r\\n var result = memoize(func, function(key) {\\r\\n if (cache.size === MAX_MEMOIZE_SIZE) {\\r\\n cache.clear();\\r\\n }\\r\\n return key;\\r\\n });\\r\\n\\r\\n var cache = result.cache;\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Merges the function metadata of `source` into `data`.\\r\\n *\\r\\n * Merging metadata reduces the number of wrappers used to invoke a function.\\r\\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\\r\\n * may be applied regardless of execution order. Methods like `_.ary` and\\r\\n * `_.rearg` modify function arguments, making the order in which they are\\r\\n * executed important, preventing the merging of metadata. However, we make\\r\\n * an exception for a safe combined case where curried functions have `_.ary`\\r\\n * and or `_.rearg` applied.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} data The destination metadata.\\r\\n * @param {Array} source The source metadata.\\r\\n * @returns {Array} Returns `data`.\\r\\n */\\r\\n function mergeData(data, source) {\\r\\n var bitmask = data[1],\\r\\n srcBitmask = source[1],\\r\\n newBitmask = bitmask | srcBitmask,\\r\\n isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG);\\r\\n\\r\\n var isCombo =\\r\\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) ||\\r\\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) ||\\r\\n ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG));\\r\\n\\r\\n // Exit early if metadata can't be merged.\\r\\n if (!(isCommon || isCombo)) {\\r\\n return data;\\r\\n }\\r\\n // Use source `thisArg` if available.\\r\\n if (srcBitmask & WRAP_BIND_FLAG) {\\r\\n data[2] = source[2];\\r\\n // Set when currying a bound function.\\r\\n newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG;\\r\\n }\\r\\n // Compose partial arguments.\\r\\n var value = source[3];\\r\\n if (value) {\\r\\n var partials = data[3];\\r\\n data[3] = partials ? composeArgs(partials, value, source[4]) : value;\\r\\n data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4];\\r\\n }\\r\\n // Compose partial right arguments.\\r\\n value = source[5];\\r\\n if (value) {\\r\\n partials = data[5];\\r\\n data[5] = partials ? composeArgsRight(partials, value, source[6]) : value;\\r\\n data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6];\\r\\n }\\r\\n // Use source `argPos` if available.\\r\\n value = source[7];\\r\\n if (value) {\\r\\n data[7] = value;\\r\\n }\\r\\n // Use source `ary` if it's smaller.\\r\\n if (srcBitmask & WRAP_ARY_FLAG) {\\r\\n data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\\r\\n }\\r\\n // Use source `arity` if one is not provided.\\r\\n if (data[9] == null) {\\r\\n data[9] = source[9];\\r\\n }\\r\\n // Use source `func` and merge bitmasks.\\r\\n data[0] = source[0];\\r\\n data[1] = newBitmask;\\r\\n\\r\\n return data;\\r\\n }\\r\\n\\r\\n /**\\r\\n * This function is like\\r\\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\\r\\n * except that it includes inherited enumerable properties.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of property names.\\r\\n */\\r\\n function nativeKeysIn(object) {\\r\\n var result = [];\\r\\n if (object != null) {\\r\\n for (var key in Object(object)) {\\r\\n result.push(key);\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `value` to a string using `Object.prototype.toString`.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to convert.\\r\\n * @returns {string} Returns the converted string.\\r\\n */\\r\\n function objectToString(value) {\\r\\n return nativeObjectToString.call(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * A specialized version of `baseRest` which transforms the rest array.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to apply a rest parameter to.\\r\\n * @param {number} [start=func.length-1] The start position of the rest parameter.\\r\\n * @param {Function} transform The rest array transform.\\r\\n * @returns {Function} Returns the new function.\\r\\n */\\r\\n function overRest(func, start, transform) {\\r\\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\\r\\n return function() {\\r\\n var args = arguments,\\r\\n index = -1,\\r\\n length = nativeMax(args.length - start, 0),\\r\\n array = Array(length);\\r\\n\\r\\n while (++index < length) {\\r\\n array[index] = args[start + index];\\r\\n }\\r\\n index = -1;\\r\\n var otherArgs = Array(start + 1);\\r\\n while (++index < start) {\\r\\n otherArgs[index] = args[index];\\r\\n }\\r\\n otherArgs[start] = transform(array);\\r\\n return apply(func, this, otherArgs);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the parent value at `path` of `object`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array} path The path to get the parent value of.\\r\\n * @returns {*} Returns the parent value.\\r\\n */\\r\\n function parent(object, path) {\\r\\n return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Reorder `array` according to the specified indexes where the element at\\r\\n * the first index is assigned as the first element, the element at\\r\\n * the second index is assigned as the second element, and so on.\\r\\n *\\r\\n * @private\\r\\n * @param {Array} array The array to reorder.\\r\\n * @param {Array} indexes The arranged array indexes.\\r\\n * @returns {Array} Returns `array`.\\r\\n */\\r\\n function reorder(array, indexes) {\\r\\n var arrLength = array.length,\\r\\n length = nativeMin(indexes.length, arrLength),\\r\\n oldArray = copyArray(array);\\r\\n\\r\\n while (length--) {\\r\\n var index = indexes[length];\\r\\n array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\\r\\n }\\r\\n return array;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Sets metadata for `func`.\\r\\n *\\r\\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\\r\\n * period of time, it will trip its breaker and transition to an identity\\r\\n * function to avoid garbage collection pauses in V8. See\\r\\n * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)\\r\\n * for more details.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to associate metadata with.\\r\\n * @param {*} data The metadata.\\r\\n * @returns {Function} Returns `func`.\\r\\n */\\r\\n var setData = shortOut(baseSetData);\\r\\n\\r\\n /**\\r\\n * Sets the `toString` method of `func` to return `string`.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to modify.\\r\\n * @param {Function} string The `toString` result.\\r\\n * @returns {Function} Returns `func`.\\r\\n */\\r\\n var setToString = shortOut(baseSetToString);\\r\\n\\r\\n /**\\r\\n * Sets the `toString` method of `wrapper` to mimic the source of `reference`\\r\\n * with wrapper details in a comment at the top of the source body.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} wrapper The function to modify.\\r\\n * @param {Function} reference The reference function.\\r\\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\\r\\n * @returns {Function} Returns `wrapper`.\\r\\n */\\r\\n function setWrapToString(wrapper, reference, bitmask) {\\r\\n var source = (reference + '');\\r\\n return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask)));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that'll short out and invoke `identity` instead\\r\\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\\r\\n * milliseconds.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to restrict.\\r\\n * @returns {Function} Returns the new shortable function.\\r\\n */\\r\\n function shortOut(func) {\\r\\n var count = 0,\\r\\n lastCalled = 0;\\r\\n\\r\\n return function() {\\r\\n var stamp = nativeNow(),\\r\\n remaining = HOT_SPAN - (stamp - lastCalled);\\r\\n\\r\\n lastCalled = stamp;\\r\\n if (remaining > 0) {\\r\\n if (++count >= HOT_COUNT) {\\r\\n return arguments[0];\\r\\n }\\r\\n } else {\\r\\n count = 0;\\r\\n }\\r\\n return func.apply(undefined, arguments);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `string` to a property path array.\\r\\n *\\r\\n * @private\\r\\n * @param {string} string The string to convert.\\r\\n * @returns {Array} Returns the property path array.\\r\\n */\\r\\n var stringToPath = memoizeCapped(function(string) {\\r\\n var result = [];\\r\\n if (string.charCodeAt(0) === 46 /* . */) {\\r\\n result.push('');\\r\\n }\\r\\n string.replace(rePropName, function(match, number, quote, subString) {\\r\\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\\r\\n });\\r\\n return result;\\r\\n });\\r\\n\\r\\n /**\\r\\n * Converts `value` to a string key if it's not a string or symbol.\\r\\n *\\r\\n * @private\\r\\n * @param {*} value The value to inspect.\\r\\n * @returns {string|symbol} Returns the key.\\r\\n */\\r\\n function toKey(value) {\\r\\n if (typeof value == 'string' || isSymbol(value)) {\\r\\n return value;\\r\\n }\\r\\n var result = (value + '');\\r\\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `func` to its source code.\\r\\n *\\r\\n * @private\\r\\n * @param {Function} func The function to convert.\\r\\n * @returns {string} Returns the source code.\\r\\n */\\r\\n function toSource(func) {\\r\\n if (func != null) {\\r\\n try {\\r\\n return funcToString.call(func);\\r\\n } catch (e) {}\\r\\n try {\\r\\n return (func + '');\\r\\n } catch (e) {}\\r\\n }\\r\\n return '';\\r\\n }\\r\\n\\r\\n /**\\r\\n * Updates wrapper `details` based on `bitmask` flags.\\r\\n *\\r\\n * @private\\r\\n * @returns {Array} details The details to modify.\\r\\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\\r\\n * @returns {Array} Returns `details`.\\r\\n */\\r\\n function updateWrapDetails(details, bitmask) {\\r\\n arrayEach(wrapFlags, function(pair) {\\r\\n var value = '_.' + pair[0];\\r\\n if ((bitmask & pair[1]) && !arrayIncludes(details, value)) {\\r\\n details.push(value);\\r\\n }\\r\\n });\\r\\n return details.sort();\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of `wrapper`.\\r\\n *\\r\\n * @private\\r\\n * @param {Object} wrapper The wrapper to clone.\\r\\n * @returns {Object} Returns the cloned wrapper.\\r\\n */\\r\\n function wrapperClone(wrapper) {\\r\\n if (wrapper instanceof LazyWrapper) {\\r\\n return wrapper.clone();\\r\\n }\\r\\n var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__);\\r\\n result.__actions__ = copyArray(wrapper.__actions__);\\r\\n result.__index__ = wrapper.__index__;\\r\\n result.__values__ = wrapper.__values__;\\r\\n return result;\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates an array with all falsey values removed. The values `false`, `null`,\\r\\n * `0`, `\\\"\\\"`, `undefined`, and `NaN` are falsey.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to compact.\\r\\n * @returns {Array} Returns the new array of filtered values.\\r\\n * @example\\r\\n *\\r\\n * _.compact([0, 1, false, 2, '', 3]);\\r\\n * // => [1, 2, 3]\\r\\n */\\r\\n function compact(array) {\\r\\n var index = -1,\\r\\n length = array == null ? 0 : array.length,\\r\\n resIndex = 0,\\r\\n result = [];\\r\\n\\r\\n while (++index < length) {\\r\\n var value = array[index];\\r\\n if (value) {\\r\\n result[resIndex++] = value;\\r\\n }\\r\\n }\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a new array concatenating `array` with any additional arrays\\r\\n * and/or values.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to concatenate.\\r\\n * @param {...*} [values] The values to concatenate.\\r\\n * @returns {Array} Returns the new concatenated array.\\r\\n * @example\\r\\n *\\r\\n * var array = [1];\\r\\n * var other = _.concat(array, 2, [3], [[4]]);\\r\\n *\\r\\n * console.log(other);\\r\\n * // => [1, 2, 3, [4]]\\r\\n *\\r\\n * console.log(array);\\r\\n * // => [1]\\r\\n */\\r\\n function concat() {\\r\\n var length = arguments.length;\\r\\n if (!length) {\\r\\n return [];\\r\\n }\\r\\n var args = Array(length - 1),\\r\\n array = arguments[0],\\r\\n index = length;\\r\\n\\r\\n while (index--) {\\r\\n args[index - 1] = arguments[index];\\r\\n }\\r\\n return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of `array` values not included in the other given arrays\\r\\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\\r\\n * for equality comparisons. The order and references of result values are\\r\\n * determined by the first array.\\r\\n *\\r\\n * **Note:** Unlike `_.pullAll`, this method returns a new array.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {...Array} [values] The values to exclude.\\r\\n * @returns {Array} Returns the new array of filtered values.\\r\\n * @see _.without, _.xor\\r\\n * @example\\r\\n *\\r\\n * _.difference([2, 1], [2, 3]);\\r\\n * // => [1]\\r\\n */\\r\\n var difference = baseRest(function(array, values) {\\r\\n return isArrayLikeObject(array)\\r\\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true))\\r\\n : [];\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates a slice of `array` with `n` elements dropped from the beginning.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.5.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to query.\\r\\n * @param {number} [n=1] The number of elements to drop.\\r\\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\\r\\n * @returns {Array} Returns the slice of `array`.\\r\\n * @example\\r\\n *\\r\\n * _.drop([1, 2, 3]);\\r\\n * // => [2, 3]\\r\\n *\\r\\n * _.drop([1, 2, 3], 2);\\r\\n * // => [3]\\r\\n *\\r\\n * _.drop([1, 2, 3], 5);\\r\\n * // => []\\r\\n *\\r\\n * _.drop([1, 2, 3], 0);\\r\\n * // => [1, 2, 3]\\r\\n */\\r\\n function drop(array, n, guard) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n if (!length) {\\r\\n return [];\\r\\n }\\r\\n n = (guard || n === undefined) ? 1 : toInteger(n);\\r\\n return baseSlice(array, n < 0 ? 0 : n, length);\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.find` except that it returns the index of the first\\r\\n * element `predicate` returns truthy for instead of the element itself.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 1.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @param {number} [fromIndex=0] The index to search from.\\r\\n * @returns {number} Returns the index of the found element, else `-1`.\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'active': false },\\r\\n * { 'user': 'fred', 'active': false },\\r\\n * { 'user': 'pebbles', 'active': true }\\r\\n * ];\\r\\n *\\r\\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\\r\\n * // => 0\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.findIndex(users, { 'user': 'fred', 'active': false });\\r\\n * // => 1\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.findIndex(users, ['active', false]);\\r\\n * // => 0\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.findIndex(users, 'active');\\r\\n * // => 2\\r\\n */\\r\\n function findIndex(array, predicate, fromIndex) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n if (!length) {\\r\\n return -1;\\r\\n }\\r\\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\\r\\n if (index < 0) {\\r\\n index = nativeMax(length + index, 0);\\r\\n }\\r\\n return baseFindIndex(array, baseIteratee(predicate, 3), index);\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.findIndex` except that it iterates over elements\\r\\n * of `collection` from right to left.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 2.0.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @param {number} [fromIndex=array.length-1] The index to search from.\\r\\n * @returns {number} Returns the index of the found element, else `-1`.\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'active': true },\\r\\n * { 'user': 'fred', 'active': false },\\r\\n * { 'user': 'pebbles', 'active': false }\\r\\n * ];\\r\\n *\\r\\n * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });\\r\\n * // => 2\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.findLastIndex(users, { 'user': 'barney', 'active': true });\\r\\n * // => 0\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.findLastIndex(users, ['active', false]);\\r\\n * // => 2\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.findLastIndex(users, 'active');\\r\\n * // => 0\\r\\n */\\r\\n function findLastIndex(array, predicate, fromIndex) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n if (!length) {\\r\\n return -1;\\r\\n }\\r\\n var index = length - 1;\\r\\n if (fromIndex !== undefined) {\\r\\n index = toInteger(fromIndex);\\r\\n index = fromIndex < 0\\r\\n ? nativeMax(length + index, 0)\\r\\n : nativeMin(index, length - 1);\\r\\n }\\r\\n return baseFindIndex(array, baseIteratee(predicate, 3), index, true);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Flattens `array` a single level deep.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to flatten.\\r\\n * @returns {Array} Returns the new flattened array.\\r\\n * @example\\r\\n *\\r\\n * _.flatten([1, [2, [3, [4]], 5]]);\\r\\n * // => [1, 2, [3, [4]], 5]\\r\\n */\\r\\n function flatten(array) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n return length ? baseFlatten(array, 1) : [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Recursively flattens `array`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to flatten.\\r\\n * @returns {Array} Returns the new flattened array.\\r\\n * @example\\r\\n *\\r\\n * _.flattenDeep([1, [2, [3, [4]], 5]]);\\r\\n * // => [1, 2, 3, 4, 5]\\r\\n */\\r\\n function flattenDeep(array) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n return length ? baseFlatten(array, INFINITY) : [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the first element of `array`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @alias first\\r\\n * @category Array\\r\\n * @param {Array} array The array to query.\\r\\n * @returns {*} Returns the first element of `array`.\\r\\n * @example\\r\\n *\\r\\n * _.head([1, 2, 3]);\\r\\n * // => 1\\r\\n *\\r\\n * _.head([]);\\r\\n * // => undefined\\r\\n */\\r\\n function head(array) {\\r\\n return (array && array.length) ? array[0] : undefined;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the index at which the first occurrence of `value` is found in `array`\\r\\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\\r\\n * for equality comparisons. If `fromIndex` is negative, it's used as the\\r\\n * offset from the end of `array`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {*} value The value to search for.\\r\\n * @param {number} [fromIndex=0] The index to search from.\\r\\n * @returns {number} Returns the index of the matched value, else `-1`.\\r\\n * @example\\r\\n *\\r\\n * _.indexOf([1, 2, 1, 2], 2);\\r\\n * // => 1\\r\\n *\\r\\n * // Search from the `fromIndex`.\\r\\n * _.indexOf([1, 2, 1, 2], 2, 2);\\r\\n * // => 3\\r\\n */\\r\\n function indexOf(array, value, fromIndex) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n if (!length) {\\r\\n return -1;\\r\\n }\\r\\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\\r\\n if (index < 0) {\\r\\n index = nativeMax(length + index, 0);\\r\\n }\\r\\n return baseIndexOf(array, value, index);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets all but the last element of `array`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to query.\\r\\n * @returns {Array} Returns the slice of `array`.\\r\\n * @example\\r\\n *\\r\\n * _.initial([1, 2, 3]);\\r\\n * // => [1, 2]\\r\\n */\\r\\n function initial(array) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n return length ? baseSlice(array, 0, -1) : [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of unique values that are included in all given arrays\\r\\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\\r\\n * for equality comparisons. The order and references of result values are\\r\\n * determined by the first array.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {...Array} [arrays] The arrays to inspect.\\r\\n * @returns {Array} Returns the new array of intersecting values.\\r\\n * @example\\r\\n *\\r\\n * _.intersection([2, 1], [2, 3]);\\r\\n * // => [2]\\r\\n */\\r\\n var intersection = baseRest(function(arrays) {\\r\\n var mapped = arrayMap(arrays, castArrayLikeObject);\\r\\n return (mapped.length && mapped[0] === arrays[0])\\r\\n ? baseIntersection(mapped)\\r\\n : [];\\r\\n });\\r\\n\\r\\n /**\\r\\n * Gets the last element of `array`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to query.\\r\\n * @returns {*} Returns the last element of `array`.\\r\\n * @example\\r\\n *\\r\\n * _.last([1, 2, 3]);\\r\\n * // => 3\\r\\n */\\r\\n function last(array) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n return length ? array[length - 1] : undefined;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Reverses `array` so that the first element becomes the last, the second\\r\\n * element becomes the second to last, and so on.\\r\\n *\\r\\n * **Note:** This method mutates `array` and is based on\\r\\n * [`Array#reverse`](https://mdn.io/Array/reverse).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to modify.\\r\\n * @returns {Array} Returns `array`.\\r\\n * @example\\r\\n *\\r\\n * var array = [1, 2, 3];\\r\\n *\\r\\n * _.reverse(array);\\r\\n * // => [3, 2, 1]\\r\\n *\\r\\n * console.log(array);\\r\\n * // => [3, 2, 1]\\r\\n */\\r\\n function reverse(array) {\\r\\n return array == null ? array : nativeReverse.call(array);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a slice of `array` from `start` up to, but not including, `end`.\\r\\n *\\r\\n * **Note:** This method is used instead of\\r\\n * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are\\r\\n * returned.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to slice.\\r\\n * @param {number} [start=0] The start position.\\r\\n * @param {number} [end=array.length] The end position.\\r\\n * @returns {Array} Returns the slice of `array`.\\r\\n */\\r\\n function slice(array, start, end) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n if (!length) {\\r\\n return [];\\r\\n }\\r\\n if (end && typeof end != 'number' && isIterateeCall(array, start, end)) {\\r\\n start = 0;\\r\\n end = length;\\r\\n }\\r\\n else {\\r\\n start = start == null ? 0 : toInteger(start);\\r\\n end = end === undefined ? length : toInteger(end);\\r\\n }\\r\\n return baseSlice(array, start, end);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a slice of `array` with `n` elements taken from the beginning.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to query.\\r\\n * @param {number} [n=1] The number of elements to take.\\r\\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\\r\\n * @returns {Array} Returns the slice of `array`.\\r\\n * @example\\r\\n *\\r\\n * _.take([1, 2, 3]);\\r\\n * // => [1]\\r\\n *\\r\\n * _.take([1, 2, 3], 2);\\r\\n * // => [1, 2]\\r\\n *\\r\\n * _.take([1, 2, 3], 5);\\r\\n * // => [1, 2, 3]\\r\\n *\\r\\n * _.take([1, 2, 3], 0);\\r\\n * // => []\\r\\n */\\r\\n function take(array, n, guard) {\\r\\n if (!(array && array.length)) {\\r\\n return [];\\r\\n }\\r\\n n = (guard || n === undefined) ? 1 : toInteger(n);\\r\\n return baseSlice(array, 0, n < 0 ? 0 : n);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a slice of `array` with `n` elements taken from the end.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to query.\\r\\n * @param {number} [n=1] The number of elements to take.\\r\\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\\r\\n * @returns {Array} Returns the slice of `array`.\\r\\n * @example\\r\\n *\\r\\n * _.takeRight([1, 2, 3]);\\r\\n * // => [3]\\r\\n *\\r\\n * _.takeRight([1, 2, 3], 2);\\r\\n * // => [2, 3]\\r\\n *\\r\\n * _.takeRight([1, 2, 3], 5);\\r\\n * // => [1, 2, 3]\\r\\n *\\r\\n * _.takeRight([1, 2, 3], 0);\\r\\n * // => []\\r\\n */\\r\\n function takeRight(array, n, guard) {\\r\\n var length = array == null ? 0 : array.length;\\r\\n if (!length) {\\r\\n return [];\\r\\n }\\r\\n n = (guard || n === undefined) ? 1 : toInteger(n);\\r\\n n = length - n;\\r\\n return baseSlice(array, n < 0 ? 0 : n, length);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of unique values, in order, from all given arrays using\\r\\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\\r\\n * for equality comparisons.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {...Array} [arrays] The arrays to inspect.\\r\\n * @returns {Array} Returns the new array of combined values.\\r\\n * @example\\r\\n *\\r\\n * _.union([2], [1, 2]);\\r\\n * // => [2, 1]\\r\\n */\\r\\n var union = baseRest(function(arrays) {\\r\\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates a duplicate-free version of an array, using\\r\\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\\r\\n * for equality comparisons, in which only the first occurrence of each element\\r\\n * is kept. The order of result values is determined by the order they occur\\r\\n * in the array.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to inspect.\\r\\n * @returns {Array} Returns the new duplicate free array.\\r\\n * @example\\r\\n *\\r\\n * _.uniq([2, 1, 2]);\\r\\n * // => [2, 1]\\r\\n */\\r\\n function uniq(array) {\\r\\n return (array && array.length) ? baseUniq(array) : [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.uniq` except that it accepts `iteratee` which is\\r\\n * invoked for each element in `array` to generate the criterion by which\\r\\n * uniqueness is computed. The order of result values is determined by the\\r\\n * order they occur in the array. The iteratee is invoked with one argument:\\r\\n * (value).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\\r\\n * @returns {Array} Returns the new duplicate free array.\\r\\n * @example\\r\\n *\\r\\n * _.uniqBy([2.1, 1.2, 2.3], Math.floor);\\r\\n * // => [2.1, 1.2]\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');\\r\\n * // => [{ 'x': 1 }, { 'x': 2 }]\\r\\n */\\r\\n function uniqBy(array, iteratee) {\\r\\n return (array && array.length) ? baseUniq(array, baseIteratee(iteratee, 2)) : [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.zip` except that it accepts an array of grouped\\r\\n * elements and creates an array regrouping the elements to their pre-zip\\r\\n * configuration.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 1.2.0\\r\\n * @category Array\\r\\n * @param {Array} array The array of grouped elements to process.\\r\\n * @returns {Array} Returns the new array of regrouped elements.\\r\\n * @example\\r\\n *\\r\\n * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]);\\r\\n * // => [['a', 1, true], ['b', 2, false]]\\r\\n *\\r\\n * _.unzip(zipped);\\r\\n * // => [['a', 'b'], [1, 2], [true, false]]\\r\\n */\\r\\n function unzip(array) {\\r\\n if (!(array && array.length)) {\\r\\n return [];\\r\\n }\\r\\n var length = 0;\\r\\n array = arrayFilter(array, function(group) {\\r\\n if (isArrayLikeObject(group)) {\\r\\n length = nativeMax(group.length, length);\\r\\n return true;\\r\\n }\\r\\n });\\r\\n return baseTimes(length, function(index) {\\r\\n return arrayMap(array, baseProperty(index));\\r\\n });\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array excluding all given values using\\r\\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\\r\\n * for equality comparisons.\\r\\n *\\r\\n * **Note:** Unlike `_.pull`, this method returns a new array.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {Array} array The array to inspect.\\r\\n * @param {...*} [values] The values to exclude.\\r\\n * @returns {Array} Returns the new array of filtered values.\\r\\n * @see _.difference, _.xor\\r\\n * @example\\r\\n *\\r\\n * _.without([2, 1, 2, 3], 1, 2);\\r\\n * // => [3]\\r\\n */\\r\\n var without = baseRest(function(array, values) {\\r\\n return isArrayLikeObject(array)\\r\\n ? baseDifference(array, values)\\r\\n : [];\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates an array of grouped elements, the first of which contains the\\r\\n * first elements of the given arrays, the second of which contains the\\r\\n * second elements of the given arrays, and so on.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Array\\r\\n * @param {...Array} [arrays] The arrays to process.\\r\\n * @returns {Array} Returns the new array of grouped elements.\\r\\n * @example\\r\\n *\\r\\n * _.zip(['a', 'b'], [1, 2], [true, false]);\\r\\n * // => [['a', 1, true], ['b', 2, false]]\\r\\n */\\r\\n var zip = baseRest(unzip);\\r\\n\\r\\n /**\\r\\n * This method is like `_.fromPairs` except that it accepts two arrays,\\r\\n * one of property identifiers and one of corresponding values.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.4.0\\r\\n * @category Array\\r\\n * @param {Array} [props=[]] The property identifiers.\\r\\n * @param {Array} [values=[]] The property values.\\r\\n * @returns {Object} Returns the new object.\\r\\n * @example\\r\\n *\\r\\n * _.zipObject(['a', 'b'], [1, 2]);\\r\\n * // => { 'a': 1, 'b': 2 }\\r\\n */\\r\\n function zipObject(props, values) {\\r\\n return baseZipObject(props || [], values || [], assignValue);\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates a `lodash` wrapper instance that wraps `value` with explicit method\\r\\n * chain sequences enabled. The result of such sequences must be unwrapped\\r\\n * with `_#value`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 1.3.0\\r\\n * @category Seq\\r\\n * @param {*} value The value to wrap.\\r\\n * @returns {Object} Returns the new `lodash` wrapper instance.\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'age': 36 },\\r\\n * { 'user': 'fred', 'age': 40 },\\r\\n * { 'user': 'pebbles', 'age': 1 }\\r\\n * ];\\r\\n *\\r\\n * var youngest = _\\r\\n * .chain(users)\\r\\n * .sortBy('age')\\r\\n * .map(function(o) {\\r\\n * return o.user + ' is ' + o.age;\\r\\n * })\\r\\n * .head()\\r\\n * .value();\\r\\n * // => 'pebbles is 1'\\r\\n */\\r\\n function chain(value) {\\r\\n var result = lodash(value);\\r\\n result.__chain__ = true;\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method invokes `interceptor` and returns `value`. The interceptor\\r\\n * is invoked with one argument; (value). The purpose of this method is to\\r\\n * \\\"tap into\\\" a method chain sequence in order to modify intermediate results.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Seq\\r\\n * @param {*} value The value to provide to `interceptor`.\\r\\n * @param {Function} interceptor The function to invoke.\\r\\n * @returns {*} Returns `value`.\\r\\n * @example\\r\\n *\\r\\n * _([1, 2, 3])\\r\\n * .tap(function(array) {\\r\\n * // Mutate input array.\\r\\n * array.pop();\\r\\n * })\\r\\n * .reverse()\\r\\n * .value();\\r\\n * // => [2, 1]\\r\\n */\\r\\n function tap(value, interceptor) {\\r\\n interceptor(value);\\r\\n return value;\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.tap` except that it returns the result of `interceptor`.\\r\\n * The purpose of this method is to \\\"pass thru\\\" values replacing intermediate\\r\\n * results in a method chain sequence.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Seq\\r\\n * @param {*} value The value to provide to `interceptor`.\\r\\n * @param {Function} interceptor The function to invoke.\\r\\n * @returns {*} Returns the result of `interceptor`.\\r\\n * @example\\r\\n *\\r\\n * _(' abc ')\\r\\n * .chain()\\r\\n * .trim()\\r\\n * .thru(function(value) {\\r\\n * return [value];\\r\\n * })\\r\\n * .value();\\r\\n * // => ['abc']\\r\\n */\\r\\n function thru(value, interceptor) {\\r\\n return interceptor(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is the wrapper version of `_.at`.\\r\\n *\\r\\n * @name at\\r\\n * @memberOf _\\r\\n * @since 1.0.0\\r\\n * @category Seq\\r\\n * @param {...(string|string[])} [paths] The property paths to pick.\\r\\n * @returns {Object} Returns the new `lodash` wrapper instance.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\\r\\n *\\r\\n * _(object).at(['a[0].b.c', 'a[1]']).value();\\r\\n * // => [3, 4]\\r\\n */\\r\\n var wrapperAt = flatRest(function(paths) {\\r\\n var length = paths.length,\\r\\n start = length ? paths[0] : 0,\\r\\n value = this.__wrapped__,\\r\\n interceptor = function(object) { return baseAt(object, paths); };\\r\\n\\r\\n if (length > 1 || this.__actions__.length ||\\r\\n !(value instanceof LazyWrapper) || !isIndex(start)) {\\r\\n return this.thru(interceptor);\\r\\n }\\r\\n value = value.slice(start, +start + (length ? 1 : 0));\\r\\n value.__actions__.push({\\r\\n 'func': thru,\\r\\n 'args': [interceptor],\\r\\n 'thisArg': undefined\\r\\n });\\r\\n return new LodashWrapper(value, this.__chain__).thru(function(array) {\\r\\n if (length && !array.length) {\\r\\n array.push(undefined);\\r\\n }\\r\\n return array;\\r\\n });\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates a `lodash` wrapper instance with explicit method chain sequences enabled.\\r\\n *\\r\\n * @name chain\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Seq\\r\\n * @returns {Object} Returns the new `lodash` wrapper instance.\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'age': 36 },\\r\\n * { 'user': 'fred', 'age': 40 }\\r\\n * ];\\r\\n *\\r\\n * // A sequence without explicit chaining.\\r\\n * _(users).head();\\r\\n * // => { 'user': 'barney', 'age': 36 }\\r\\n *\\r\\n * // A sequence with explicit chaining.\\r\\n * _(users)\\r\\n * .chain()\\r\\n * .head()\\r\\n * .pick('user')\\r\\n * .value();\\r\\n * // => { 'user': 'barney' }\\r\\n */\\r\\n function wrapperChain() {\\r\\n return chain(this);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Executes the chain sequence and returns the wrapped result.\\r\\n *\\r\\n * @name commit\\r\\n * @memberOf _\\r\\n * @since 3.2.0\\r\\n * @category Seq\\r\\n * @returns {Object} Returns the new `lodash` wrapper instance.\\r\\n * @example\\r\\n *\\r\\n * var array = [1, 2];\\r\\n * var wrapped = _(array).push(3);\\r\\n *\\r\\n * console.log(array);\\r\\n * // => [1, 2]\\r\\n *\\r\\n * wrapped = wrapped.commit();\\r\\n * console.log(array);\\r\\n * // => [1, 2, 3]\\r\\n *\\r\\n * wrapped.last();\\r\\n * // => 3\\r\\n *\\r\\n * console.log(array);\\r\\n * // => [1, 2, 3]\\r\\n */\\r\\n function wrapperCommit() {\\r\\n return new LodashWrapper(this.value(), this.__chain__);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the next value on a wrapped object following the\\r\\n * [iterator protocol](https://mdn.io/iteration_protocols#iterator).\\r\\n *\\r\\n * @name next\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Seq\\r\\n * @returns {Object} Returns the next iterator value.\\r\\n * @example\\r\\n *\\r\\n * var wrapped = _([1, 2]);\\r\\n *\\r\\n * wrapped.next();\\r\\n * // => { 'done': false, 'value': 1 }\\r\\n *\\r\\n * wrapped.next();\\r\\n * // => { 'done': false, 'value': 2 }\\r\\n *\\r\\n * wrapped.next();\\r\\n * // => { 'done': true, 'value': undefined }\\r\\n */\\r\\n function wrapperNext() {\\r\\n if (this.__values__ === undefined) {\\r\\n this.__values__ = toArray(this.value());\\r\\n }\\r\\n var done = this.__index__ >= this.__values__.length,\\r\\n value = done ? undefined : this.__values__[this.__index__++];\\r\\n\\r\\n return { 'done': done, 'value': value };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Enables the wrapper to be iterable.\\r\\n *\\r\\n * @name Symbol.iterator\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Seq\\r\\n * @returns {Object} Returns the wrapper object.\\r\\n * @example\\r\\n *\\r\\n * var wrapped = _([1, 2]);\\r\\n *\\r\\n * wrapped[Symbol.iterator]() === wrapped;\\r\\n * // => true\\r\\n *\\r\\n * Array.from(wrapped);\\r\\n * // => [1, 2]\\r\\n */\\r\\n function wrapperToIterator() {\\r\\n return this;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a clone of the chain sequence planting `value` as the wrapped value.\\r\\n *\\r\\n * @name plant\\r\\n * @memberOf _\\r\\n * @since 3.2.0\\r\\n * @category Seq\\r\\n * @param {*} value The value to plant.\\r\\n * @returns {Object} Returns the new `lodash` wrapper instance.\\r\\n * @example\\r\\n *\\r\\n * function square(n) {\\r\\n * return n * n;\\r\\n * }\\r\\n *\\r\\n * var wrapped = _([1, 2]).map(square);\\r\\n * var other = wrapped.plant([3, 4]);\\r\\n *\\r\\n * other.value();\\r\\n * // => [9, 16]\\r\\n *\\r\\n * wrapped.value();\\r\\n * // => [1, 4]\\r\\n */\\r\\n function wrapperPlant(value) {\\r\\n var result,\\r\\n parent = this;\\r\\n\\r\\n while (parent instanceof baseLodash) {\\r\\n var clone = wrapperClone(parent);\\r\\n clone.__index__ = 0;\\r\\n clone.__values__ = undefined;\\r\\n if (result) {\\r\\n previous.__wrapped__ = clone;\\r\\n } else {\\r\\n result = clone;\\r\\n }\\r\\n var previous = clone;\\r\\n parent = parent.__wrapped__;\\r\\n }\\r\\n previous.__wrapped__ = value;\\r\\n return result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is the wrapper version of `_.reverse`.\\r\\n *\\r\\n * **Note:** This method mutates the wrapped array.\\r\\n *\\r\\n * @name reverse\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Seq\\r\\n * @returns {Object} Returns the new `lodash` wrapper instance.\\r\\n * @example\\r\\n *\\r\\n * var array = [1, 2, 3];\\r\\n *\\r\\n * _(array).reverse().value()\\r\\n * // => [3, 2, 1]\\r\\n *\\r\\n * console.log(array);\\r\\n * // => [3, 2, 1]\\r\\n */\\r\\n function wrapperReverse() {\\r\\n var value = this.__wrapped__;\\r\\n if (value instanceof LazyWrapper) {\\r\\n var wrapped = value;\\r\\n if (this.__actions__.length) {\\r\\n wrapped = new LazyWrapper(this);\\r\\n }\\r\\n wrapped = wrapped.reverse();\\r\\n wrapped.__actions__.push({\\r\\n 'func': thru,\\r\\n 'args': [reverse],\\r\\n 'thisArg': undefined\\r\\n });\\r\\n return new LodashWrapper(wrapped, this.__chain__);\\r\\n }\\r\\n return this.thru(reverse);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Executes the chain sequence to resolve the unwrapped value.\\r\\n *\\r\\n * @name value\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @alias toJSON, valueOf\\r\\n * @category Seq\\r\\n * @returns {*} Returns the resolved unwrapped value.\\r\\n * @example\\r\\n *\\r\\n * _([1, 2, 3]).value();\\r\\n * // => [1, 2, 3]\\r\\n */\\r\\n function wrapperValue() {\\r\\n return baseWrapperValue(this.__wrapped__, this.__actions__);\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates an object composed of keys generated from the results of running\\r\\n * each element of `collection` thru `iteratee`. The corresponding value of\\r\\n * each key is the number of times the key was returned by `iteratee`. The\\r\\n * iteratee is invoked with one argument: (value).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.5.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\\r\\n * @returns {Object} Returns the composed aggregate object.\\r\\n * @example\\r\\n *\\r\\n * _.countBy([6.1, 4.2, 6.3], Math.floor);\\r\\n * // => { '4': 1, '6': 2 }\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.countBy(['one', 'two', 'three'], 'length');\\r\\n * // => { '3': 2, '5': 1 }\\r\\n */\\r\\n var countBy = createAggregator(function(result, value, key) {\\r\\n if (hasOwnProperty.call(result, key)) {\\r\\n ++result[key];\\r\\n } else {\\r\\n baseAssignValue(result, key, 1);\\r\\n }\\r\\n });\\r\\n\\r\\n /**\\r\\n * Checks if `predicate` returns truthy for **all** elements of `collection`.\\r\\n * Iteration is stopped once `predicate` returns falsey. The predicate is\\r\\n * invoked with three arguments: (value, index|key, collection).\\r\\n *\\r\\n * **Note:** This method returns `true` for\\r\\n * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because\\r\\n * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of\\r\\n * elements of empty collections.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\\r\\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\\r\\n * else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.every([true, 1, null, 'yes'], Boolean);\\r\\n * // => false\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'age': 36, 'active': false },\\r\\n * { 'user': 'fred', 'age': 40, 'active': false }\\r\\n * ];\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.every(users, { 'user': 'barney', 'active': false });\\r\\n * // => false\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.every(users, ['active', false]);\\r\\n * // => true\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.every(users, 'active');\\r\\n * // => false\\r\\n */\\r\\n function every(collection, predicate, guard) {\\r\\n var func = isArray(collection) ? arrayEvery : baseEvery;\\r\\n if (guard && isIterateeCall(collection, predicate, guard)) {\\r\\n predicate = undefined;\\r\\n }\\r\\n return func(collection, baseIteratee(predicate, 3));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Iterates over elements of `collection`, returning an array of all elements\\r\\n * `predicate` returns truthy for. The predicate is invoked with three\\r\\n * arguments: (value, index|key, collection).\\r\\n *\\r\\n * **Note:** Unlike `_.remove`, this method returns a new array.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @returns {Array} Returns the new filtered array.\\r\\n * @see _.reject\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'age': 36, 'active': true },\\r\\n * { 'user': 'fred', 'age': 40, 'active': false }\\r\\n * ];\\r\\n *\\r\\n * _.filter(users, function(o) { return !o.active; });\\r\\n * // => objects for ['fred']\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.filter(users, { 'age': 36, 'active': true });\\r\\n * // => objects for ['barney']\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.filter(users, ['active', false]);\\r\\n * // => objects for ['fred']\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.filter(users, 'active');\\r\\n * // => objects for ['barney']\\r\\n */\\r\\n function filter(collection, predicate) {\\r\\n var func = isArray(collection) ? arrayFilter : baseFilter;\\r\\n return func(collection, baseIteratee(predicate, 3));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Iterates over elements of `collection`, returning the first element\\r\\n * `predicate` returns truthy for. The predicate is invoked with three\\r\\n * arguments: (value, index|key, collection).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to inspect.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @param {number} [fromIndex=0] The index to search from.\\r\\n * @returns {*} Returns the matched element, else `undefined`.\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'age': 36, 'active': true },\\r\\n * { 'user': 'fred', 'age': 40, 'active': false },\\r\\n * { 'user': 'pebbles', 'age': 1, 'active': true }\\r\\n * ];\\r\\n *\\r\\n * _.find(users, function(o) { return o.age < 40; });\\r\\n * // => object for 'barney'\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.find(users, { 'age': 1, 'active': true });\\r\\n * // => object for 'pebbles'\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.find(users, ['active', false]);\\r\\n * // => object for 'fred'\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.find(users, 'active');\\r\\n * // => object for 'barney'\\r\\n */\\r\\n var find = createFind(findIndex);\\r\\n\\r\\n /**\\r\\n * Iterates over elements of `collection` and invokes `iteratee` for each element.\\r\\n * The iteratee is invoked with three arguments: (value, index|key, collection).\\r\\n * Iteratee functions may exit iteration early by explicitly returning `false`.\\r\\n *\\r\\n * **Note:** As with other \\\"Collections\\\" methods, objects with a \\\"length\\\"\\r\\n * property are iterated like arrays. To avoid this behavior use `_.forIn`\\r\\n * or `_.forOwn` for object iteration.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @alias each\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\\r\\n * @returns {Array|Object} Returns `collection`.\\r\\n * @see _.forEachRight\\r\\n * @example\\r\\n *\\r\\n * _.forEach([1, 2], function(value) {\\r\\n * console.log(value);\\r\\n * });\\r\\n * // => Logs `1` then `2`.\\r\\n *\\r\\n * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {\\r\\n * console.log(key);\\r\\n * });\\r\\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\\r\\n */\\r\\n function forEach(collection, iteratee) {\\r\\n var func = isArray(collection) ? arrayEach : baseEach;\\r\\n return func(collection, baseIteratee(iteratee, 3));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an object composed of keys generated from the results of running\\r\\n * each element of `collection` thru `iteratee`. The order of grouped values\\r\\n * is determined by the order they occur in `collection`. The corresponding\\r\\n * value of each key is an array of elements responsible for generating the\\r\\n * key. The iteratee is invoked with one argument: (value).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\\r\\n * @returns {Object} Returns the composed aggregate object.\\r\\n * @example\\r\\n *\\r\\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\\r\\n * // => { '4': [4.2], '6': [6.1, 6.3] }\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.groupBy(['one', 'two', 'three'], 'length');\\r\\n * // => { '3': ['one', 'two'], '5': ['three'] }\\r\\n */\\r\\n var groupBy = createAggregator(function(result, value, key) {\\r\\n if (hasOwnProperty.call(result, key)) {\\r\\n result[key].push(value);\\r\\n } else {\\r\\n baseAssignValue(result, key, [value]);\\r\\n }\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates an array of values by running each element in `collection` thru\\r\\n * `iteratee`. The iteratee is invoked with three arguments:\\r\\n * (value, index|key, collection).\\r\\n *\\r\\n * Many lodash methods are guarded to work as iteratees for methods like\\r\\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\\r\\n *\\r\\n * The guarded methods are:\\r\\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\\r\\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\\r\\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\\r\\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\\r\\n * @returns {Array} Returns the new mapped array.\\r\\n * @example\\r\\n *\\r\\n * function square(n) {\\r\\n * return n * n;\\r\\n * }\\r\\n *\\r\\n * _.map([4, 8], square);\\r\\n * // => [16, 64]\\r\\n *\\r\\n * _.map({ 'a': 4, 'b': 8 }, square);\\r\\n * // => [16, 64] (iteration order is not guaranteed)\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney' },\\r\\n * { 'user': 'fred' }\\r\\n * ];\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.map(users, 'user');\\r\\n * // => ['barney', 'fred']\\r\\n */\\r\\n function map(collection, iteratee) {\\r\\n var func = isArray(collection) ? arrayMap : baseMap;\\r\\n return func(collection, baseIteratee(iteratee, 3));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Reduces `collection` to a value which is the accumulated result of running\\r\\n * each element in `collection` thru `iteratee`, where each successive\\r\\n * invocation is supplied the return value of the previous. If `accumulator`\\r\\n * is not given, the first element of `collection` is used as the initial\\r\\n * value. The iteratee is invoked with four arguments:\\r\\n * (accumulator, value, index|key, collection).\\r\\n *\\r\\n * Many lodash methods are guarded to work as iteratees for methods like\\r\\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\\r\\n *\\r\\n * The guarded methods are:\\r\\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\\r\\n * and `sortBy`\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\\r\\n * @param {*} [accumulator] The initial value.\\r\\n * @returns {*} Returns the accumulated value.\\r\\n * @see _.reduceRight\\r\\n * @example\\r\\n *\\r\\n * _.reduce([1, 2], function(sum, n) {\\r\\n * return sum + n;\\r\\n * }, 0);\\r\\n * // => 3\\r\\n *\\r\\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\\r\\n * (result[value] || (result[value] = [])).push(key);\\r\\n * return result;\\r\\n * }, {});\\r\\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\\r\\n */\\r\\n function reduce(collection, iteratee, accumulator) {\\r\\n var func = isArray(collection) ? arrayReduce : baseReduce,\\r\\n initAccum = arguments.length < 3;\\r\\n\\r\\n return func(collection, baseIteratee(iteratee, 4), accumulator, initAccum, baseEach);\\r\\n }\\r\\n\\r\\n /**\\r\\n * The opposite of `_.filter`; this method returns the elements of `collection`\\r\\n * that `predicate` does **not** return truthy for.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @returns {Array} Returns the new filtered array.\\r\\n * @see _.filter\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'age': 36, 'active': false },\\r\\n * { 'user': 'fred', 'age': 40, 'active': true }\\r\\n * ];\\r\\n *\\r\\n * _.reject(users, function(o) { return !o.active; });\\r\\n * // => objects for ['fred']\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.reject(users, { 'age': 40, 'active': true });\\r\\n * // => objects for ['barney']\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.reject(users, ['active', false]);\\r\\n * // => objects for ['fred']\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.reject(users, 'active');\\r\\n * // => objects for ['barney']\\r\\n */\\r\\n function reject(collection, predicate) {\\r\\n var func = isArray(collection) ? arrayFilter : baseFilter;\\r\\n return func(collection, negate(baseIteratee(predicate, 3)));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the size of `collection` by returning its length for array-like\\r\\n * values or the number of own enumerable string keyed properties for objects.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object|string} collection The collection to inspect.\\r\\n * @returns {number} Returns the collection size.\\r\\n * @example\\r\\n *\\r\\n * _.size([1, 2, 3]);\\r\\n * // => 3\\r\\n *\\r\\n * _.size({ 'a': 1, 'b': 2 });\\r\\n * // => 2\\r\\n *\\r\\n * _.size('pebbles');\\r\\n * // => 7\\r\\n */\\r\\n function size(collection) {\\r\\n if (collection == null) {\\r\\n return 0;\\r\\n }\\r\\n if (isArrayLike(collection)) {\\r\\n return isString(collection) ? stringSize(collection) : collection.length;\\r\\n }\\r\\n var tag = getTag(collection);\\r\\n if (tag == mapTag || tag == setTag) {\\r\\n return collection.size;\\r\\n }\\r\\n return baseKeys(collection).length;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `predicate` returns truthy for **any** element of `collection`.\\r\\n * Iteration is stopped once `predicate` returns truthy. The predicate is\\r\\n * invoked with three arguments: (value, index|key, collection).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\\r\\n * @returns {boolean} Returns `true` if any element passes the predicate check,\\r\\n * else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.some([null, 0, 'yes', false], Boolean);\\r\\n * // => true\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'active': true },\\r\\n * { 'user': 'fred', 'active': false }\\r\\n * ];\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.some(users, { 'user': 'barney', 'active': false });\\r\\n * // => false\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.some(users, ['active', false]);\\r\\n * // => true\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.some(users, 'active');\\r\\n * // => true\\r\\n */\\r\\n function some(collection, predicate, guard) {\\r\\n var func = isArray(collection) ? arraySome : baseSome;\\r\\n if (guard && isIterateeCall(collection, predicate, guard)) {\\r\\n predicate = undefined;\\r\\n }\\r\\n return func(collection, baseIteratee(predicate, 3));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of elements, sorted in ascending order by the results of\\r\\n * running each element in a collection thru each iteratee. This method\\r\\n * performs a stable sort, that is, it preserves the original sort order of\\r\\n * equal elements. The iteratees are invoked with one argument: (value).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Collection\\r\\n * @param {Array|Object} collection The collection to iterate over.\\r\\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\\r\\n * The iteratees to sort by.\\r\\n * @returns {Array} Returns the new sorted array.\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'fred', 'age': 48 },\\r\\n * { 'user': 'barney', 'age': 36 },\\r\\n * { 'user': 'fred', 'age': 40 },\\r\\n * { 'user': 'barney', 'age': 34 }\\r\\n * ];\\r\\n *\\r\\n * _.sortBy(users, [function(o) { return o.user; }]);\\r\\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]\\r\\n *\\r\\n * _.sortBy(users, ['user', 'age']);\\r\\n * // => objects for [['barney', 34], ['barney', 36], ['fred', 40], ['fred', 48]]\\r\\n */\\r\\n var sortBy = baseRest(function(collection, iteratees) {\\r\\n if (collection == null) {\\r\\n return [];\\r\\n }\\r\\n var length = iteratees.length;\\r\\n if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) {\\r\\n iteratees = [];\\r\\n } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) {\\r\\n iteratees = [iteratees[0]];\\r\\n }\\r\\n return baseOrderBy(collection, baseFlatten(iteratees, 1), []);\\r\\n });\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Gets the timestamp of the number of milliseconds that have elapsed since\\r\\n * the Unix epoch (1 January 1970 00:00:00 UTC).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 2.4.0\\r\\n * @category Date\\r\\n * @returns {number} Returns the timestamp.\\r\\n * @example\\r\\n *\\r\\n * _.defer(function(stamp) {\\r\\n * console.log(_.now() - stamp);\\r\\n * }, _.now());\\r\\n * // => Logs the number of milliseconds it took for the deferred invocation.\\r\\n */\\r\\n var now = function() {\\r\\n return root.Date.now();\\r\\n };\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * The opposite of `_.before`; this method creates a function that invokes\\r\\n * `func` once it's called `n` or more times.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Function\\r\\n * @param {number} n The number of calls before `func` is invoked.\\r\\n * @param {Function} func The function to restrict.\\r\\n * @returns {Function} Returns the new restricted function.\\r\\n * @example\\r\\n *\\r\\n * var saves = ['profile', 'settings'];\\r\\n *\\r\\n * var done = _.after(saves.length, function() {\\r\\n * console.log('done saving!');\\r\\n * });\\r\\n *\\r\\n * _.forEach(saves, function(type) {\\r\\n * asyncSave({ 'type': type, 'complete': done });\\r\\n * });\\r\\n * // => Logs 'done saving!' after the two async saves have completed.\\r\\n */\\r\\n function after(n, func) {\\r\\n if (typeof func != 'function') {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n n = toInteger(n);\\r\\n return function() {\\r\\n if (--n < 1) {\\r\\n return func.apply(this, arguments);\\r\\n }\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that invokes `func`, with the `this` binding and arguments\\r\\n * of the created function, while it's called less than `n` times. Subsequent\\r\\n * calls to the created function return the result of the last `func` invocation.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Function\\r\\n * @param {number} n The number of calls at which `func` is no longer invoked.\\r\\n * @param {Function} func The function to restrict.\\r\\n * @returns {Function} Returns the new restricted function.\\r\\n * @example\\r\\n *\\r\\n * jQuery(element).on('click', _.before(5, addContactToList));\\r\\n * // => Allows adding up to 4 contacts to the list.\\r\\n */\\r\\n function before(n, func) {\\r\\n var result;\\r\\n if (typeof func != 'function') {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n n = toInteger(n);\\r\\n return function() {\\r\\n if (--n > 0) {\\r\\n result = func.apply(this, arguments);\\r\\n }\\r\\n if (n <= 1) {\\r\\n func = undefined;\\r\\n }\\r\\n return result;\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that invokes `func` with the `this` binding of `thisArg`\\r\\n * and `partials` prepended to the arguments it receives.\\r\\n *\\r\\n * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,\\r\\n * may be used as a placeholder for partially applied arguments.\\r\\n *\\r\\n * **Note:** Unlike native `Function#bind`, this method doesn't set the \\\"length\\\"\\r\\n * property of bound functions.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Function\\r\\n * @param {Function} func The function to bind.\\r\\n * @param {*} thisArg The `this` binding of `func`.\\r\\n * @param {...*} [partials] The arguments to be partially applied.\\r\\n * @returns {Function} Returns the new bound function.\\r\\n * @example\\r\\n *\\r\\n * function greet(greeting, punctuation) {\\r\\n * return greeting + ' ' + this.user + punctuation;\\r\\n * }\\r\\n *\\r\\n * var object = { 'user': 'fred' };\\r\\n *\\r\\n * var bound = _.bind(greet, object, 'hi');\\r\\n * bound('!');\\r\\n * // => 'hi fred!'\\r\\n *\\r\\n * // Bound with placeholders.\\r\\n * var bound = _.bind(greet, object, _, '!');\\r\\n * bound('hi');\\r\\n * // => 'hi fred!'\\r\\n */\\r\\n var bind = baseRest(function(func, thisArg, partials) {\\r\\n var bitmask = WRAP_BIND_FLAG;\\r\\n if (partials.length) {\\r\\n var holders = replaceHolders(partials, getHolder(bind));\\r\\n bitmask |= WRAP_PARTIAL_FLAG;\\r\\n }\\r\\n return createWrap(func, bitmask, thisArg, partials, holders);\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates a debounced function that delays invoking `func` until after `wait`\\r\\n * milliseconds have elapsed since the last time the debounced function was\\r\\n * invoked. The debounced function comes with a `cancel` method to cancel\\r\\n * delayed `func` invocations and a `flush` method to immediately invoke them.\\r\\n * Provide `options` to indicate whether `func` should be invoked on the\\r\\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\\r\\n * with the last arguments provided to the debounced function. Subsequent\\r\\n * calls to the debounced function return the result of the last `func`\\r\\n * invocation.\\r\\n *\\r\\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\\r\\n * invoked on the trailing edge of the timeout only if the debounced function\\r\\n * is invoked more than once during the `wait` timeout.\\r\\n *\\r\\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\\r\\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\\r\\n *\\r\\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\\r\\n * for details over the differences between `_.debounce` and `_.throttle`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Function\\r\\n * @param {Function} func The function to debounce.\\r\\n * @param {number} [wait=0] The number of milliseconds to delay.\\r\\n * @param {Object} [options={}] The options object.\\r\\n * @param {boolean} [options.leading=false]\\r\\n * Specify invoking on the leading edge of the timeout.\\r\\n * @param {number} [options.maxWait]\\r\\n * The maximum time `func` is allowed to be delayed before it's invoked.\\r\\n * @param {boolean} [options.trailing=true]\\r\\n * Specify invoking on the trailing edge of the timeout.\\r\\n * @returns {Function} Returns the new debounced function.\\r\\n * @example\\r\\n *\\r\\n * // Avoid costly calculations while the window size is in flux.\\r\\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\\r\\n *\\r\\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\\r\\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\\r\\n * 'leading': true,\\r\\n * 'trailing': false\\r\\n * }));\\r\\n *\\r\\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\\r\\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\\r\\n * var source = new EventSource('/stream');\\r\\n * jQuery(source).on('message', debounced);\\r\\n *\\r\\n * // Cancel the trailing debounced invocation.\\r\\n * jQuery(window).on('popstate', debounced.cancel);\\r\\n */\\r\\n function debounce(func, wait, options) {\\r\\n var lastArgs,\\r\\n lastThis,\\r\\n maxWait,\\r\\n result,\\r\\n timerId,\\r\\n lastCallTime,\\r\\n lastInvokeTime = 0,\\r\\n leading = false,\\r\\n maxing = false,\\r\\n trailing = true;\\r\\n\\r\\n if (typeof func != 'function') {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n wait = toNumber(wait) || 0;\\r\\n if (isObject(options)) {\\r\\n leading = !!options.leading;\\r\\n maxing = 'maxWait' in options;\\r\\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\\r\\n trailing = 'trailing' in options ? !!options.trailing : trailing;\\r\\n }\\r\\n\\r\\n function invokeFunc(time) {\\r\\n var args = lastArgs,\\r\\n thisArg = lastThis;\\r\\n\\r\\n lastArgs = lastThis = undefined;\\r\\n lastInvokeTime = time;\\r\\n result = func.apply(thisArg, args);\\r\\n return result;\\r\\n }\\r\\n\\r\\n function leadingEdge(time) {\\r\\n // Reset any `maxWait` timer.\\r\\n lastInvokeTime = time;\\r\\n // Start the timer for the trailing edge.\\r\\n timerId = setTimeout(timerExpired, wait);\\r\\n // Invoke the leading edge.\\r\\n return leading ? invokeFunc(time) : result;\\r\\n }\\r\\n\\r\\n function remainingWait(time) {\\r\\n var timeSinceLastCall = time - lastCallTime,\\r\\n timeSinceLastInvoke = time - lastInvokeTime,\\r\\n timeWaiting = wait - timeSinceLastCall;\\r\\n\\r\\n return maxing\\r\\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\\r\\n : timeWaiting;\\r\\n }\\r\\n\\r\\n function shouldInvoke(time) {\\r\\n var timeSinceLastCall = time - lastCallTime,\\r\\n timeSinceLastInvoke = time - lastInvokeTime;\\r\\n\\r\\n // Either this is the first call, activity has stopped and we're at the\\r\\n // trailing edge, the system time has gone backwards and we're treating\\r\\n // it as the trailing edge, or we've hit the `maxWait` limit.\\r\\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\\r\\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\\r\\n }\\r\\n\\r\\n function timerExpired() {\\r\\n var time = now();\\r\\n if (shouldInvoke(time)) {\\r\\n return trailingEdge(time);\\r\\n }\\r\\n // Restart the timer.\\r\\n timerId = setTimeout(timerExpired, remainingWait(time));\\r\\n }\\r\\n\\r\\n function trailingEdge(time) {\\r\\n timerId = undefined;\\r\\n\\r\\n // Only invoke if we have `lastArgs` which means `func` has been\\r\\n // debounced at least once.\\r\\n if (trailing && lastArgs) {\\r\\n return invokeFunc(time);\\r\\n }\\r\\n lastArgs = lastThis = undefined;\\r\\n return result;\\r\\n }\\r\\n\\r\\n function cancel() {\\r\\n if (timerId !== undefined) {\\r\\n clearTimeout(timerId);\\r\\n }\\r\\n lastInvokeTime = 0;\\r\\n lastArgs = lastCallTime = lastThis = timerId = undefined;\\r\\n }\\r\\n\\r\\n function flush() {\\r\\n return timerId === undefined ? result : trailingEdge(now());\\r\\n }\\r\\n\\r\\n function debounced() {\\r\\n var time = now(),\\r\\n isInvoking = shouldInvoke(time);\\r\\n\\r\\n lastArgs = arguments;\\r\\n lastThis = this;\\r\\n lastCallTime = time;\\r\\n\\r\\n if (isInvoking) {\\r\\n if (timerId === undefined) {\\r\\n return leadingEdge(lastCallTime);\\r\\n }\\r\\n if (maxing) {\\r\\n // Handle invocations in a tight loop.\\r\\n timerId = setTimeout(timerExpired, wait);\\r\\n return invokeFunc(lastCallTime);\\r\\n }\\r\\n }\\r\\n if (timerId === undefined) {\\r\\n timerId = setTimeout(timerExpired, wait);\\r\\n }\\r\\n return result;\\r\\n }\\r\\n debounced.cancel = cancel;\\r\\n debounced.flush = flush;\\r\\n return debounced;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Defers invoking the `func` until the current call stack has cleared. Any\\r\\n * additional arguments are provided to `func` when it's invoked.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Function\\r\\n * @param {Function} func The function to defer.\\r\\n * @param {...*} [args] The arguments to invoke `func` with.\\r\\n * @returns {number} Returns the timer id.\\r\\n * @example\\r\\n *\\r\\n * _.defer(function(text) {\\r\\n * console.log(text);\\r\\n * }, 'deferred');\\r\\n * // => Logs 'deferred' after one millisecond.\\r\\n */\\r\\n var defer = baseRest(function(func, args) {\\r\\n return baseDelay(func, 1, args);\\r\\n });\\r\\n\\r\\n /**\\r\\n * Invokes `func` after `wait` milliseconds. Any additional arguments are\\r\\n * provided to `func` when it's invoked.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Function\\r\\n * @param {Function} func The function to delay.\\r\\n * @param {number} wait The number of milliseconds to delay invocation.\\r\\n * @param {...*} [args] The arguments to invoke `func` with.\\r\\n * @returns {number} Returns the timer id.\\r\\n * @example\\r\\n *\\r\\n * _.delay(function(text) {\\r\\n * console.log(text);\\r\\n * }, 1000, 'later');\\r\\n * // => Logs 'later' after one second.\\r\\n */\\r\\n var delay = baseRest(function(func, wait, args) {\\r\\n return baseDelay(func, toNumber(wait) || 0, args);\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates a function that memoizes the result of `func`. If `resolver` is\\r\\n * provided, it determines the cache key for storing the result based on the\\r\\n * arguments provided to the memoized function. By default, the first argument\\r\\n * provided to the memoized function is used as the map cache key. The `func`\\r\\n * is invoked with the `this` binding of the memoized function.\\r\\n *\\r\\n * **Note:** The cache is exposed as the `cache` property on the memoized\\r\\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\\r\\n * constructor with one whose instances implement the\\r\\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\\r\\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Function\\r\\n * @param {Function} func The function to have its output memoized.\\r\\n * @param {Function} [resolver] The function to resolve the cache key.\\r\\n * @returns {Function} Returns the new memoized function.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1, 'b': 2 };\\r\\n * var other = { 'c': 3, 'd': 4 };\\r\\n *\\r\\n * var values = _.memoize(_.values);\\r\\n * values(object);\\r\\n * // => [1, 2]\\r\\n *\\r\\n * values(other);\\r\\n * // => [3, 4]\\r\\n *\\r\\n * object.a = 2;\\r\\n * values(object);\\r\\n * // => [1, 2]\\r\\n *\\r\\n * // Modify the result cache.\\r\\n * values.cache.set(object, ['a', 'b']);\\r\\n * values(object);\\r\\n * // => ['a', 'b']\\r\\n *\\r\\n * // Replace `_.memoize.Cache`.\\r\\n * _.memoize.Cache = WeakMap;\\r\\n */\\r\\n function memoize(func, resolver) {\\r\\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n var memoized = function() {\\r\\n var args = arguments,\\r\\n key = resolver ? resolver.apply(this, args) : args[0],\\r\\n cache = memoized.cache;\\r\\n\\r\\n if (cache.has(key)) {\\r\\n return cache.get(key);\\r\\n }\\r\\n var result = func.apply(this, args);\\r\\n memoized.cache = cache.set(key, result) || cache;\\r\\n return result;\\r\\n };\\r\\n memoized.cache = new (memoize.Cache || MapCache);\\r\\n return memoized;\\r\\n }\\r\\n\\r\\n // Expose `MapCache`.\\r\\n memoize.Cache = MapCache;\\r\\n\\r\\n /**\\r\\n * Creates a function that negates the result of the predicate `func`. The\\r\\n * `func` predicate is invoked with the `this` binding and arguments of the\\r\\n * created function.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Function\\r\\n * @param {Function} predicate The predicate to negate.\\r\\n * @returns {Function} Returns the new negated function.\\r\\n * @example\\r\\n *\\r\\n * function isEven(n) {\\r\\n * return n % 2 == 0;\\r\\n * }\\r\\n *\\r\\n * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven));\\r\\n * // => [1, 3, 5]\\r\\n */\\r\\n function negate(predicate) {\\r\\n if (typeof predicate != 'function') {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n return function() {\\r\\n var args = arguments;\\r\\n switch (args.length) {\\r\\n case 0: return !predicate.call(this);\\r\\n case 1: return !predicate.call(this, args[0]);\\r\\n case 2: return !predicate.call(this, args[0], args[1]);\\r\\n case 3: return !predicate.call(this, args[0], args[1], args[2]);\\r\\n }\\r\\n return !predicate.apply(this, args);\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that is restricted to invoking `func` once. Repeat calls\\r\\n * to the function return the value of the first invocation. The `func` is\\r\\n * invoked with the `this` binding and arguments of the created function.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Function\\r\\n * @param {Function} func The function to restrict.\\r\\n * @returns {Function} Returns the new restricted function.\\r\\n * @example\\r\\n *\\r\\n * var initialize = _.once(createApplication);\\r\\n * initialize();\\r\\n * initialize();\\r\\n * // => `createApplication` is invoked once\\r\\n */\\r\\n function once(func) {\\r\\n return before(2, func);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that invokes `func` with the `this` binding of the\\r\\n * created function and arguments from `start` and beyond provided as\\r\\n * an array.\\r\\n *\\r\\n * **Note:** This method is based on the\\r\\n * [rest parameter](https://mdn.io/rest_parameters).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Function\\r\\n * @param {Function} func The function to apply a rest parameter to.\\r\\n * @param {number} [start=func.length-1] The start position of the rest parameter.\\r\\n * @returns {Function} Returns the new function.\\r\\n * @example\\r\\n *\\r\\n * var say = _.rest(function(what, names) {\\r\\n * return what + ' ' + _.initial(names).join(', ') +\\r\\n * (_.size(names) > 1 ? ', & ' : '') + _.last(names);\\r\\n * });\\r\\n *\\r\\n * say('hello', 'fred', 'barney', 'pebbles');\\r\\n * // => 'hello fred, barney, & pebbles'\\r\\n */\\r\\n function rest(func, start) {\\r\\n if (typeof func != 'function') {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n start = start === undefined ? start : toInteger(start);\\r\\n return baseRest(func, start);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a throttled function that only invokes `func` at most once per\\r\\n * every `wait` milliseconds. The throttled function comes with a `cancel`\\r\\n * method to cancel delayed `func` invocations and a `flush` method to\\r\\n * immediately invoke them. Provide `options` to indicate whether `func`\\r\\n * should be invoked on the leading and/or trailing edge of the `wait`\\r\\n * timeout. The `func` is invoked with the last arguments provided to the\\r\\n * throttled function. Subsequent calls to the throttled function return the\\r\\n * result of the last `func` invocation.\\r\\n *\\r\\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\\r\\n * invoked on the trailing edge of the timeout only if the throttled function\\r\\n * is invoked more than once during the `wait` timeout.\\r\\n *\\r\\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\\r\\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\\r\\n *\\r\\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\\r\\n * for details over the differences between `_.throttle` and `_.debounce`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Function\\r\\n * @param {Function} func The function to throttle.\\r\\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\\r\\n * @param {Object} [options={}] The options object.\\r\\n * @param {boolean} [options.leading=true]\\r\\n * Specify invoking on the leading edge of the timeout.\\r\\n * @param {boolean} [options.trailing=true]\\r\\n * Specify invoking on the trailing edge of the timeout.\\r\\n * @returns {Function} Returns the new throttled function.\\r\\n * @example\\r\\n *\\r\\n * // Avoid excessively updating the position while scrolling.\\r\\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\\r\\n *\\r\\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\\r\\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\\r\\n * jQuery(element).on('click', throttled);\\r\\n *\\r\\n * // Cancel the trailing throttled invocation.\\r\\n * jQuery(window).on('popstate', throttled.cancel);\\r\\n */\\r\\n function throttle(func, wait, options) {\\r\\n var leading = true,\\r\\n trailing = true;\\r\\n\\r\\n if (typeof func != 'function') {\\r\\n throw new TypeError(FUNC_ERROR_TEXT);\\r\\n }\\r\\n if (isObject(options)) {\\r\\n leading = 'leading' in options ? !!options.leading : leading;\\r\\n trailing = 'trailing' in options ? !!options.trailing : trailing;\\r\\n }\\r\\n return debounce(func, wait, {\\r\\n 'leading': leading,\\r\\n 'maxWait': wait,\\r\\n 'trailing': trailing\\r\\n });\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates a shallow clone of `value`.\\r\\n *\\r\\n * **Note:** This method is loosely based on the\\r\\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\\r\\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\\r\\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\\r\\n * arrays. The own enumerable properties of `arguments` objects are cloned\\r\\n * as plain objects. An empty object is returned for uncloneable values such\\r\\n * as error objects, functions, DOM nodes, and WeakMaps.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to clone.\\r\\n * @returns {*} Returns the cloned value.\\r\\n * @see _.cloneDeep\\r\\n * @example\\r\\n *\\r\\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\\r\\n *\\r\\n * var shallow = _.clone(objects);\\r\\n * console.log(shallow[0] === objects[0]);\\r\\n * // => true\\r\\n */\\r\\n function clone(value) {\\r\\n return baseClone(value, CLONE_SYMBOLS_FLAG);\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.clone` except that it recursively clones `value`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 1.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to recursively clone.\\r\\n * @returns {*} Returns the deep cloned value.\\r\\n * @see _.clone\\r\\n * @example\\r\\n *\\r\\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\\r\\n *\\r\\n * var deep = _.cloneDeep(objects);\\r\\n * console.log(deep[0] === objects[0]);\\r\\n * // => false\\r\\n */\\r\\n function cloneDeep(value) {\\r\\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Performs a\\r\\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\\r\\n * comparison between two values to determine if they are equivalent.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to compare.\\r\\n * @param {*} other The other value to compare.\\r\\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1 };\\r\\n * var other = { 'a': 1 };\\r\\n *\\r\\n * _.eq(object, object);\\r\\n * // => true\\r\\n *\\r\\n * _.eq(object, other);\\r\\n * // => false\\r\\n *\\r\\n * _.eq('a', 'a');\\r\\n * // => true\\r\\n *\\r\\n * _.eq('a', Object('a'));\\r\\n * // => false\\r\\n *\\r\\n * _.eq(NaN, NaN);\\r\\n * // => true\\r\\n */\\r\\n function eq(value, other) {\\r\\n return value === other || (value !== value && other !== other);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is likely an `arguments` object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\\r\\n * else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isArguments(function() { return arguments; }());\\r\\n * // => true\\r\\n *\\r\\n * _.isArguments([1, 2, 3]);\\r\\n * // => false\\r\\n */\\r\\n var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\\r\\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\\r\\n !propertyIsEnumerable.call(value, 'callee');\\r\\n };\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as an `Array` object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isArray([1, 2, 3]);\\r\\n * // => true\\r\\n *\\r\\n * _.isArray(document.body.children);\\r\\n * // => false\\r\\n *\\r\\n * _.isArray('abc');\\r\\n * // => false\\r\\n *\\r\\n * _.isArray(_.noop);\\r\\n * // => false\\r\\n */\\r\\n var isArray = Array.isArray;\\r\\n\\r\\n /**\\r\\n * Checks if `value` is array-like. A value is considered array-like if it's\\r\\n * not a function and has a `value.length` that's an integer greater than or\\r\\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isArrayLike([1, 2, 3]);\\r\\n * // => true\\r\\n *\\r\\n * _.isArrayLike(document.body.children);\\r\\n * // => true\\r\\n *\\r\\n * _.isArrayLike('abc');\\r\\n * // => true\\r\\n *\\r\\n * _.isArrayLike(_.noop);\\r\\n * // => false\\r\\n */\\r\\n function isArrayLike(value) {\\r\\n return value != null && isLength(value.length) && !isFunction(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.isArrayLike` except that it also checks if `value`\\r\\n * is an object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is an array-like object,\\r\\n * else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isArrayLikeObject([1, 2, 3]);\\r\\n * // => true\\r\\n *\\r\\n * _.isArrayLikeObject(document.body.children);\\r\\n * // => true\\r\\n *\\r\\n * _.isArrayLikeObject('abc');\\r\\n * // => false\\r\\n *\\r\\n * _.isArrayLikeObject(_.noop);\\r\\n * // => false\\r\\n */\\r\\n function isArrayLikeObject(value) {\\r\\n return isObjectLike(value) && isArrayLike(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a boolean primitive or object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a boolean, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isBoolean(false);\\r\\n * // => true\\r\\n *\\r\\n * _.isBoolean(null);\\r\\n * // => false\\r\\n */\\r\\n function isBoolean(value) {\\r\\n return value === true || value === false ||\\r\\n (isObjectLike(value) && baseGetTag(value) == boolTag);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is a buffer.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.3.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isBuffer(new Buffer(2));\\r\\n * // => true\\r\\n *\\r\\n * _.isBuffer(new Uint8Array(2));\\r\\n * // => false\\r\\n */\\r\\n var isBuffer = nativeIsBuffer || stubFalse;\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a `Date` object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isDate(new Date);\\r\\n * // => true\\r\\n *\\r\\n * _.isDate('Mon April 23 2012');\\r\\n * // => false\\r\\n */\\r\\n var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate;\\r\\n\\r\\n /**\\r\\n * Checks if `value` is an empty object, collection, map, or set.\\r\\n *\\r\\n * Objects are considered empty if they have no own enumerable string keyed\\r\\n * properties.\\r\\n *\\r\\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\\r\\n * jQuery-like collections are considered empty if they have a `length` of `0`.\\r\\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isEmpty(null);\\r\\n * // => true\\r\\n *\\r\\n * _.isEmpty(true);\\r\\n * // => true\\r\\n *\\r\\n * _.isEmpty(1);\\r\\n * // => true\\r\\n *\\r\\n * _.isEmpty([1, 2, 3]);\\r\\n * // => false\\r\\n *\\r\\n * _.isEmpty({ 'a': 1 });\\r\\n * // => false\\r\\n */\\r\\n function isEmpty(value) {\\r\\n if (value == null) {\\r\\n return true;\\r\\n }\\r\\n if (isArrayLike(value) &&\\r\\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\\r\\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\\r\\n return !value.length;\\r\\n }\\r\\n var tag = getTag(value);\\r\\n if (tag == mapTag || tag == setTag) {\\r\\n return !value.size;\\r\\n }\\r\\n if (isPrototype(value)) {\\r\\n return !baseKeys(value).length;\\r\\n }\\r\\n for (var key in value) {\\r\\n if (hasOwnProperty.call(value, key)) {\\r\\n return false;\\r\\n }\\r\\n }\\r\\n return true;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Performs a deep comparison between two values to determine if they are\\r\\n * equivalent.\\r\\n *\\r\\n * **Note:** This method supports comparing arrays, array buffers, booleans,\\r\\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\\r\\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\\r\\n * by their own, not inherited, enumerable properties. Functions and DOM\\r\\n * nodes are compared by strict equality, i.e. `===`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to compare.\\r\\n * @param {*} other The other value to compare.\\r\\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1 };\\r\\n * var other = { 'a': 1 };\\r\\n *\\r\\n * _.isEqual(object, other);\\r\\n * // => true\\r\\n *\\r\\n * object === other;\\r\\n * // => false\\r\\n */\\r\\n function isEqual(value, other) {\\r\\n return baseIsEqual(value, other);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is a finite primitive number.\\r\\n *\\r\\n * **Note:** This method is based on\\r\\n * [`Number.isFinite`](https://mdn.io/Number/isFinite).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a finite number, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isFinite(3);\\r\\n * // => true\\r\\n *\\r\\n * _.isFinite(Number.MIN_VALUE);\\r\\n * // => true\\r\\n *\\r\\n * _.isFinite(Infinity);\\r\\n * // => false\\r\\n *\\r\\n * _.isFinite('3');\\r\\n * // => false\\r\\n */\\r\\n function isFinite(value) {\\r\\n return typeof value == 'number' && nativeIsFinite(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a `Function` object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isFunction(_);\\r\\n * // => true\\r\\n *\\r\\n * _.isFunction(/abc/);\\r\\n * // => false\\r\\n */\\r\\n function isFunction(value) {\\r\\n if (!isObject(value)) {\\r\\n return false;\\r\\n }\\r\\n // The use of `Object#toString` avoids issues with the `typeof` operator\\r\\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\\r\\n var tag = baseGetTag(value);\\r\\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is a valid array-like length.\\r\\n *\\r\\n * **Note:** This method is loosely based on\\r\\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isLength(3);\\r\\n * // => true\\r\\n *\\r\\n * _.isLength(Number.MIN_VALUE);\\r\\n * // => false\\r\\n *\\r\\n * _.isLength(Infinity);\\r\\n * // => false\\r\\n *\\r\\n * _.isLength('3');\\r\\n * // => false\\r\\n */\\r\\n function isLength(value) {\\r\\n return typeof value == 'number' &&\\r\\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is the\\r\\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\\r\\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isObject({});\\r\\n * // => true\\r\\n *\\r\\n * _.isObject([1, 2, 3]);\\r\\n * // => true\\r\\n *\\r\\n * _.isObject(_.noop);\\r\\n * // => true\\r\\n *\\r\\n * _.isObject(null);\\r\\n * // => false\\r\\n */\\r\\n function isObject(value) {\\r\\n var type = typeof value;\\r\\n return value != null && (type == 'object' || type == 'function');\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is object-like. A value is object-like if it's not `null`\\r\\n * and has a `typeof` result of \\\"object\\\".\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isObjectLike({});\\r\\n * // => true\\r\\n *\\r\\n * _.isObjectLike([1, 2, 3]);\\r\\n * // => true\\r\\n *\\r\\n * _.isObjectLike(_.noop);\\r\\n * // => false\\r\\n *\\r\\n * _.isObjectLike(null);\\r\\n * // => false\\r\\n */\\r\\n function isObjectLike(value) {\\r\\n return value != null && typeof value == 'object';\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a `Map` object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.3.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isMap(new Map);\\r\\n * // => true\\r\\n *\\r\\n * _.isMap(new WeakMap);\\r\\n * // => false\\r\\n */\\r\\n var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\\r\\n\\r\\n /**\\r\\n * Checks if `value` is `NaN`.\\r\\n *\\r\\n * **Note:** This method is based on\\r\\n * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as\\r\\n * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for\\r\\n * `undefined` and other non-number values.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isNaN(NaN);\\r\\n * // => true\\r\\n *\\r\\n * _.isNaN(new Number(NaN));\\r\\n * // => true\\r\\n *\\r\\n * isNaN(undefined);\\r\\n * // => true\\r\\n *\\r\\n * _.isNaN(undefined);\\r\\n * // => false\\r\\n */\\r\\n function isNaN(value) {\\r\\n // An `NaN` primitive is the only value that is not equal to itself.\\r\\n // Perform the `toStringTag` check first to avoid errors with some\\r\\n // ActiveX objects in IE.\\r\\n return isNumber(value) && value != +value;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is `null`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is `null`, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isNull(null);\\r\\n * // => true\\r\\n *\\r\\n * _.isNull(void 0);\\r\\n * // => false\\r\\n */\\r\\n function isNull(value) {\\r\\n return value === null;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a `Number` primitive or object.\\r\\n *\\r\\n * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are\\r\\n * classified as numbers, use the `_.isFinite` method.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a number, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isNumber(3);\\r\\n * // => true\\r\\n *\\r\\n * _.isNumber(Number.MIN_VALUE);\\r\\n * // => true\\r\\n *\\r\\n * _.isNumber(Infinity);\\r\\n * // => true\\r\\n *\\r\\n * _.isNumber('3');\\r\\n * // => false\\r\\n */\\r\\n function isNumber(value) {\\r\\n return typeof value == 'number' ||\\r\\n (isObjectLike(value) && baseGetTag(value) == numberTag);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is a plain object, that is, an object created by the\\r\\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.8.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\\r\\n * @example\\r\\n *\\r\\n * function Foo() {\\r\\n * this.a = 1;\\r\\n * }\\r\\n *\\r\\n * _.isPlainObject(new Foo);\\r\\n * // => false\\r\\n *\\r\\n * _.isPlainObject([1, 2, 3]);\\r\\n * // => false\\r\\n *\\r\\n * _.isPlainObject({ 'x': 0, 'y': 0 });\\r\\n * // => true\\r\\n *\\r\\n * _.isPlainObject(Object.create(null));\\r\\n * // => true\\r\\n */\\r\\n function isPlainObject(value) {\\r\\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\\r\\n return false;\\r\\n }\\r\\n var proto = getPrototype(value);\\r\\n if (proto === null) {\\r\\n return true;\\r\\n }\\r\\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\\r\\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\\r\\n funcToString.call(Ctor) == objectCtorString;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a `RegExp` object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.1.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isRegExp(/abc/);\\r\\n * // => true\\r\\n *\\r\\n * _.isRegExp('/abc/');\\r\\n * // => false\\r\\n */\\r\\n var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp;\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a `Set` object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.3.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isSet(new Set);\\r\\n * // => true\\r\\n *\\r\\n * _.isSet(new WeakSet);\\r\\n * // => false\\r\\n */\\r\\n var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a `String` primitive or object.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isString('abc');\\r\\n * // => true\\r\\n *\\r\\n * _.isString(1);\\r\\n * // => false\\r\\n */\\r\\n function isString(value) {\\r\\n return typeof value == 'string' ||\\r\\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a `Symbol` primitive or object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isSymbol(Symbol.iterator);\\r\\n * // => true\\r\\n *\\r\\n * _.isSymbol('abc');\\r\\n * // => false\\r\\n */\\r\\n function isSymbol(value) {\\r\\n return typeof value == 'symbol' ||\\r\\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `value` is classified as a typed array.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isTypedArray(new Uint8Array);\\r\\n * // => true\\r\\n *\\r\\n * _.isTypedArray([]);\\r\\n * // => false\\r\\n */\\r\\n var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\\r\\n\\r\\n /**\\r\\n * Checks if `value` is `undefined`.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Lang\\r\\n * @param {*} value The value to check.\\r\\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\\r\\n * @example\\r\\n *\\r\\n * _.isUndefined(void 0);\\r\\n * // => true\\r\\n *\\r\\n * _.isUndefined(null);\\r\\n * // => false\\r\\n */\\r\\n function isUndefined(value) {\\r\\n return value === undefined;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `value` to an array.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Lang\\r\\n * @param {*} value The value to convert.\\r\\n * @returns {Array} Returns the converted array.\\r\\n * @example\\r\\n *\\r\\n * _.toArray({ 'a': 1, 'b': 2 });\\r\\n * // => [1, 2]\\r\\n *\\r\\n * _.toArray('abc');\\r\\n * // => ['a', 'b', 'c']\\r\\n *\\r\\n * _.toArray(1);\\r\\n * // => []\\r\\n *\\r\\n * _.toArray(null);\\r\\n * // => []\\r\\n */\\r\\n function toArray(value) {\\r\\n if (!value) {\\r\\n return [];\\r\\n }\\r\\n if (isArrayLike(value)) {\\r\\n return isString(value) ? stringToArray(value) : copyArray(value);\\r\\n }\\r\\n if (symIterator && value[symIterator]) {\\r\\n return iteratorToArray(value[symIterator]());\\r\\n }\\r\\n var tag = getTag(value),\\r\\n func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values);\\r\\n\\r\\n return func(value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `value` to a finite number.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.12.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to convert.\\r\\n * @returns {number} Returns the converted number.\\r\\n * @example\\r\\n *\\r\\n * _.toFinite(3.2);\\r\\n * // => 3.2\\r\\n *\\r\\n * _.toFinite(Number.MIN_VALUE);\\r\\n * // => 5e-324\\r\\n *\\r\\n * _.toFinite(Infinity);\\r\\n * // => 1.7976931348623157e+308\\r\\n *\\r\\n * _.toFinite('3.2');\\r\\n * // => 3.2\\r\\n */\\r\\n function toFinite(value) {\\r\\n if (!value) {\\r\\n return value === 0 ? value : 0;\\r\\n }\\r\\n value = toNumber(value);\\r\\n if (value === INFINITY || value === -INFINITY) {\\r\\n var sign = (value < 0 ? -1 : 1);\\r\\n return sign * MAX_INTEGER;\\r\\n }\\r\\n return value === value ? value : 0;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `value` to an integer.\\r\\n *\\r\\n * **Note:** This method is loosely based on\\r\\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to convert.\\r\\n * @returns {number} Returns the converted integer.\\r\\n * @example\\r\\n *\\r\\n * _.toInteger(3.2);\\r\\n * // => 3\\r\\n *\\r\\n * _.toInteger(Number.MIN_VALUE);\\r\\n * // => 0\\r\\n *\\r\\n * _.toInteger(Infinity);\\r\\n * // => 1.7976931348623157e+308\\r\\n *\\r\\n * _.toInteger('3.2');\\r\\n * // => 3\\r\\n */\\r\\n function toInteger(value) {\\r\\n var result = toFinite(value),\\r\\n remainder = result % 1;\\r\\n\\r\\n return result === result ? (remainder ? result - remainder : result) : 0;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `value` to a number.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to process.\\r\\n * @returns {number} Returns the number.\\r\\n * @example\\r\\n *\\r\\n * _.toNumber(3.2);\\r\\n * // => 3.2\\r\\n *\\r\\n * _.toNumber(Number.MIN_VALUE);\\r\\n * // => 5e-324\\r\\n *\\r\\n * _.toNumber(Infinity);\\r\\n * // => Infinity\\r\\n *\\r\\n * _.toNumber('3.2');\\r\\n * // => 3.2\\r\\n */\\r\\n function toNumber(value) {\\r\\n if (typeof value == 'number') {\\r\\n return value;\\r\\n }\\r\\n if (isSymbol(value)) {\\r\\n return NAN;\\r\\n }\\r\\n if (isObject(value)) {\\r\\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\\r\\n value = isObject(other) ? (other + '') : other;\\r\\n }\\r\\n if (typeof value != 'string') {\\r\\n return value === 0 ? value : +value;\\r\\n }\\r\\n value = value.replace(reTrim, '');\\r\\n var isBinary = reIsBinary.test(value);\\r\\n return (isBinary || reIsOctal.test(value))\\r\\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\\r\\n : (reIsBadHex.test(value) ? NAN : +value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `value` to a plain object flattening inherited enumerable string\\r\\n * keyed properties of `value` to own properties of the plain object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to convert.\\r\\n * @returns {Object} Returns the converted plain object.\\r\\n * @example\\r\\n *\\r\\n * function Foo() {\\r\\n * this.b = 2;\\r\\n * }\\r\\n *\\r\\n * Foo.prototype.c = 3;\\r\\n *\\r\\n * _.assign({ 'a': 1 }, new Foo);\\r\\n * // => { 'a': 1, 'b': 2 }\\r\\n *\\r\\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\\r\\n * // => { 'a': 1, 'b': 2, 'c': 3 }\\r\\n */\\r\\n function toPlainObject(value) {\\r\\n return copyObject(value, keysIn(value));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Converts `value` to a string. An empty string is returned for `null`\\r\\n * and `undefined` values. The sign of `-0` is preserved.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Lang\\r\\n * @param {*} value The value to convert.\\r\\n * @returns {string} Returns the converted string.\\r\\n * @example\\r\\n *\\r\\n * _.toString(null);\\r\\n * // => ''\\r\\n *\\r\\n * _.toString(-0);\\r\\n * // => '-0'\\r\\n *\\r\\n * _.toString([1, 2, 3]);\\r\\n * // => '1,2,3'\\r\\n */\\r\\n function toString(value) {\\r\\n return value == null ? '' : baseToString(value);\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * This method is like `_.assign` except that it iterates over own and\\r\\n * inherited source properties.\\r\\n *\\r\\n * **Note:** This method mutates `object`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @alias extend\\r\\n * @category Object\\r\\n * @param {Object} object The destination object.\\r\\n * @param {...Object} [sources] The source objects.\\r\\n * @returns {Object} Returns `object`.\\r\\n * @see _.assign\\r\\n * @example\\r\\n *\\r\\n * function Foo() {\\r\\n * this.a = 1;\\r\\n * }\\r\\n *\\r\\n * function Bar() {\\r\\n * this.c = 3;\\r\\n * }\\r\\n *\\r\\n * Foo.prototype.b = 2;\\r\\n * Bar.prototype.d = 4;\\r\\n *\\r\\n * _.assignIn({ 'a': 0 }, new Foo, new Bar);\\r\\n * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }\\r\\n */\\r\\n var assignIn = createAssigner(function(object, source) {\\r\\n copyObject(source, keysIn(source), object);\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates an object that inherits from the `prototype` object. If a\\r\\n * `properties` object is given, its own enumerable string keyed properties\\r\\n * are assigned to the created object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 2.3.0\\r\\n * @category Object\\r\\n * @param {Object} prototype The object to inherit from.\\r\\n * @param {Object} [properties] The properties to assign to the object.\\r\\n * @returns {Object} Returns the new object.\\r\\n * @example\\r\\n *\\r\\n * function Shape() {\\r\\n * this.x = 0;\\r\\n * this.y = 0;\\r\\n * }\\r\\n *\\r\\n * function Circle() {\\r\\n * Shape.call(this);\\r\\n * }\\r\\n *\\r\\n * Circle.prototype = _.create(Shape.prototype, {\\r\\n * 'constructor': Circle\\r\\n * });\\r\\n *\\r\\n * var circle = new Circle;\\r\\n * circle instanceof Circle;\\r\\n * // => true\\r\\n *\\r\\n * circle instanceof Shape;\\r\\n * // => true\\r\\n */\\r\\n function create(prototype, properties) {\\r\\n var result = baseCreate(prototype);\\r\\n return properties == null ? result : baseAssign(result, properties);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Assigns own and inherited enumerable string keyed properties of source\\r\\n * objects to the destination object for all destination properties that\\r\\n * resolve to `undefined`. Source objects are applied from left to right.\\r\\n * Once a property is set, additional values of the same property are ignored.\\r\\n *\\r\\n * **Note:** This method mutates `object`.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Object\\r\\n * @param {Object} object The destination object.\\r\\n * @param {...Object} [sources] The source objects.\\r\\n * @returns {Object} Returns `object`.\\r\\n * @see _.defaultsDeep\\r\\n * @example\\r\\n *\\r\\n * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\\r\\n * // => { 'a': 1, 'b': 2 }\\r\\n */\\r\\n var defaults = baseRest(function(object, sources) {\\r\\n object = Object(object);\\r\\n\\r\\n var index = -1;\\r\\n var length = sources.length;\\r\\n var guard = length > 2 ? sources[2] : undefined;\\r\\n\\r\\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\\r\\n length = 1;\\r\\n }\\r\\n\\r\\n while (++index < length) {\\r\\n var source = sources[index];\\r\\n var props = keysIn(source);\\r\\n var propsIndex = -1;\\r\\n var propsLength = props.length;\\r\\n\\r\\n while (++propsIndex < propsLength) {\\r\\n var key = props[propsIndex];\\r\\n var value = object[key];\\r\\n\\r\\n if (value === undefined ||\\r\\n (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) {\\r\\n object[key] = source[key];\\r\\n }\\r\\n }\\r\\n }\\r\\n\\r\\n return object;\\r\\n });\\r\\n\\r\\n /**\\r\\n * This method is like `_.defaults` except that it recursively assigns\\r\\n * default properties.\\r\\n *\\r\\n * **Note:** This method mutates `object`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.10.0\\r\\n * @category Object\\r\\n * @param {Object} object The destination object.\\r\\n * @param {...Object} [sources] The source objects.\\r\\n * @returns {Object} Returns `object`.\\r\\n * @see _.defaults\\r\\n * @example\\r\\n *\\r\\n * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } });\\r\\n * // => { 'a': { 'b': 2, 'c': 3 } }\\r\\n */\\r\\n var defaultsDeep = baseRest(function(args) {\\r\\n args.push(undefined, customDefaultsMerge);\\r\\n return apply(mergeWith, undefined, args);\\r\\n });\\r\\n\\r\\n /**\\r\\n * This method is like `_.find` except that it returns the key of the first\\r\\n * element `predicate` returns truthy for instead of the element itself.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 1.1.0\\r\\n * @category Object\\r\\n * @param {Object} object The object to inspect.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @returns {string|undefined} Returns the key of the matched element,\\r\\n * else `undefined`.\\r\\n * @example\\r\\n *\\r\\n * var users = {\\r\\n * 'barney': { 'age': 36, 'active': true },\\r\\n * 'fred': { 'age': 40, 'active': false },\\r\\n * 'pebbles': { 'age': 1, 'active': true }\\r\\n * };\\r\\n *\\r\\n * _.findKey(users, function(o) { return o.age < 40; });\\r\\n * // => 'barney' (iteration order is not guaranteed)\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.findKey(users, { 'age': 1, 'active': true });\\r\\n * // => 'pebbles'\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.findKey(users, ['active', false]);\\r\\n * // => 'fred'\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.findKey(users, 'active');\\r\\n * // => 'barney'\\r\\n */\\r\\n function findKey(object, predicate) {\\r\\n return baseFindKey(object, baseIteratee(predicate, 3), baseForOwn);\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.findKey` except that it iterates over elements of\\r\\n * a collection in the opposite order.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 2.0.0\\r\\n * @category Object\\r\\n * @param {Object} object The object to inspect.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\\r\\n * @returns {string|undefined} Returns the key of the matched element,\\r\\n * else `undefined`.\\r\\n * @example\\r\\n *\\r\\n * var users = {\\r\\n * 'barney': { 'age': 36, 'active': true },\\r\\n * 'fred': { 'age': 40, 'active': false },\\r\\n * 'pebbles': { 'age': 1, 'active': true }\\r\\n * };\\r\\n *\\r\\n * _.findLastKey(users, function(o) { return o.age < 40; });\\r\\n * // => returns 'pebbles' assuming `_.findKey` returns 'barney'\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.findLastKey(users, { 'age': 36, 'active': true });\\r\\n * // => 'barney'\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.findLastKey(users, ['active', false]);\\r\\n * // => 'fred'\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.findLastKey(users, 'active');\\r\\n * // => 'pebbles'\\r\\n */\\r\\n function findLastKey(object, predicate) {\\r\\n return baseFindKey(object, baseIteratee(predicate, 3), baseForOwnRight);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Gets the value at `path` of `object`. If the resolved value is\\r\\n * `undefined`, the `defaultValue` is returned in its place.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.7.0\\r\\n * @category Object\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array|string} path The path of the property to get.\\r\\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\\r\\n * @returns {*} Returns the resolved value.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\\r\\n *\\r\\n * _.get(object, 'a[0].b.c');\\r\\n * // => 3\\r\\n *\\r\\n * _.get(object, ['a', '0', 'b', 'c']);\\r\\n * // => 3\\r\\n *\\r\\n * _.get(object, 'a.b.c', 'default');\\r\\n * // => 'default'\\r\\n */\\r\\n function get(object, path, defaultValue) {\\r\\n var result = object == null ? undefined : baseGet(object, path);\\r\\n return result === undefined ? defaultValue : result;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `path` is a direct property of `object`.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Object\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array|string} path The path to check.\\r\\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': { 'b': 2 } };\\r\\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\\r\\n *\\r\\n * _.has(object, 'a');\\r\\n * // => true\\r\\n *\\r\\n * _.has(object, 'a.b');\\r\\n * // => true\\r\\n *\\r\\n * _.has(object, ['a', 'b']);\\r\\n * // => true\\r\\n *\\r\\n * _.has(other, 'a');\\r\\n * // => false\\r\\n */\\r\\n function has(object, path) {\\r\\n return object != null && hasPath(object, path, baseHas);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Checks if `path` is a direct or inherited property of `object`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Object\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array|string} path The path to check.\\r\\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\\r\\n * @example\\r\\n *\\r\\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\\r\\n *\\r\\n * _.hasIn(object, 'a');\\r\\n * // => true\\r\\n *\\r\\n * _.hasIn(object, 'a.b');\\r\\n * // => true\\r\\n *\\r\\n * _.hasIn(object, ['a', 'b']);\\r\\n * // => true\\r\\n *\\r\\n * _.hasIn(object, 'b');\\r\\n * // => false\\r\\n */\\r\\n function hasIn(object, path) {\\r\\n return object != null && hasPath(object, path, baseHasIn);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an object composed of the inverted keys and values of `object`.\\r\\n * If `object` contains duplicate values, subsequent values overwrite\\r\\n * property assignments of previous values.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.7.0\\r\\n * @category Object\\r\\n * @param {Object} object The object to invert.\\r\\n * @returns {Object} Returns the new inverted object.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\\r\\n *\\r\\n * _.invert(object);\\r\\n * // => { '1': 'c', '2': 'b' }\\r\\n */\\r\\n var invert = createInverter(function(result, value, key) {\\r\\n if (value != null &&\\r\\n typeof value.toString != 'function') {\\r\\n value = nativeObjectToString.call(value);\\r\\n }\\r\\n\\r\\n result[value] = key;\\r\\n }, constant(identity));\\r\\n\\r\\n /**\\r\\n * This method is like `_.invert` except that the inverted object is generated\\r\\n * from the results of running each element of `object` thru `iteratee`. The\\r\\n * corresponding inverted value of each inverted key is an array of keys\\r\\n * responsible for generating the inverted value. The iteratee is invoked\\r\\n * with one argument: (value).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.1.0\\r\\n * @category Object\\r\\n * @param {Object} object The object to invert.\\r\\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\\r\\n * @returns {Object} Returns the new inverted object.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\\r\\n *\\r\\n * _.invertBy(object);\\r\\n * // => { '1': ['a', 'c'], '2': ['b'] }\\r\\n *\\r\\n * _.invertBy(object, function(value) {\\r\\n * return 'group' + value;\\r\\n * });\\r\\n * // => { 'group1': ['a', 'c'], 'group2': ['b'] }\\r\\n */\\r\\n var invertBy = createInverter(function(result, value, key) {\\r\\n if (value != null &&\\r\\n typeof value.toString != 'function') {\\r\\n value = nativeObjectToString.call(value);\\r\\n }\\r\\n\\r\\n if (hasOwnProperty.call(result, value)) {\\r\\n result[value].push(key);\\r\\n } else {\\r\\n result[value] = [key];\\r\\n }\\r\\n }, baseIteratee);\\r\\n\\r\\n /**\\r\\n * Creates an array of the own enumerable property names of `object`.\\r\\n *\\r\\n * **Note:** Non-object values are coerced to objects. See the\\r\\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\\r\\n * for more details.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Object\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of property names.\\r\\n * @example\\r\\n *\\r\\n * function Foo() {\\r\\n * this.a = 1;\\r\\n * this.b = 2;\\r\\n * }\\r\\n *\\r\\n * Foo.prototype.c = 3;\\r\\n *\\r\\n * _.keys(new Foo);\\r\\n * // => ['a', 'b'] (iteration order is not guaranteed)\\r\\n *\\r\\n * _.keys('hi');\\r\\n * // => ['0', '1']\\r\\n */\\r\\n function keys(object) {\\r\\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of the own and inherited enumerable property names of `object`.\\r\\n *\\r\\n * **Note:** Non-object values are coerced to objects.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Object\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of property names.\\r\\n * @example\\r\\n *\\r\\n * function Foo() {\\r\\n * this.a = 1;\\r\\n * this.b = 2;\\r\\n * }\\r\\n *\\r\\n * Foo.prototype.c = 3;\\r\\n *\\r\\n * _.keysIn(new Foo);\\r\\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\\r\\n */\\r\\n function keysIn(object) {\\r\\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.assign` except that it recursively merges own and\\r\\n * inherited enumerable string keyed properties of source objects into the\\r\\n * destination object. Source properties that resolve to `undefined` are\\r\\n * skipped if a destination value exists. Array and plain object properties\\r\\n * are merged recursively. Other objects and value types are overridden by\\r\\n * assignment. Source objects are applied from left to right. Subsequent\\r\\n * sources overwrite property assignments of previous sources.\\r\\n *\\r\\n * **Note:** This method mutates `object`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.5.0\\r\\n * @category Object\\r\\n * @param {Object} object The destination object.\\r\\n * @param {...Object} [sources] The source objects.\\r\\n * @returns {Object} Returns `object`.\\r\\n * @example\\r\\n *\\r\\n * var object = {\\r\\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\\r\\n * };\\r\\n *\\r\\n * var other = {\\r\\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\\r\\n * };\\r\\n *\\r\\n * _.merge(object, other);\\r\\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\\r\\n */\\r\\n var merge = createAssigner(function(object, source, srcIndex) {\\r\\n baseMerge(object, source, srcIndex);\\r\\n });\\r\\n\\r\\n /**\\r\\n * This method is like `_.merge` except that it accepts `customizer` which\\r\\n * is invoked to produce the merged values of the destination and source\\r\\n * properties. If `customizer` returns `undefined`, merging is handled by the\\r\\n * method instead. The `customizer` is invoked with six arguments:\\r\\n * (objValue, srcValue, key, object, source, stack).\\r\\n *\\r\\n * **Note:** This method mutates `object`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Object\\r\\n * @param {Object} object The destination object.\\r\\n * @param {...Object} sources The source objects.\\r\\n * @param {Function} customizer The function to customize assigned values.\\r\\n * @returns {Object} Returns `object`.\\r\\n * @example\\r\\n *\\r\\n * function customizer(objValue, srcValue) {\\r\\n * if (_.isArray(objValue)) {\\r\\n * return objValue.concat(srcValue);\\r\\n * }\\r\\n * }\\r\\n *\\r\\n * var object = { 'a': [1], 'b': [2] };\\r\\n * var other = { 'a': [3], 'b': [4] };\\r\\n *\\r\\n * _.mergeWith(object, other, customizer);\\r\\n * // => { 'a': [1, 3], 'b': [2, 4] }\\r\\n */\\r\\n var mergeWith = createAssigner(function(object, source, srcIndex, customizer) {\\r\\n baseMerge(object, source, srcIndex, customizer);\\r\\n });\\r\\n\\r\\n /**\\r\\n * The opposite of `_.pick`; this method creates an object composed of the\\r\\n * own and inherited enumerable property paths of `object` that are not omitted.\\r\\n *\\r\\n * **Note:** This method is considerably slower than `_.pick`.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Object\\r\\n * @param {Object} object The source object.\\r\\n * @param {...(string|string[])} [paths] The property paths to omit.\\r\\n * @returns {Object} Returns the new object.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\\r\\n *\\r\\n * _.omit(object, ['a', 'c']);\\r\\n * // => { 'b': '2' }\\r\\n */\\r\\n var omit = flatRest(function(object, paths) {\\r\\n var result = {};\\r\\n if (object == null) {\\r\\n return result;\\r\\n }\\r\\n var isDeep = false;\\r\\n paths = arrayMap(paths, function(path) {\\r\\n path = castPath(path, object);\\r\\n isDeep || (isDeep = path.length > 1);\\r\\n return path;\\r\\n });\\r\\n copyObject(object, getAllKeysIn(object), result);\\r\\n if (isDeep) {\\r\\n result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);\\r\\n }\\r\\n var length = paths.length;\\r\\n while (length--) {\\r\\n baseUnset(result, paths[length]);\\r\\n }\\r\\n return result;\\r\\n });\\r\\n\\r\\n /**\\r\\n * The opposite of `_.pickBy`; this method creates an object composed of\\r\\n * the own and inherited enumerable string keyed properties of `object` that\\r\\n * `predicate` doesn't return truthy for. The predicate is invoked with two\\r\\n * arguments: (value, key).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Object\\r\\n * @param {Object} object The source object.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per property.\\r\\n * @returns {Object} Returns the new object.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\\r\\n *\\r\\n * _.omitBy(object, _.isNumber);\\r\\n * // => { 'b': '2' }\\r\\n */\\r\\n function omitBy(object, predicate) {\\r\\n return pickBy(object, negate(baseIteratee(predicate)));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an object composed of the picked `object` properties.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Object\\r\\n * @param {Object} object The source object.\\r\\n * @param {...(string|string[])} [paths] The property paths to pick.\\r\\n * @returns {Object} Returns the new object.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\\r\\n *\\r\\n * _.pick(object, ['a', 'c']);\\r\\n * // => { 'a': 1, 'c': 3 }\\r\\n */\\r\\n var pick = flatRest(function(object, paths) {\\r\\n return object == null ? {} : basePick(object, paths);\\r\\n });\\r\\n\\r\\n /**\\r\\n * Creates an object composed of the `object` properties `predicate` returns\\r\\n * truthy for. The predicate is invoked with two arguments: (value, key).\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Object\\r\\n * @param {Object} object The source object.\\r\\n * @param {Function} [predicate=_.identity] The function invoked per property.\\r\\n * @returns {Object} Returns the new object.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\\r\\n *\\r\\n * _.pickBy(object, _.isNumber);\\r\\n * // => { 'a': 1, 'c': 3 }\\r\\n */\\r\\n function pickBy(object, predicate) {\\r\\n if (object == null) {\\r\\n return {};\\r\\n }\\r\\n var props = arrayMap(getAllKeysIn(object), function(prop) {\\r\\n return [prop];\\r\\n });\\r\\n predicate = baseIteratee(predicate);\\r\\n return basePickBy(object, props, function(value, path) {\\r\\n return predicate(value, path[0]);\\r\\n });\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method is like `_.get` except that if the resolved value is a\\r\\n * function it's invoked with the `this` binding of its parent object and\\r\\n * its result is returned.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Object\\r\\n * @param {Object} object The object to query.\\r\\n * @param {Array|string} path The path of the property to resolve.\\r\\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\\r\\n * @returns {*} Returns the resolved value.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] };\\r\\n *\\r\\n * _.result(object, 'a[0].b.c1');\\r\\n * // => 3\\r\\n *\\r\\n * _.result(object, 'a[0].b.c2');\\r\\n * // => 4\\r\\n *\\r\\n * _.result(object, 'a[0].b.c3', 'default');\\r\\n * // => 'default'\\r\\n *\\r\\n * _.result(object, 'a[0].b.c3', _.constant('default'));\\r\\n * // => 'default'\\r\\n */\\r\\n function result(object, path, defaultValue) {\\r\\n path = castPath(path, object);\\r\\n\\r\\n var index = -1,\\r\\n length = path.length;\\r\\n\\r\\n // Ensure the loop is entered when path is empty.\\r\\n if (!length) {\\r\\n length = 1;\\r\\n object = undefined;\\r\\n }\\r\\n while (++index < length) {\\r\\n var value = object == null ? undefined : object[toKey(path[index])];\\r\\n if (value === undefined) {\\r\\n index = length;\\r\\n value = defaultValue;\\r\\n }\\r\\n object = isFunction(value) ? value.call(object) : value;\\r\\n }\\r\\n return object;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\\r\\n * it's created. Arrays are created for missing index properties while objects\\r\\n * are created for all other missing properties. Use `_.setWith` to customize\\r\\n * `path` creation.\\r\\n *\\r\\n * **Note:** This method mutates `object`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.7.0\\r\\n * @category Object\\r\\n * @param {Object} object The object to modify.\\r\\n * @param {Array|string} path The path of the property to set.\\r\\n * @param {*} value The value to set.\\r\\n * @returns {Object} Returns `object`.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\\r\\n *\\r\\n * _.set(object, 'a[0].b.c', 4);\\r\\n * console.log(object.a[0].b.c);\\r\\n * // => 4\\r\\n *\\r\\n * _.set(object, ['x', '0', 'y', 'z'], 5);\\r\\n * console.log(object.x[0].y.z);\\r\\n * // => 5\\r\\n */\\r\\n function set(object, path, value) {\\r\\n return object == null ? object : baseSet(object, path, value);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of the own enumerable string keyed property values of `object`.\\r\\n *\\r\\n * **Note:** Non-object values are coerced to objects.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Object\\r\\n * @param {Object} object The object to query.\\r\\n * @returns {Array} Returns the array of property values.\\r\\n * @example\\r\\n *\\r\\n * function Foo() {\\r\\n * this.a = 1;\\r\\n * this.b = 2;\\r\\n * }\\r\\n *\\r\\n * Foo.prototype.c = 3;\\r\\n *\\r\\n * _.values(new Foo);\\r\\n * // => [1, 2] (iteration order is not guaranteed)\\r\\n *\\r\\n * _.values('hi');\\r\\n * // => ['h', 'i']\\r\\n */\\r\\n function values(object) {\\r\\n return object == null ? [] : baseValues(object, keys(object));\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Clamps `number` within the inclusive `lower` and `upper` bounds.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.0.0\\r\\n * @category Number\\r\\n * @param {number} number The number to clamp.\\r\\n * @param {number} [lower] The lower bound.\\r\\n * @param {number} upper The upper bound.\\r\\n * @returns {number} Returns the clamped number.\\r\\n * @example\\r\\n *\\r\\n * _.clamp(-10, -5, 5);\\r\\n * // => -5\\r\\n *\\r\\n * _.clamp(10, -5, 5);\\r\\n * // => 5\\r\\n */\\r\\n function clamp(number, lower, upper) {\\r\\n if (upper === undefined) {\\r\\n upper = lower;\\r\\n lower = undefined;\\r\\n }\\r\\n if (upper !== undefined) {\\r\\n upper = toNumber(upper);\\r\\n upper = upper === upper ? upper : 0;\\r\\n }\\r\\n if (lower !== undefined) {\\r\\n lower = toNumber(lower);\\r\\n lower = lower === lower ? lower : 0;\\r\\n }\\r\\n return baseClamp(toNumber(number), lower, upper);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Produces a random number between the inclusive `lower` and `upper` bounds.\\r\\n * If only one argument is provided a number between `0` and the given number\\r\\n * is returned. If `floating` is `true`, or either `lower` or `upper` are\\r\\n * floats, a floating-point number is returned instead of an integer.\\r\\n *\\r\\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\\r\\n * floating-point values which can produce unexpected results.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 0.7.0\\r\\n * @category Number\\r\\n * @param {number} [lower=0] The lower bound.\\r\\n * @param {number} [upper=1] The upper bound.\\r\\n * @param {boolean} [floating] Specify returning a floating-point number.\\r\\n * @returns {number} Returns the random number.\\r\\n * @example\\r\\n *\\r\\n * _.random(0, 5);\\r\\n * // => an integer between 0 and 5\\r\\n *\\r\\n * _.random(5);\\r\\n * // => also an integer between 0 and 5\\r\\n *\\r\\n * _.random(5, true);\\r\\n * // => a floating-point number between 0 and 5\\r\\n *\\r\\n * _.random(1.2, 5.2);\\r\\n * // => a floating-point number between 1.2 and 5.2\\r\\n */\\r\\n function random(lower, upper, floating) {\\r\\n if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) {\\r\\n upper = floating = undefined;\\r\\n }\\r\\n if (floating === undefined) {\\r\\n if (typeof upper == 'boolean') {\\r\\n floating = upper;\\r\\n upper = undefined;\\r\\n }\\r\\n else if (typeof lower == 'boolean') {\\r\\n floating = lower;\\r\\n lower = undefined;\\r\\n }\\r\\n }\\r\\n if (lower === undefined && upper === undefined) {\\r\\n lower = 0;\\r\\n upper = 1;\\r\\n }\\r\\n else {\\r\\n lower = toFinite(lower);\\r\\n if (upper === undefined) {\\r\\n upper = lower;\\r\\n lower = 0;\\r\\n } else {\\r\\n upper = toFinite(upper);\\r\\n }\\r\\n }\\r\\n if (lower > upper) {\\r\\n var temp = lower;\\r\\n lower = upper;\\r\\n upper = temp;\\r\\n }\\r\\n if (floating || lower % 1 || upper % 1) {\\r\\n var rand = nativeRandom();\\r\\n return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper);\\r\\n }\\r\\n return baseRandom(lower, upper);\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Converts the characters \\\"&\\\", \\\"<\\\", \\\">\\\", '\\\"', and \\\"'\\\" in `string` to their\\r\\n * corresponding HTML entities.\\r\\n *\\r\\n * **Note:** No other characters are escaped. To escape additional\\r\\n * characters use a third-party library like [_he_](https://mths.be/he).\\r\\n *\\r\\n * Though the \\\">\\\" character is escaped for symmetry, characters like\\r\\n * \\\">\\\" and \\\"/\\\" don't need escaping in HTML and have no special meaning\\r\\n * unless they're part of a tag or unquoted attribute value. See\\r\\n * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands)\\r\\n * (under \\\"semi-related fun fact\\\") for more details.\\r\\n *\\r\\n * When working with HTML you should always\\r\\n * [quote attribute values](http://wonko.com/post/html-escaping) to reduce\\r\\n * XSS vectors.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category String\\r\\n * @param {string} [string=''] The string to escape.\\r\\n * @returns {string} Returns the escaped string.\\r\\n * @example\\r\\n *\\r\\n * _.escape('fred, barney, & pebbles');\\r\\n * // => 'fred, barney, & pebbles'\\r\\n */\\r\\n function escape(string) {\\r\\n string = toString(string);\\r\\n return (string && reHasUnescapedHtml.test(string))\\r\\n ? string.replace(reUnescapedHtml, escapeHtmlChar)\\r\\n : string;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Removes leading and trailing whitespace or specified characters from `string`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category String\\r\\n * @param {string} [string=''] The string to trim.\\r\\n * @param {string} [chars=whitespace] The characters to trim.\\r\\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\\r\\n * @returns {string} Returns the trimmed string.\\r\\n * @example\\r\\n *\\r\\n * _.trim(' abc ');\\r\\n * // => 'abc'\\r\\n *\\r\\n * _.trim('-_-abc-_-', '_-');\\r\\n * // => 'abc'\\r\\n *\\r\\n * _.map([' foo ', ' bar '], _.trim);\\r\\n * // => ['foo', 'bar']\\r\\n */\\r\\n function trim(string, chars, guard) {\\r\\n string = toString(string);\\r\\n if (string && (guard || chars === undefined)) {\\r\\n return string.replace(reTrim, '');\\r\\n }\\r\\n if (!string || !(chars = baseToString(chars))) {\\r\\n return string;\\r\\n }\\r\\n var strSymbols = stringToArray(string),\\r\\n chrSymbols = stringToArray(chars),\\r\\n start = charsStartIndex(strSymbols, chrSymbols),\\r\\n end = charsEndIndex(strSymbols, chrSymbols) + 1;\\r\\n\\r\\n return castSlice(strSymbols, start, end).join('');\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Creates a function that returns `value`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 2.4.0\\r\\n * @category Util\\r\\n * @param {*} value The value to return from the new function.\\r\\n * @returns {Function} Returns the new constant function.\\r\\n * @example\\r\\n *\\r\\n * var objects = _.times(2, _.constant({ 'a': 1 }));\\r\\n *\\r\\n * console.log(objects);\\r\\n * // => [{ 'a': 1 }, { 'a': 1 }]\\r\\n *\\r\\n * console.log(objects[0] === objects[1]);\\r\\n * // => true\\r\\n */\\r\\n function constant(value) {\\r\\n return function() {\\r\\n return value;\\r\\n };\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method returns the first argument it receives.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Util\\r\\n * @param {*} value Any value.\\r\\n * @returns {*} Returns `value`.\\r\\n * @example\\r\\n *\\r\\n * var object = { 'a': 1 };\\r\\n *\\r\\n * console.log(_.identity(object) === object);\\r\\n * // => true\\r\\n */\\r\\n function identity(value) {\\r\\n return value;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that invokes `func` with the arguments of the created\\r\\n * function. If `func` is a property name, the created function returns the\\r\\n * property value for a given element. If `func` is an array or object, the\\r\\n * created function returns `true` for elements that contain the equivalent\\r\\n * source properties, otherwise it returns `false`.\\r\\n *\\r\\n * @static\\r\\n * @since 4.0.0\\r\\n * @memberOf _\\r\\n * @category Util\\r\\n * @param {*} [func=_.identity] The value to convert to a callback.\\r\\n * @returns {Function} Returns the callback.\\r\\n * @example\\r\\n *\\r\\n * var users = [\\r\\n * { 'user': 'barney', 'age': 36, 'active': true },\\r\\n * { 'user': 'fred', 'age': 40, 'active': false }\\r\\n * ];\\r\\n *\\r\\n * // The `_.matches` iteratee shorthand.\\r\\n * _.filter(users, _.iteratee({ 'user': 'barney', 'active': true }));\\r\\n * // => [{ 'user': 'barney', 'age': 36, 'active': true }]\\r\\n *\\r\\n * // The `_.matchesProperty` iteratee shorthand.\\r\\n * _.filter(users, _.iteratee(['user', 'fred']));\\r\\n * // => [{ 'user': 'fred', 'age': 40 }]\\r\\n *\\r\\n * // The `_.property` iteratee shorthand.\\r\\n * _.map(users, _.iteratee('user'));\\r\\n * // => ['barney', 'fred']\\r\\n *\\r\\n * // Create custom iteratee shorthands.\\r\\n * _.iteratee = _.wrap(_.iteratee, function(iteratee, func) {\\r\\n * return !_.isRegExp(func) ? iteratee(func) : function(string) {\\r\\n * return func.test(string);\\r\\n * };\\r\\n * });\\r\\n *\\r\\n * _.filter(['abc', 'def'], /ef/);\\r\\n * // => ['def']\\r\\n */\\r\\n function iteratee(func) {\\r\\n return baseIteratee(typeof func == 'function' ? func : baseClone(func, CLONE_DEEP_FLAG));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that performs a partial deep comparison between a given\\r\\n * object and `source`, returning `true` if the given object has equivalent\\r\\n * property values, else `false`.\\r\\n *\\r\\n * **Note:** The created function is equivalent to `_.isMatch` with `source`\\r\\n * partially applied.\\r\\n *\\r\\n * Partial comparisons will match empty array and empty object `source`\\r\\n * values against any array or object value, respectively. See `_.isEqual`\\r\\n * for a list of supported value comparisons.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 3.0.0\\r\\n * @category Util\\r\\n * @param {Object} source The object of property values to match.\\r\\n * @returns {Function} Returns the new spec function.\\r\\n * @example\\r\\n *\\r\\n * var objects = [\\r\\n * { 'a': 1, 'b': 2, 'c': 3 },\\r\\n * { 'a': 4, 'b': 5, 'c': 6 }\\r\\n * ];\\r\\n *\\r\\n * _.filter(objects, _.matches({ 'a': 4, 'c': 6 }));\\r\\n * // => [{ 'a': 4, 'b': 5, 'c': 6 }]\\r\\n */\\r\\n function matches(source) {\\r\\n return baseMatches(baseClone(source, CLONE_DEEP_FLAG));\\r\\n }\\r\\n\\r\\n /**\\r\\n * Adds all own enumerable string keyed function properties of a source\\r\\n * object to the destination object. If `object` is a function, then methods\\r\\n * are added to its prototype as well.\\r\\n *\\r\\n * **Note:** Use `_.runInContext` to create a pristine `lodash` function to\\r\\n * avoid conflicts caused by modifying the original.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Util\\r\\n * @param {Function|Object} [object=lodash] The destination object.\\r\\n * @param {Object} source The object of functions to add.\\r\\n * @param {Object} [options={}] The options object.\\r\\n * @param {boolean} [options.chain=true] Specify whether mixins are chainable.\\r\\n * @returns {Function|Object} Returns `object`.\\r\\n * @example\\r\\n *\\r\\n * function vowels(string) {\\r\\n * return _.filter(string, function(v) {\\r\\n * return /[aeiou]/i.test(v);\\r\\n * });\\r\\n * }\\r\\n *\\r\\n * _.mixin({ 'vowels': vowels });\\r\\n * _.vowels('fred');\\r\\n * // => ['e']\\r\\n *\\r\\n * _('fred').vowels().value();\\r\\n * // => ['e']\\r\\n *\\r\\n * _.mixin({ 'vowels': vowels }, { 'chain': false });\\r\\n * _('fred').vowels();\\r\\n * // => ['e']\\r\\n */\\r\\n function mixin(object, source, options) {\\r\\n var props = keys(source),\\r\\n methodNames = baseFunctions(source, props);\\r\\n\\r\\n if (options == null &&\\r\\n !(isObject(source) && (methodNames.length || !props.length))) {\\r\\n options = source;\\r\\n source = object;\\r\\n object = this;\\r\\n methodNames = baseFunctions(source, keys(source));\\r\\n }\\r\\n var chain = !(isObject(options) && 'chain' in options) || !!options.chain,\\r\\n isFunc = isFunction(object);\\r\\n\\r\\n arrayEach(methodNames, function(methodName) {\\r\\n var func = source[methodName];\\r\\n object[methodName] = func;\\r\\n if (isFunc) {\\r\\n object.prototype[methodName] = function() {\\r\\n var chainAll = this.__chain__;\\r\\n if (chain || chainAll) {\\r\\n var result = object(this.__wrapped__),\\r\\n actions = result.__actions__ = copyArray(this.__actions__);\\r\\n\\r\\n actions.push({ 'func': func, 'args': arguments, 'thisArg': object });\\r\\n result.__chain__ = chainAll;\\r\\n return result;\\r\\n }\\r\\n return func.apply(object, arrayPush([this.value()], arguments));\\r\\n };\\r\\n }\\r\\n });\\r\\n\\r\\n return object;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Reverts the `_` variable to its previous value and returns a reference to\\r\\n * the `lodash` function.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Util\\r\\n * @returns {Function} Returns the `lodash` function.\\r\\n * @example\\r\\n *\\r\\n * var lodash = _.noConflict();\\r\\n */\\r\\n function noConflict() {\\r\\n if (root._ === this) {\\r\\n root._ = oldDash;\\r\\n }\\r\\n return this;\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method returns `undefined`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 2.3.0\\r\\n * @category Util\\r\\n * @example\\r\\n *\\r\\n * _.times(2, _.noop);\\r\\n * // => [undefined, undefined]\\r\\n */\\r\\n function noop() {\\r\\n // No operation performed.\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates a function that returns the value at `path` of a given object.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 2.4.0\\r\\n * @category Util\\r\\n * @param {Array|string} path The path of the property to get.\\r\\n * @returns {Function} Returns the new accessor function.\\r\\n * @example\\r\\n *\\r\\n * var objects = [\\r\\n * { 'a': { 'b': 2 } },\\r\\n * { 'a': { 'b': 1 } }\\r\\n * ];\\r\\n *\\r\\n * _.map(objects, _.property('a.b'));\\r\\n * // => [2, 1]\\r\\n *\\r\\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\\r\\n * // => [1, 2]\\r\\n */\\r\\n function property(path) {\\r\\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\\r\\n }\\r\\n\\r\\n /**\\r\\n * Creates an array of numbers (positive and/or negative) progressing from\\r\\n * `start` up to, but not including, `end`. A step of `-1` is used if a negative\\r\\n * `start` is specified without an `end` or `step`. If `end` is not specified,\\r\\n * it's set to `start` with `start` then set to `0`.\\r\\n *\\r\\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\\r\\n * floating-point values which can produce unexpected results.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Util\\r\\n * @param {number} [start=0] The start of the range.\\r\\n * @param {number} end The end of the range.\\r\\n * @param {number} [step=1] The value to increment or decrement by.\\r\\n * @returns {Array} Returns the range of numbers.\\r\\n * @see _.inRange, _.rangeRight\\r\\n * @example\\r\\n *\\r\\n * _.range(4);\\r\\n * // => [0, 1, 2, 3]\\r\\n *\\r\\n * _.range(-4);\\r\\n * // => [0, -1, -2, -3]\\r\\n *\\r\\n * _.range(1, 5);\\r\\n * // => [1, 2, 3, 4]\\r\\n *\\r\\n * _.range(0, 20, 5);\\r\\n * // => [0, 5, 10, 15]\\r\\n *\\r\\n * _.range(0, -4, -1);\\r\\n * // => [0, -1, -2, -3]\\r\\n *\\r\\n * _.range(1, 4, 0);\\r\\n * // => [1, 1, 1]\\r\\n *\\r\\n * _.range(0);\\r\\n * // => []\\r\\n */\\r\\n var range = createRange();\\r\\n\\r\\n /**\\r\\n * This method returns a new empty array.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.13.0\\r\\n * @category Util\\r\\n * @returns {Array} Returns the new empty array.\\r\\n * @example\\r\\n *\\r\\n * var arrays = _.times(2, _.stubArray);\\r\\n *\\r\\n * console.log(arrays);\\r\\n * // => [[], []]\\r\\n *\\r\\n * console.log(arrays[0] === arrays[1]);\\r\\n * // => false\\r\\n */\\r\\n function stubArray() {\\r\\n return [];\\r\\n }\\r\\n\\r\\n /**\\r\\n * This method returns `false`.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @since 4.13.0\\r\\n * @category Util\\r\\n * @returns {boolean} Returns `false`.\\r\\n * @example\\r\\n *\\r\\n * _.times(2, _.stubFalse);\\r\\n * // => [false, false]\\r\\n */\\r\\n function stubFalse() {\\r\\n return false;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Generates a unique ID. If `prefix` is given, the ID is appended to it.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Util\\r\\n * @param {string} [prefix=''] The value to prefix the ID with.\\r\\n * @returns {string} Returns the unique ID.\\r\\n * @example\\r\\n *\\r\\n * _.uniqueId('contact_');\\r\\n * // => 'contact_104'\\r\\n *\\r\\n * _.uniqueId();\\r\\n * // => '105'\\r\\n */\\r\\n function uniqueId(prefix) {\\r\\n var id = ++idCounter;\\r\\n return toString(prefix) + id;\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * Computes the maximum value of `array`. If `array` is empty or falsey,\\r\\n * `undefined` is returned.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Math\\r\\n * @param {Array} array The array to iterate over.\\r\\n * @returns {*} Returns the maximum value.\\r\\n * @example\\r\\n *\\r\\n * _.max([4, 2, 8, 6]);\\r\\n * // => 8\\r\\n *\\r\\n * _.max([]);\\r\\n * // => undefined\\r\\n */\\r\\n function max(array) {\\r\\n return (array && array.length)\\r\\n ? baseExtremum(array, identity, baseGt)\\r\\n : undefined;\\r\\n }\\r\\n\\r\\n /**\\r\\n * Computes the minimum value of `array`. If `array` is empty or falsey,\\r\\n * `undefined` is returned.\\r\\n *\\r\\n * @static\\r\\n * @since 0.1.0\\r\\n * @memberOf _\\r\\n * @category Math\\r\\n * @param {Array} array The array to iterate over.\\r\\n * @returns {*} Returns the minimum value.\\r\\n * @example\\r\\n *\\r\\n * _.min([4, 2, 8, 6]);\\r\\n * // => 2\\r\\n *\\r\\n * _.min([]);\\r\\n * // => undefined\\r\\n */\\r\\n function min(array) {\\r\\n return (array && array.length)\\r\\n ? baseExtremum(array, identity, baseLt)\\r\\n : undefined;\\r\\n }\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n // Add methods that return wrapped values in chain sequences.\\r\\n lodash.after = after;\\r\\n lodash.assignIn = assignIn;\\r\\n lodash.before = before;\\r\\n lodash.bind = bind;\\r\\n lodash.chain = chain;\\r\\n lodash.compact = compact;\\r\\n lodash.concat = concat;\\r\\n lodash.countBy = countBy;\\r\\n lodash.create = create;\\r\\n lodash.debounce = debounce;\\r\\n lodash.defaults = defaults;\\r\\n lodash.defaultsDeep = defaultsDeep;\\r\\n lodash.defer = defer;\\r\\n lodash.delay = delay;\\r\\n lodash.difference = difference;\\r\\n lodash.drop = drop;\\r\\n lodash.filter = filter;\\r\\n lodash.flatten = flatten;\\r\\n lodash.flattenDeep = flattenDeep;\\r\\n lodash.groupBy = groupBy;\\r\\n lodash.initial = initial;\\r\\n lodash.intersection = intersection;\\r\\n lodash.invert = invert;\\r\\n lodash.invertBy = invertBy;\\r\\n lodash.iteratee = iteratee;\\r\\n lodash.keys = keys;\\r\\n lodash.map = map;\\r\\n lodash.matches = matches;\\r\\n lodash.merge = merge;\\r\\n lodash.mixin = mixin;\\r\\n lodash.negate = negate;\\r\\n lodash.omit = omit;\\r\\n lodash.omitBy = omitBy;\\r\\n lodash.once = once;\\r\\n lodash.pick = pick;\\r\\n lodash.range = range;\\r\\n lodash.reject = reject;\\r\\n lodash.rest = rest;\\r\\n lodash.set = set;\\r\\n lodash.slice = slice;\\r\\n lodash.sortBy = sortBy;\\r\\n lodash.take = take;\\r\\n lodash.takeRight = takeRight;\\r\\n lodash.tap = tap;\\r\\n lodash.throttle = throttle;\\r\\n lodash.thru = thru;\\r\\n lodash.toArray = toArray;\\r\\n lodash.union = union;\\r\\n lodash.uniq = uniq;\\r\\n lodash.uniqBy = uniqBy;\\r\\n lodash.unzip = unzip;\\r\\n lodash.values = values;\\r\\n lodash.without = without;\\r\\n lodash.zip = zip;\\r\\n lodash.zipObject = zipObject;\\r\\n\\r\\n // Add aliases.\\r\\n lodash.extend = assignIn;\\r\\n\\r\\n // Add methods to `lodash.prototype`.\\r\\n mixin(lodash, lodash);\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n // Add methods that return unwrapped values in chain sequences.\\r\\n lodash.clamp = clamp;\\r\\n lodash.clone = clone;\\r\\n lodash.cloneDeep = cloneDeep;\\r\\n lodash.escape = escape;\\r\\n lodash.every = every;\\r\\n lodash.find = find;\\r\\n lodash.findIndex = findIndex;\\r\\n lodash.findKey = findKey;\\r\\n lodash.findLastIndex = findLastIndex;\\r\\n lodash.findLastKey = findLastKey;\\r\\n lodash.forEach = forEach;\\r\\n lodash.get = get;\\r\\n lodash.has = has;\\r\\n lodash.head = head;\\r\\n lodash.identity = identity;\\r\\n lodash.indexOf = indexOf;\\r\\n lodash.isArguments = isArguments;\\r\\n lodash.isArray = isArray;\\r\\n lodash.isArrayLike = isArrayLike;\\r\\n lodash.isBoolean = isBoolean;\\r\\n lodash.isDate = isDate;\\r\\n lodash.isEmpty = isEmpty;\\r\\n lodash.isEqual = isEqual;\\r\\n lodash.isFinite = isFinite;\\r\\n lodash.isFunction = isFunction;\\r\\n lodash.isNaN = isNaN;\\r\\n lodash.isNull = isNull;\\r\\n lodash.isNumber = isNumber;\\r\\n lodash.isObject = isObject;\\r\\n lodash.isPlainObject = isPlainObject;\\r\\n lodash.isRegExp = isRegExp;\\r\\n lodash.isString = isString;\\r\\n lodash.isUndefined = isUndefined;\\r\\n lodash.last = last;\\r\\n lodash.max = max;\\r\\n lodash.min = min;\\r\\n lodash.noConflict = noConflict;\\r\\n lodash.noop = noop;\\r\\n lodash.random = random;\\r\\n lodash.reduce = reduce;\\r\\n lodash.result = result;\\r\\n lodash.size = size;\\r\\n lodash.some = some;\\r\\n lodash.trim = trim;\\r\\n lodash.uniqueId = uniqueId;\\r\\n\\r\\n // Add aliases.\\r\\n lodash.each = forEach;\\r\\n lodash.first = head;\\r\\n\\r\\n mixin(lodash, (function() {\\r\\n var source = {};\\r\\n baseForOwn(lodash, function(func, methodName) {\\r\\n if (!hasOwnProperty.call(lodash.prototype, methodName)) {\\r\\n source[methodName] = func;\\r\\n }\\r\\n });\\r\\n return source;\\r\\n }()), { 'chain': false });\\r\\n\\r\\n /*------------------------------------------------------------------------*/\\r\\n\\r\\n /**\\r\\n * The semantic version number.\\r\\n *\\r\\n * @static\\r\\n * @memberOf _\\r\\n * @type {string}\\r\\n */\\r\\n lodash.VERSION = VERSION;\\r\\n\\r\\n // Add `LazyWrapper` methods for `_.drop` and `_.take` variants.\\r\\n arrayEach(['drop', 'take'], function(methodName, index) {\\r\\n LazyWrapper.prototype[methodName] = function(n) {\\r\\n n = n === undefined ? 1 : nativeMax(toInteger(n), 0);\\r\\n\\r\\n var result = (this.__filtered__ && !index)\\r\\n ? new LazyWrapper(this)\\r\\n : this.clone();\\r\\n\\r\\n if (result.__filtered__) {\\r\\n result.__takeCount__ = nativeMin(n, result.__takeCount__);\\r\\n } else {\\r\\n result.__views__.push({\\r\\n 'size': nativeMin(n, MAX_ARRAY_LENGTH),\\r\\n 'type': methodName + (result.__dir__ < 0 ? 'Right' : '')\\r\\n });\\r\\n }\\r\\n return result;\\r\\n };\\r\\n\\r\\n LazyWrapper.prototype[methodName + 'Right'] = function(n) {\\r\\n return this.reverse()[methodName](n).reverse();\\r\\n };\\r\\n });\\r\\n\\r\\n // Add `LazyWrapper` methods that accept an `iteratee` value.\\r\\n arrayEach(['filter', 'map', 'takeWhile'], function(methodName, index) {\\r\\n var type = index + 1,\\r\\n isFilter = type == LAZY_FILTER_FLAG || type == LAZY_WHILE_FLAG;\\r\\n\\r\\n LazyWrapper.prototype[methodName] = function(iteratee) {\\r\\n var result = this.clone();\\r\\n result.__iteratees__.push({\\r\\n 'iteratee': getIteratee(iteratee, 3),\\r\\n 'type': type\\r\\n });\\r\\n result.__filtered__ = result.__filtered__ || isFilter;\\r\\n return result;\\r\\n };\\r\\n });\\r\\n\\r\\n // Add `LazyWrapper` methods for `_.head` and `_.last`.\\r\\n arrayEach(['head', 'last'], function(methodName, index) {\\r\\n var takeName = 'take' + (index ? 'Right' : '');\\r\\n\\r\\n LazyWrapper.prototype[methodName] = function() {\\r\\n return this[takeName](1).value()[0];\\r\\n };\\r\\n });\\r\\n\\r\\n // Add `LazyWrapper` methods for `_.initial` and `_.tail`.\\r\\n arrayEach(['initial', 'tail'], function(methodName, index) {\\r\\n var dropName = 'drop' + (index ? '' : 'Right');\\r\\n\\r\\n LazyWrapper.prototype[methodName] = function() {\\r\\n return this.__filtered__ ? new LazyWrapper(this) : this[dropName](1);\\r\\n };\\r\\n });\\r\\n\\r\\n LazyWrapper.prototype.compact = function() {\\r\\n return this.filter(identity);\\r\\n };\\r\\n\\r\\n LazyWrapper.prototype.find = function(predicate) {\\r\\n return this.filter(predicate).head();\\r\\n };\\r\\n\\r\\n LazyWrapper.prototype.findLast = function(predicate) {\\r\\n return this.reverse().find(predicate);\\r\\n };\\r\\n\\r\\n LazyWrapper.prototype.invokeMap = baseRest(function(path, args) {\\r\\n if (typeof path == 'function') {\\r\\n return new LazyWrapper(this);\\r\\n }\\r\\n return this.map(function(value) {\\r\\n return baseInvoke(value, path, args);\\r\\n });\\r\\n });\\r\\n\\r\\n LazyWrapper.prototype.reject = function(predicate) {\\r\\n return this.filter(negate(getIteratee(predicate)));\\r\\n };\\r\\n\\r\\n LazyWrapper.prototype.slice = function(start, end) {\\r\\n start = toInteger(start);\\r\\n\\r\\n var result = this;\\r\\n if (result.__filtered__ && (start > 0 || end < 0)) {\\r\\n return new LazyWrapper(result);\\r\\n }\\r\\n if (start < 0) {\\r\\n result = result.takeRight(-start);\\r\\n } else if (start) {\\r\\n result = result.drop(start);\\r\\n }\\r\\n if (end !== undefined) {\\r\\n end = toInteger(end);\\r\\n result = end < 0 ? result.dropRight(-end) : result.take(end - start);\\r\\n }\\r\\n return result;\\r\\n };\\r\\n\\r\\n LazyWrapper.prototype.takeRightWhile = function(predicate) {\\r\\n return this.reverse().takeWhile(predicate).reverse();\\r\\n };\\r\\n\\r\\n LazyWrapper.prototype.toArray = function() {\\r\\n return this.take(MAX_ARRAY_LENGTH);\\r\\n };\\r\\n\\r\\n // Add `LazyWrapper` methods to `lodash.prototype`.\\r\\n baseForOwn(LazyWrapper.prototype, function(func, methodName) {\\r\\n var checkIteratee = /^(?:filter|find|map|reject)|While$/.test(methodName),\\r\\n isTaker = /^(?:head|last)$/.test(methodName),\\r\\n lodashFunc = lodash[isTaker ? ('take' + (methodName == 'last' ? 'Right' : '')) : methodName],\\r\\n retUnwrapped = isTaker || /^find/.test(methodName);\\r\\n\\r\\n if (!lodashFunc) {\\r\\n return;\\r\\n }\\r\\n lodash.prototype[methodName] = function() {\\r\\n var value = this.__wrapped__,\\r\\n args = isTaker ? [1] : arguments,\\r\\n isLazy = value instanceof LazyWrapper,\\r\\n iteratee = args[0],\\r\\n useLazy = isLazy || isArray(value);\\r\\n\\r\\n var interceptor = function(value) {\\r\\n var result = lodashFunc.apply(lodash, arrayPush([value], args));\\r\\n return (isTaker && chainAll) ? result[0] : result;\\r\\n };\\r\\n\\r\\n if (useLazy && checkIteratee && typeof iteratee == 'function' && iteratee.length != 1) {\\r\\n // Avoid lazy use if the iteratee has a \\\"length\\\" value other than `1`.\\r\\n isLazy = useLazy = false;\\r\\n }\\r\\n var chainAll = this.__chain__,\\r\\n isHybrid = !!this.__actions__.length,\\r\\n isUnwrapped = retUnwrapped && !chainAll,\\r\\n onlyLazy = isLazy && !isHybrid;\\r\\n\\r\\n if (!retUnwrapped && useLazy) {\\r\\n value = onlyLazy ? value : new LazyWrapper(this);\\r\\n var result = func.apply(value, args);\\r\\n result.__actions__.push({ 'func': thru, 'args': [interceptor], 'thisArg': undefined });\\r\\n return new LodashWrapper(result, chainAll);\\r\\n }\\r\\n if (isUnwrapped && onlyLazy) {\\r\\n return func.apply(this, args);\\r\\n }\\r\\n result = this.thru(interceptor);\\r\\n return isUnwrapped ? (isTaker ? result.value()[0] : result.value()) : result;\\r\\n };\\r\\n });\\r\\n\\r\\n // Add `Array` methods to `lodash.prototype`.\\r\\n arrayEach(['pop', 'push', 'shift', 'sort', 'splice', 'unshift'], function(methodName) {\\r\\n var func = arrayProto[methodName],\\r\\n chainName = /^(?:push|sort|unshift)$/.test(methodName) ? 'tap' : 'thru',\\r\\n retUnwrapped = /^(?:pop|shift)$/.test(methodName);\\r\\n\\r\\n lodash.prototype[methodName] = function() {\\r\\n var args = arguments;\\r\\n if (retUnwrapped && !this.__chain__) {\\r\\n var value = this.value();\\r\\n return func.apply(isArray(value) ? value : [], args);\\r\\n }\\r\\n return this[chainName](function(value) {\\r\\n return func.apply(isArray(value) ? value : [], args);\\r\\n });\\r\\n };\\r\\n });\\r\\n\\r\\n // Map minified method names to their real names.\\r\\n baseForOwn(LazyWrapper.prototype, function(func, methodName) {\\r\\n var lodashFunc = lodash[methodName];\\r\\n if (lodashFunc) {\\r\\n var key = (lodashFunc.name + ''),\\r\\n names = realNames[key] || (realNames[key] = []);\\r\\n\\r\\n names.push({ 'name': methodName, 'func': lodashFunc });\\r\\n }\\r\\n });\\r\\n\\r\\n realNames[createHybrid(undefined, WRAP_BIND_KEY_FLAG).name] = [{\\r\\n 'name': 'wrapper',\\r\\n 'func': undefined\\r\\n }];\\r\\n\\r\\n // Add methods to `LazyWrapper`.\\r\\n LazyWrapper.prototype.clone = lazyClone;\\r\\n LazyWrapper.prototype.reverse = lazyReverse;\\r\\n LazyWrapper.prototype.value = lazyValue;\\r\\n\\r\\n // Add lazy aliases.\\r\\n lodash.prototype.first = lodash.prototype.head;\\r\\n\\r\\n if (symIterator) {\\r\\n lodash.prototype[symIterator] = wrapperToIterator;\\r\\n }\\r\\n\\r\\n /*--------------------------------------------------------------------------*/\\r\\n\\r\\n // Some AMD build optimizers, like r.js, check for condition patterns like:\\r\\n if (typeof define == 'function' && typeof define.amd == 'object' && define.amd) {\\r\\n // Expose Lodash on the global object to prevent errors when Lodash is\\r\\n // loaded by a script tag in the presence of an AMD loader.\\r\\n // See http://requirejs.org/docs/errors.html#mismatch for more details.\\r\\n // Use `_.noConflict` to remove Lodash from the global object.\\r\\n root._ = lodash;\\r\\n\\r\\n // Define as an anonymous module so, through path mapping, it can be\\r\\n // referenced as the \\\"underscore\\\" module.\\r\\n define(function() {\\r\\n return lodash;\\r\\n });\\r\\n }\\r\\n // Check for `exports` after `define` in case a build optimizer adds it.\\r\\n else if (freeModule) {\\r\\n // Export for Node.js.\\r\\n (freeModule.exports = lodash)._ = lodash;\\r\\n // Export for CommonJS support.\\r\\n freeExports._ = lodash;\\r\\n }\\r\\n else {\\r\\n // Export to the global object.\\r\\n root._ = lodash;\\r\\n }\\r\\n}.call(this));\\r\\n\"","/**\r\n * 基本函数\r\n * Create By GUY 2014\\11\\17\r\n *\r\n */\r\n_global = undefined;\r\nif (typeof window !== \"undefined\") {\r\n _global = window;\r\n} else if (typeof global !== \"undefined\") {\r\n _global = global;\r\n} else if (typeof self !== \"undefined\") {\r\n _global = self;\r\n} else {\r\n _global = this;\r\n}\r\nif (!_global.BI) {\r\n _global.BI = {};\r\n}\r\n\r\n!(function (undefined) {\r\n var traverse = function (func, context) {\r\n return function (value, key, obj) {\r\n return func.call(context, key, value, obj);\r\n };\r\n };\r\n var _apply = function (name) {\r\n return function () {\r\n return _[name].apply(_, arguments);\r\n };\r\n };\r\n var _applyFunc = function (name) {\r\n return function () {\r\n var args = Array.prototype.slice.call(arguments, 0);\r\n args[1] = _.isFunction(args[1]) ? traverse(args[1], args[2]) : args[1];\r\n return _[name].apply(_, args);\r\n };\r\n };\r\n\r\n // Utility\r\n _.extend(BI, {\r\n assert: function (v, is) {\r\n if (this.isFunction(is)) {\r\n if (!is(v)) {\r\n throw new Error(v + \" error\");\r\n } else {\r\n return true;\r\n }\r\n }\r\n if (!this.isArray(is)) {\r\n is = [is];\r\n }\r\n if (!this.deepContains(is, v)) {\r\n throw new Error(v + \" error\");\r\n }\r\n return true;\r\n },\r\n\r\n warn: function (message) {\r\n console.warn(message);\r\n },\r\n\r\n UUID: function () {\r\n var f = [\"0\", \"1\", \"2\", \"3\", \"4\", \"5\", \"6\", \"7\", \"8\", \"9\", \"a\", \"b\", \"c\", \"d\", \"e\", \"f\"];\r\n var str = \"\";\r\n for (var i = 0; i < 16; i++) {\r\n var r = parseInt(f.length * Math.random(), 10);\r\n str += f[r];\r\n }\r\n return str;\r\n },\r\n\r\n isWidget: function (widget) {\r\n return widget instanceof BI.Widget || (BI.View && widget instanceof BI.View);\r\n },\r\n\r\n createWidgets: function (items, options, context) {\r\n if (!BI.isArray(items)) {\r\n throw new Error(\"cannot create Widgets\");\r\n }\r\n if (BI.isWidget(options)) {\r\n context = options;\r\n options = {};\r\n } else {\r\n options || (options = {});\r\n }\r\n return BI.map(BI.flatten(items), function (i, item) {\r\n return BI.createWidget(item, BI.deepClone(options));\r\n });\r\n },\r\n\r\n createItems: function (data, innerAttr, outerAttr) {\r\n innerAttr = BI.isArray(innerAttr) ? innerAttr : BI.makeArray(BI.flatten(data).length, innerAttr || {});\r\n outerAttr = BI.isArray(outerAttr) ? outerAttr : BI.makeArray(BI.flatten(data).length, outerAttr || {});\r\n return BI.map(data, function (i, item) {\r\n if (BI.isArray(item)) {\r\n return BI.createItems(item, innerAttr, outerAttr);\r\n }\r\n if (item instanceof BI.Widget) {\r\n return BI.extend({}, innerAttr.shift(), outerAttr.shift(), {\r\n type: null,\r\n el: item\r\n });\r\n }\r\n if (innerAttr[0] instanceof BI.Widget) {\r\n outerAttr.shift();\r\n return BI.extend({}, item, {\r\n el: innerAttr.shift()\r\n });\r\n }\r\n if (item.el instanceof BI.Widget || (BI.View && item.el instanceof BI.View)) {\r\n innerAttr.shift();\r\n return BI.extend({}, outerAttr.shift(), { type: null }, item);\r\n }\r\n if (item.el) {\r\n return BI.extend({}, outerAttr.shift(), item, {\r\n el: BI.extend({}, innerAttr.shift(), item.el)\r\n });\r\n }\r\n return BI.extend({}, outerAttr.shift(), {\r\n el: BI.extend({}, innerAttr.shift(), item)\r\n });\r\n });\r\n },\r\n\r\n // 用容器包装items\r\n packageItems: function (items, layouts) {\r\n for (var i = layouts.length - 1; i >= 0; i--) {\r\n items = BI.map(items, function (k, it) {\r\n return BI.extend({}, layouts[i], {\r\n items: [\r\n BI.extend({}, layouts[i].el, {\r\n el: it\r\n })\r\n ]\r\n });\r\n });\r\n }\r\n return items;\r\n },\r\n\r\n formatEL: function (obj) {\r\n if (obj && !obj.type && obj.el) {\r\n return obj;\r\n }\r\n return {\r\n el: obj\r\n };\r\n },\r\n\r\n // 剥开EL\r\n stripEL: function (obj) {\r\n return obj.type && obj || obj.el || obj;\r\n },\r\n\r\n trans2Element: function (widgets) {\r\n return BI.map(widgets, function (i, wi) {\r\n return wi.element;\r\n });\r\n }\r\n });\r\n\r\n // 集合相关方法\r\n _.each([\"where\", \"findWhere\", \"invoke\", \"pluck\", \"shuffle\", \"sample\", \"toArray\", \"size\"], function (name) {\r\n BI[name] = _apply(name);\r\n });\r\n _.each([\"get\", \"set\", \"each\", \"map\", \"reduce\", \"reduceRight\", \"find\", \"filter\", \"reject\", \"every\", \"all\", \"some\", \"any\", \"max\", \"min\",\r\n \"sortBy\", \"groupBy\", \"indexBy\", \"countBy\", \"partition\", \"clamp\"], function (name) {\r\n if (name === \"any\") {\r\n BI[name] = _applyFunc(\"some\");\r\n } else {\r\n BI[name] = _applyFunc(name);\r\n }\r\n });\r\n _.extend(BI, {\r\n // 数数\r\n count: function (from, to, predicate) {\r\n var t;\r\n if (predicate) {\r\n for (t = from; t < to; t++) {\r\n predicate(t);\r\n }\r\n }\r\n return to - from;\r\n },\r\n\r\n // 倒数\r\n inverse: function (from, to, predicate) {\r\n return BI.count(to, from, predicate);\r\n },\r\n\r\n firstKey: function (obj) {\r\n var res = undefined;\r\n BI.any(obj, function (key, value) {\r\n res = key;\r\n return true;\r\n });\r\n return res;\r\n },\r\n\r\n lastKey: function (obj) {\r\n var res = undefined;\r\n BI.each(obj, function (key, value) {\r\n res = key;\r\n return true;\r\n });\r\n return res;\r\n },\r\n\r\n firstObject: function (obj) {\r\n var res = undefined;\r\n BI.any(obj, function (key, value) {\r\n res = value;\r\n return true;\r\n });\r\n return res;\r\n },\r\n\r\n lastObject: function (obj) {\r\n var res = undefined;\r\n BI.each(obj, function (key, value) {\r\n res = value;\r\n return true;\r\n });\r\n return res;\r\n },\r\n\r\n concat: function (obj1, obj2) {\r\n if (BI.isKey(obj1)) {\r\n return BI.map([].slice.apply(arguments), function (idx, v) {\r\n return v;\r\n }).join(\"\");\r\n }\r\n if (BI.isArray(obj1)) {\r\n return _.concat.apply([], arguments);\r\n }\r\n if (BI.isObject(obj1)) {\r\n return _.extend.apply({}, arguments);\r\n }\r\n },\r\n\r\n backEach: function (obj, predicate, context) {\r\n predicate = BI.iteratee(predicate, context);\r\n for (var index = obj.length - 1; index >= 0; index--) {\r\n predicate(index, obj[index], obj);\r\n }\r\n return false;\r\n },\r\n\r\n backAny: function (obj, predicate, context) {\r\n predicate = BI.iteratee(predicate, context);\r\n for (var index = obj.length - 1; index >= 0; index--) {\r\n if (predicate(index, obj[index], obj)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n },\r\n\r\n backEvery: function (obj, predicate, context) {\r\n predicate = BI.iteratee(predicate, context);\r\n for (var index = obj.length - 1; index >= 0; index--) {\r\n if (!predicate(index, obj[index], obj)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n },\r\n\r\n backFindKey: function (obj, predicate, context) {\r\n predicate = BI.iteratee(predicate, context);\r\n var keys = _.keys(obj), key;\r\n for (var i = keys.length - 1; i >= 0; i--) {\r\n key = keys[i];\r\n if (predicate(obj[key], key, obj)) {\r\n return key;\r\n }\r\n }\r\n },\r\n\r\n backFind: function (obj, predicate, context) {\r\n var key;\r\n if (BI.isArray(obj)) {\r\n key = BI.findLastIndex(obj, predicate, context);\r\n } else {\r\n key = BI.backFindKey(obj, predicate, context);\r\n }\r\n if (key !== void 0 && key !== -1) {\r\n return obj[key];\r\n }\r\n },\r\n\r\n remove: function (obj, target, context) {\r\n var isFunction = BI.isFunction(target);\r\n target = isFunction || BI.isArray(target) ? target : [target];\r\n var i;\r\n if (BI.isArray(obj)) {\r\n for (i = 0; i < obj.length; i++) {\r\n if ((isFunction && target.apply(context, [i, obj[i]]) === true) || (!isFunction && BI.contains(target, obj[i]))) {\r\n obj.splice(i--, 1);\r\n }\r\n }\r\n } else {\r\n BI.each(obj, function (i, v) {\r\n if ((isFunction && target.apply(context, [i, obj[i]]) === true) || (!isFunction && BI.contains(target, obj[i]))) {\r\n delete obj[i];\r\n }\r\n });\r\n }\r\n },\r\n\r\n removeAt: function (obj, index) {\r\n index = BI.isArray(index) ? index : [index];\r\n var isArray = BI.isArray(obj), i;\r\n for (i = 0; i < index.length; i++) {\r\n if (isArray) {\r\n obj[index[i]] = \"$deleteIndex\";\r\n } else {\r\n delete obj[index[i]];\r\n }\r\n }\r\n if (isArray) {\r\n BI.remove(obj, \"$deleteIndex\");\r\n }\r\n },\r\n\r\n string2Array: function (str) {\r\n return str.split(\"&-&\");\r\n },\r\n\r\n array2String: function (array) {\r\n return array.join(\"&-&\");\r\n },\r\n\r\n abc2Int: function (str) {\r\n var idx = 0, start = \"A\", str = str.toUpperCase();\r\n for (var i = 0, len = str.length; i < len; ++i) {\r\n idx = str.charAt(i).charCodeAt(0) - start.charCodeAt(0) + 26 * idx + 1;\r\n if (idx > (2147483646 - str.charAt(i).charCodeAt(0) + start.charCodeAt(0)) / 26) {\r\n return 0;\r\n }\r\n }\r\n return idx;\r\n },\r\n\r\n int2Abc: function (num) {\r\n var DIGITS = [\"A\", \"B\", \"C\", \"D\", \"E\", \"F\", \"G\", \"H\", \"I\", \"J\", \"K\", \"L\", \"M\", \"N\", \"O\", \"P\", \"Q\", \"R\", \"S\", \"T\", \"U\", \"V\", \"W\", \"X\", \"Y\", \"Z\"];\r\n var idx = num, str = \"\";\r\n if (num === 0) {\r\n return \"\";\r\n }\r\n while (idx !== 0) {\r\n var t = idx % 26;\r\n if (t === 0) {\r\n t = 26;\r\n }\r\n str = DIGITS[t - 1] + str;\r\n idx = (idx - t) / 26;\r\n }\r\n return str;\r\n }\r\n });\r\n\r\n // 数组相关的方法\r\n _.each([\"first\", \"initial\", \"last\", \"rest\", \"compact\", \"flatten\", \"without\", \"union\", \"intersection\",\r\n \"difference\", \"zip\", \"unzip\", \"object\", \"indexOf\", \"lastIndexOf\", \"sortedIndex\", \"range\", \"take\", \"takeRight\", \"uniqBy\"], function (name) {\r\n BI[name] = _apply(name);\r\n });\r\n _.each([\"findIndex\", \"findLastIndex\"], function (name) {\r\n BI[name] = _applyFunc(name);\r\n });\r\n _.extend(BI, {\r\n // 构建一个长度为length的数组\r\n makeArray: function (length, value) {\r\n var res = [];\r\n for (var i = 0; i < length; i++) {\r\n if (BI.isNull(value)) {\r\n res.push(i);\r\n } else {\r\n res.push(BI.deepClone(value));\r\n }\r\n }\r\n return res;\r\n },\r\n\r\n makeObject: function (array, value) {\r\n var map = {};\r\n for (var i = 0; i < array.length; i++) {\r\n if (BI.isNull(value)) {\r\n map[array[i]] = array[i];\r\n } else if (BI.isFunction(value)) {\r\n map[array[i]] = value(i, array[i]);\r\n } else {\r\n map[array[i]] = BI.deepClone(value);\r\n }\r\n }\r\n return map;\r\n },\r\n\r\n makeArrayByArray: function (array, value) {\r\n var res = [];\r\n if (!array) {\r\n return res;\r\n }\r\n for (var i = 0, len = array.length; i < len; i++) {\r\n if (BI.isArray(array[i])) {\r\n res.push(arguments.callee(array[i], value));\r\n } else {\r\n res.push(BI.deepClone(value));\r\n }\r\n }\r\n return res;\r\n },\r\n\r\n uniq: function (array, isSorted, iteratee, context) {\r\n if (array == null) {\r\n return [];\r\n }\r\n if (!_.isBoolean(isSorted)) {\r\n context = iteratee;\r\n iteratee = isSorted;\r\n isSorted = false;\r\n }\r\n iteratee && (iteratee = traverse(iteratee, context));\r\n return _.uniq.call(_, array, isSorted, iteratee, context);\r\n }\r\n });\r\n\r\n // 对象相关方法\r\n _.each([\"keys\", \"allKeys\", \"values\", \"pairs\", \"invert\", \"create\", \"functions\", \"extend\", \"extendOwn\",\r\n \"defaults\", \"clone\", \"property\", \"propertyOf\", \"matcher\", \"isEqual\", \"isMatch\", \"isEmpty\",\r\n \"isElement\", \"isNumber\", \"isString\", \"isArray\", \"isObject\", \"isPlainObject\", \"isArguments\", \"isFunction\", \"isFinite\",\r\n \"isBoolean\", \"isDate\", \"isRegExp\", \"isError\", \"isNaN\", \"isUndefined\", \"zipObject\", \"cloneDeep\"], function (name) {\r\n BI[name] = _apply(name);\r\n });\r\n _.each([\"mapObject\", \"findKey\", \"pick\", \"omit\", \"tap\"], function (name) {\r\n BI[name] = _applyFunc(name);\r\n });\r\n _.extend(BI, {\r\n\r\n inherit: function (sb, sp, overrides) {\r\n if (typeof sp === \"object\") {\r\n overrides = sp;\r\n sp = sb;\r\n sb = function () {\r\n return sp.apply(this, arguments);\r\n };\r\n }\r\n var F = function () {\r\n }, spp = sp.prototype;\r\n F.prototype = spp;\r\n sb.prototype = new F();\r\n sb.superclass = spp;\r\n _.extend(sb.prototype, overrides, {\r\n superclass: sp\r\n });\r\n return sb;\r\n },\r\n\r\n init: function () {\r\n // 先把准备环境准备好\r\n while (BI.prepares && BI.prepares.length > 0) {\r\n BI.prepares.shift()();\r\n }\r\n while (_global.___fineuiExposedFunction && _global.___fineuiExposedFunction.length > 0) {\r\n _global.___fineuiExposedFunction.shift()();\r\n }\r\n BI.initialized = true;\r\n },\r\n\r\n has: function (obj, keys) {\r\n if (BI.isArray(keys)) {\r\n if (keys.length === 0) {\r\n return false;\r\n }\r\n return BI.every(keys, function (i, key) {\r\n return _.has(obj, key);\r\n });\r\n }\r\n return _.has.apply(_, arguments);\r\n },\r\n\r\n freeze: function (value) {\r\n // 在ES5中,如果这个方法的参数不是一个对象(一个原始值),那么它会导致 TypeError\r\n // 在ES2015中,非对象参数将被视为要被冻结的普通对象,并被简单地返回\r\n if (Object.freeze && BI.isObject(value)) {\r\n return Object.freeze(value);\r\n }\r\n return value;\r\n },\r\n\r\n // 数字和字符串可以作为key\r\n isKey: function (key) {\r\n return BI.isNumber(key) || (BI.isString(key) && key.length > 0);\r\n },\r\n\r\n // 忽略大小写的等于\r\n isCapitalEqual: function (a, b) {\r\n a = BI.isNull(a) ? a : (\"\" + a).toLowerCase();\r\n b = BI.isNull(b) ? b : (\"\" + b).toLowerCase();\r\n return BI.isEqual(a, b);\r\n },\r\n\r\n isWidthOrHeight: function (w) {\r\n if (typeof w === \"number\") {\r\n return w >= 0;\r\n } else if (typeof w === \"string\") {\r\n return /^\\d{1,3}%$/.exec(w) || w == \"auto\" || /^\\d+px$/.exec(w);\r\n }\r\n },\r\n\r\n isNotNull: function (obj) {\r\n return !BI.isNull(obj);\r\n },\r\n\r\n isNull: function (obj) {\r\n return typeof obj === \"undefined\" || obj === null;\r\n },\r\n\r\n isEmptyArray: function (arr) {\r\n return BI.isArray(arr) && BI.isEmpty(arr);\r\n },\r\n\r\n isNotEmptyArray: function (arr) {\r\n return BI.isArray(arr) && !BI.isEmpty(arr);\r\n },\r\n\r\n isEmptyObject: function (obj) {\r\n return BI.isEqual(obj, {});\r\n },\r\n\r\n isNotEmptyObject: function (obj) {\r\n return BI.isPlainObject(obj) && !BI.isEmptyObject(obj);\r\n },\r\n\r\n isEmptyString: function (obj) {\r\n return BI.isString(obj) && obj.length === 0;\r\n },\r\n\r\n isNotEmptyString: function (obj) {\r\n return BI.isString(obj) && !BI.isEmptyString(obj);\r\n },\r\n\r\n isWindow: function (obj) {\r\n return obj != null && obj == obj.window;\r\n }\r\n });\r\n\r\n // deep方法\r\n _.extend(BI, {\r\n deepClone: _.cloneDeep,\r\n deepExtend: _.merge,\r\n\r\n isDeepMatch: function (object, attrs) {\r\n var keys = BI.keys(attrs), length = keys.length;\r\n if (object == null) {\r\n return !length;\r\n }\r\n var obj = Object(object);\r\n for (var i = 0; i < length; i++) {\r\n var key = keys[i];\r\n if (!BI.isEqual(attrs[key], obj[key]) || !(key in obj)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n },\r\n\r\n contains: function (obj, target, fromIndex) {\r\n if (!_.isArrayLike(obj)) obj = _.values(obj);\r\n return _.indexOf(obj, target, typeof fromIndex === \"number\" && fromIndex) >= 0;\r\n },\r\n\r\n deepContains: function (obj, copy) {\r\n if (BI.isObject(copy)) {\r\n return BI.any(obj, function (i, v) {\r\n if (BI.isEqual(v, copy)) {\r\n return true;\r\n }\r\n });\r\n }\r\n return BI.contains(obj, copy);\r\n },\r\n\r\n deepIndexOf: function (obj, target) {\r\n for (var i = 0; i < obj.length; i++) {\r\n if (BI.isEqual(target, obj[i])) {\r\n return i;\r\n }\r\n }\r\n return -1;\r\n },\r\n\r\n deepRemove: function (obj, target) {\r\n var done = false;\r\n var i;\r\n if (BI.isArray(obj)) {\r\n for (i = 0; i < obj.length; i++) {\r\n if (BI.isEqual(target, obj[i])) {\r\n obj.splice(i--, 1);\r\n done = true;\r\n }\r\n }\r\n } else {\r\n BI.each(obj, function (i, v) {\r\n if (BI.isEqual(target, obj[i])) {\r\n delete obj[i];\r\n done = true;\r\n }\r\n });\r\n }\r\n return done;\r\n },\r\n\r\n deepWithout: function (obj, target) {\r\n if (BI.isArray(obj)) {\r\n var result = [];\r\n for (var i = 0; i < obj.length; i++) {\r\n if (!BI.isEqual(target, obj[i])) {\r\n result.push(obj[i]);\r\n }\r\n }\r\n return result;\r\n }\r\n var result = {};\r\n BI.each(obj, function (i, v) {\r\n if (!BI.isEqual(target, obj[i])) {\r\n result[i] = v;\r\n }\r\n });\r\n return result;\r\n\r\n },\r\n\r\n deepUnique: function (array) {\r\n var result = [];\r\n BI.each(array, function (i, item) {\r\n if (!BI.deepContains(result, item)) {\r\n result.push(item);\r\n }\r\n });\r\n return result;\r\n },\r\n\r\n // 比较两个对象得出不一样的key值\r\n deepDiff: function (object, other) {\r\n object || (object = {});\r\n other || (other = {});\r\n var result = [];\r\n var used = [];\r\n for (var b in object) {\r\n if (this.has(object, b)) {\r\n if (!this.isEqual(object[b], other[b])) {\r\n result.push(b);\r\n }\r\n used.push(b);\r\n }\r\n }\r\n for (var b in other) {\r\n if (this.has(other, b) && !BI.contains(used, b)) {\r\n result.push(b);\r\n }\r\n }\r\n return result;\r\n }\r\n });\r\n\r\n // 通用方法\r\n _.each([\"uniqueId\", \"result\", \"chain\", \"iteratee\", \"escape\", \"unescape\", \"before\", \"after\"], function (name) {\r\n BI[name] = function () {\r\n return _[name].apply(_, arguments);\r\n };\r\n });\r\n\r\n // 事件相关方法\r\n _.each([\"bind\", \"once\", \"partial\", \"debounce\", \"throttle\", \"delay\", \"defer\", \"wrap\"], function (name) {\r\n BI[name] = function () {\r\n return _[name].apply(_, arguments);\r\n };\r\n });\r\n\r\n _.extend(BI, {\r\n nextTick: (function () {\r\n var callbacks = [];\r\n var pending = false;\r\n var timerFunc = void 0;\r\n\r\n function nextTickHandler() {\r\n pending = false;\r\n var copies = callbacks.slice(0);\r\n callbacks.length = 0;\r\n for (var i = 0; i < copies.length; i++) {\r\n copies[i]();\r\n }\r\n }\r\n\r\n if (typeof Promise !== \"undefined\") {\r\n var p = Promise.resolve();\r\n timerFunc = function timerFunc() {\r\n p.then(nextTickHandler);\r\n };\r\n } else if (typeof MutationObserver !== \"undefined\") {\r\n var counter = 1;\r\n var observer = new MutationObserver(nextTickHandler);\r\n var textNode = document.createTextNode(String(counter));\r\n observer.observe(textNode, {\r\n characterData: true\r\n });\r\n timerFunc = function timerFunc() {\r\n counter = (counter + 1) % 2;\r\n textNode.data = String(counter);\r\n };\r\n } else if (typeof setImmediate !== \"undefined\") {\r\n timerFunc = function timerFunc() {\r\n setImmediate(nextTickHandler);\r\n };\r\n } else {\r\n // Fallback to setTimeout.\r\n timerFunc = function timerFunc() {\r\n setTimeout(nextTickHandler, 0);\r\n };\r\n }\r\n\r\n return function queueNextTick(cb) {\r\n var _resolve = void 0;\r\n var args = [].slice.call(arguments, 1);\r\n callbacks.push(function () {\r\n if (cb) {\r\n try {\r\n cb.apply(null, args);\r\n } catch (e) {\r\n console.error(e);\r\n }\r\n } else if (_resolve) {\r\n _resolve.apply(null, args);\r\n }\r\n });\r\n if (!pending) {\r\n pending = true;\r\n timerFunc();\r\n }\r\n // $flow-disable-line\r\n if (!cb && typeof Promise !== 'undefined') {\r\n return new Promise(function (resolve, reject) {\r\n _resolve = resolve;\r\n });\r\n }\r\n };\r\n })()\r\n });\r\n\r\n // 数字相关方法\r\n _.each([\"random\"], function (name) {\r\n BI[name] = _apply(name);\r\n });\r\n _.extend(BI, {\r\n getTime: function () {\r\n if (_global.performance && _global.performance.now) {\r\n return _global.performance.now();\r\n }\r\n if (_global.performance && _global.performance.webkitNow) {\r\n return _global.performance.webkitNow();\r\n }\r\n if (Date.now) {\r\n return Date.now();\r\n }\r\n return BI.getDate().getTime();\r\n\r\n\r\n },\r\n\r\n parseInt: function (number) {\r\n var radix = 10;\r\n if (/^0x/g.test(number)) {\r\n radix = 16;\r\n }\r\n try {\r\n return parseInt(number, radix);\r\n } catch (e) {\r\n throw new Error(number + \"parse int error\");\r\n return NaN;\r\n }\r\n },\r\n\r\n parseSafeInt: function (value) {\r\n var MAX_SAFE_INTEGER = 9007199254740991;\r\n return value\r\n ? this.clamp(this.parseInt(value), -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER)\r\n : (value === 0 ? value : 0);\r\n },\r\n\r\n parseFloat: function (number) {\r\n try {\r\n return parseFloat(number);\r\n } catch (e) {\r\n throw new Error(number + \"parse float error\");\r\n return NaN;\r\n }\r\n },\r\n\r\n isNaturalNumber: function (number) {\r\n if (/^\\d+$/.test(number)) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n\r\n isPositiveInteger: function (number) {\r\n if (/^\\+?[1-9][0-9]*$/.test(number)) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n\r\n isNegativeInteger: function (number) {\r\n if (/^\\-[1-9][0-9]*$/.test(number)) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n\r\n isInteger: function (number) {\r\n if (/^\\-?\\d+$/.test(number)) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n\r\n isNumeric: function (number) {\r\n return !isNaN(parseFloat(number)) && isFinite(number);\r\n },\r\n\r\n isFloat: function (number) {\r\n if (/^([+-]?)\\d*\\.\\d+$/.test(number)) {\r\n return true;\r\n }\r\n return false;\r\n },\r\n\r\n isOdd: function (number) {\r\n if (!BI.isInteger(number)) {\r\n return false;\r\n }\r\n return (number & 1) === 1;\r\n },\r\n\r\n isEven: function (number) {\r\n if (!BI.isInteger(number)) {\r\n return false;\r\n }\r\n return (number & 1) === 0;\r\n },\r\n\r\n sum: function (array, iteratee, context) {\r\n var sum = 0;\r\n BI.each(array, function (i, item) {\r\n if (iteratee) {\r\n sum += Number(iteratee.apply(context, [i, item]));\r\n } else {\r\n sum += Number(item);\r\n }\r\n });\r\n return sum;\r\n },\r\n\r\n average: function (array, iteratee, context) {\r\n var sum = BI.sum(array, iteratee, context);\r\n return sum / array.length;\r\n }\r\n });\r\n\r\n // 字符串相关方法\r\n _.extend(BI, {\r\n trim: function () {\r\n return _.trim.apply(_, arguments);\r\n },\r\n\r\n toUpperCase: function (string) {\r\n return (string + \"\").toLocaleUpperCase();\r\n },\r\n\r\n toLowerCase: function (string) {\r\n return (string + \"\").toLocaleLowerCase();\r\n },\r\n\r\n isEndWithBlank: function (string) {\r\n return /(\\s|\\u00A0)$/.test(string);\r\n },\r\n\r\n isLiteral: function (exp) {\r\n var literalValueRE = /^\\s?(true|false|-?[\\d\\.]+|'[^']*'|\"[^\"]*\")\\s?$/;\r\n return literalValueRE.test(exp);\r\n },\r\n\r\n stripQuotes: function (str) {\r\n var a = str.charCodeAt(0);\r\n var b = str.charCodeAt(str.length - 1);\r\n return a === b && (a === 0x22 || a === 0x27)\r\n ? str.slice(1, -1)\r\n : str;\r\n },\r\n\r\n // background-color => backgroundColor\r\n camelize: function (str) {\r\n return str.replace(/-(.)/g, function (_, character) {\r\n return character.toUpperCase();\r\n });\r\n },\r\n\r\n // backgroundColor => background-color\r\n hyphenate: function (str) {\r\n return str.replace(/([A-Z])/g, \"-$1\").toLowerCase();\r\n },\r\n\r\n isNotEmptyString: function (str) {\r\n return BI.isString(str) && !BI.isEmpty(str);\r\n },\r\n\r\n isEmptyString: function (str) {\r\n return BI.isString(str) && BI.isEmpty(str);\r\n },\r\n\r\n /**\r\n * 通用加密方法\r\n */\r\n encrypt: function (type, text, key) {\r\n switch (type) {\r\n case BI.CRYPT_TYPE.AES:\r\n default:\r\n return BI.aesEncrypt(text, key);\r\n }\r\n },\r\n\r\n /**\r\n * 通用解密方法\r\n * @param type 解密方式\r\n * @param text 文本\r\n * @param key 种子\r\n * @return {*}\r\n */\r\n decrypt: function (type, text, key) {\r\n switch (type) {\r\n case BI.CRYPT_TYPE.AES:\r\n default:\r\n return BI.aesDecrypt(text, key);\r\n }\r\n },\r\n\r\n /**\r\n * 对字符串中的'和\\做编码处理\r\n * @static\r\n * @param {String} string 要做编码处理的字符串\r\n * @return {String} 编码后的字符串\r\n */\r\n escape: function (string) {\r\n return string.replace(/('|\\\\)/g, \"\\\\$1\");\r\n },\r\n\r\n /**\r\n * 让字符串通过指定字符做补齐的函数\r\n *\r\n * var s = BI.leftPad('123', 5, '0');//s的值为:'00123'\r\n *\r\n * @static\r\n * @param {String} val 原始值\r\n * @param {Number} size 总共需要的位数\r\n * @param {String} ch 用于补齐的字符\r\n * @return {String} 补齐后的字符串\r\n */\r\n leftPad: function (val, size, ch) {\r\n var result = String(val);\r\n if (!ch) {\r\n ch = \" \";\r\n }\r\n while (result.length < size) {\r\n result = ch + result;\r\n }\r\n return result.toString();\r\n },\r\n\r\n /**\r\n * 对字符串做替换的函数\r\n *\r\n * var cls = 'my-class', text = 'Some text';\r\n * var res = BI.format('
    {1}
    ', cls, text);\r\n * //res的值为:'
    Some text
    ';\r\n *\r\n * @static\r\n * @param {String} format 要做替换的字符串,替换字符串1,替换字符串2...\r\n * @return {String} 做了替换后的字符串\r\n */\r\n format: function (format) {\r\n var args = Array.prototype.slice.call(arguments, 1);\r\n return format.replace(/\\{(\\d+)\\}/g, function (m, i) {\r\n return args[i];\r\n });\r\n }\r\n });\r\n\r\n // 日期相关方法\r\n _.extend(BI, {\r\n /**\r\n * 是否是闰年\r\n * @param year\r\n * @returns {boolean}\r\n */\r\n isLeapYear: function (year) {\r\n return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0;\r\n },\r\n\r\n /**\r\n * 检测是否在有效期\r\n *\r\n * @param YY 年\r\n * @param MM 月\r\n * @param DD 日\r\n * @param minDate '1900-01-01'\r\n * @param maxDate '2099-12-31'\r\n * @returns {Array} 若无效返回无效状态\r\n */\r\n checkDateVoid: function (YY, MM, DD, minDate, maxDate) {\r\n var back = [];\r\n YY = YY | 0;\r\n MM = MM | 0;\r\n DD = DD | 0;\r\n minDate = BI.isString(minDate) ? minDate.match(/\\d+/g) : minDate;\r\n maxDate = BI.isString(maxDate) ? maxDate.match(/\\d+/g) : maxDate;\r\n if (YY < minDate[0]) {\r\n back = [\"y\"];\r\n } else if (YY > maxDate[0]) {\r\n back = [\"y\", 1];\r\n } else if (YY >= minDate[0] && YY <= maxDate[0]) {\r\n if (YY == minDate[0]) {\r\n if (MM < minDate[1]) {\r\n back = [\"m\"];\r\n } else if (MM == minDate[1]) {\r\n if (DD < minDate[2]) {\r\n back = [\"d\"];\r\n }\r\n }\r\n }\r\n if (YY == maxDate[0]) {\r\n if (MM > maxDate[1]) {\r\n back = [\"m\", 1];\r\n } else if (MM == maxDate[1]) {\r\n if (DD > maxDate[2]) {\r\n back = [\"d\", 1];\r\n }\r\n }\r\n }\r\n }\r\n return back;\r\n },\r\n\r\n checkDateLegal: function (str) {\r\n var ar = str.match(/\\d+/g);\r\n var YY = ar[0] | 0, MM = ar[1] | 0, DD = ar[2] | 0;\r\n if (ar.length <= 1) {\r\n return true;\r\n }\r\n if (ar.length <= 2) {\r\n return MM >= 1 && MM <= 12;\r\n }\r\n var MD = BI.Date._MD.slice(0);\r\n MD[1] = BI.isLeapYear(YY) ? 29 : 28;\r\n return MM >= 1 && MM <= 12 && DD <= MD[MM - 1];\r\n },\r\n\r\n parseDateTime: function (str, fmt) {\r\n var today = BI.getDate();\r\n var y = 0;\r\n var m = 0;\r\n var d = 1;\r\n // wei : 对于fmt为‘YYYYMM’或者‘YYYYMMdd’的格式,str的值为类似'201111'的形式,因为年月之间没有分隔符,所以正则表达式分割无效,导致bug7376。\r\n var a = str.split(/\\W+/);\r\n if (fmt.toLowerCase() == \"%y%x\" || fmt.toLowerCase() == \"%y%x%d\") {\r\n var yearlength = 4;\r\n var otherlength = 2;\r\n a[0] = str.substring(0, yearlength);\r\n a[1] = str.substring(yearlength, yearlength + otherlength);\r\n a[2] = str.substring(yearlength + otherlength, yearlength + otherlength * 2);\r\n }\r\n var b = fmt.match(/%./g);\r\n var i = 0, j = 0;\r\n var hr = 0;\r\n var min = 0;\r\n var sec = 0;\r\n for (i = 0; i < a.length; ++i) {\r\n switch (b[i]) {\r\n case \"%d\":\r\n case \"%e\":\r\n d = parseInt(a[i], 10);\r\n break;\r\n\r\n case \"%X\":\r\n m = parseInt(a[i], 10) - 1;\r\n break;\r\n case \"%x\":\r\n m = parseInt(a[i], 10) - 1;\r\n break;\r\n\r\n case \"%Y\":\r\n case \"%y\":\r\n y = parseInt(a[i], 10);\r\n (y < 100) && (y += (y > 29) ? 1900 : 2000);\r\n break;\r\n\r\n case \"%b\":\r\n case \"%B\":\r\n for (j = 0; j < 12; ++j) {\r\n if (BI.Date._MN[j].substr(0, a[i].length).toLowerCase() == a[i].toLowerCase()) {\r\n m = j;\r\n break;\r\n }\r\n }\r\n break;\r\n\r\n case \"%H\":\r\n case \"%I\":\r\n case \"%k\":\r\n case \"%l\":\r\n hr = parseInt(a[i], 10);\r\n break;\r\n\r\n case \"%P\":\r\n case \"%p\":\r\n if (/pm/i.test(a[i]) && hr < 12) {\r\n hr += 12;\r\n } else if (/am/i.test(a[i]) && hr >= 12) {\r\n hr -= 12;\r\n }\r\n break;\r\n\r\n case \"%M\":\r\n min = parseInt(a[i], 10);\r\n break;\r\n case \"%S\":\r\n sec = parseInt(a[i], 10);\r\n break;\r\n }\r\n }\r\n // if (!a[i]) {\r\n // continue;\r\n //\t}\r\n if (isNaN(y)) {\r\n y = today.getFullYear();\r\n }\r\n if (isNaN(m)) {\r\n m = today.getMonth();\r\n }\r\n if (isNaN(d)) {\r\n d = today.getDate();\r\n }\r\n if (isNaN(hr)) {\r\n hr = today.getHours();\r\n }\r\n if (isNaN(min)) {\r\n min = today.getMinutes();\r\n }\r\n if (isNaN(sec)) {\r\n sec = today.getSeconds();\r\n }\r\n if (y != 0) {\r\n return BI.getDate(y, m, d, hr, min, sec);\r\n }\r\n y = 0;\r\n m = -1;\r\n d = 0;\r\n for (i = 0; i < a.length; ++i) {\r\n if (a[i].search(/[a-zA-Z]+/) != -1) {\r\n var t = -1;\r\n for (j = 0; j < 12; ++j) {\r\n if (BI.Date._MN[j].substr(0, a[i].length).toLowerCase() == a[i].toLowerCase()) {\r\n t = j;\r\n break;\r\n }\r\n }\r\n if (t != -1) {\r\n if (m != -1) {\r\n d = m + 1;\r\n }\r\n m = t;\r\n }\r\n } else if (parseInt(a[i], 10) <= 12 && m == -1) {\r\n m = a[i] - 1;\r\n } else if (parseInt(a[i], 10) > 31 && y == 0) {\r\n y = parseInt(a[i], 10);\r\n (y < 100) && (y += (y > 29) ? 1900 : 2000);\r\n } else if (d == 0) {\r\n d = a[i];\r\n }\r\n }\r\n if (y == 0) {\r\n y = today.getFullYear();\r\n }\r\n if (m === -1) {\r\n m = today.getMonth();\r\n }\r\n if (m != -1 && d != 0) {\r\n return BI.getDate(y, m, d, hr, min, sec);\r\n }\r\n return today;\r\n },\r\n\r\n getDate: function () {\r\n var length = arguments.length;\r\n var args = arguments;\r\n var dt;\r\n switch (length) {\r\n // new Date()\r\n case 0:\r\n dt = new Date();\r\n break;\r\n // new Date(long)\r\n case 1:\r\n dt = new Date(args[0]);\r\n break;\r\n // new Date(year, month)\r\n case 2:\r\n dt = new Date(args[0], args[1]);\r\n break;\r\n // new Date(year, month, day)\r\n case 3:\r\n dt = new Date(args[0], args[1], args[2]);\r\n break;\r\n // new Date(year, month, day, hour)\r\n case 4:\r\n dt = new Date(args[0], args[1], args[2], args[3]);\r\n break;\r\n // new Date(year, month, day, hour, minute)\r\n case 5:\r\n dt = new Date(args[0], args[1], args[2], args[3], args[4]);\r\n break;\r\n // new Date(year, month, day, hour, minute, second)\r\n case 6:\r\n dt = new Date(args[0], args[1], args[2], args[3], args[4], args[5]);\r\n break;\r\n // new Date(year, month, day, hour, minute, second, millisecond)\r\n case 7:\r\n dt = new Date(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\r\n break;\r\n default:\r\n dt = new Date();\r\n break;\r\n }\r\n if (BI.isNotNull(BI.timeZone) && (arguments.length === 0 || (arguments.length === 1 && BI.isNumber(arguments[0])))) {\r\n var localTime = dt.getTime();\r\n // BI-33791 1901年以前的东8区标准是GMT+0805, 统一无论是什么时间,都以整的0800这样的为基准\r\n var localOffset = dt.getTimezoneOffset() * 60000; // 获得当地时间偏移的毫秒数\r\n var utc = localTime + localOffset; // utc即GMT时间标准时区\r\n return new Date(utc + BI.timeZone);// + Pool.timeZone.offset);\r\n }\r\n return dt;\r\n\r\n },\r\n\r\n getTime: function () {\r\n var length = arguments.length;\r\n var args = arguments;\r\n var dt;\r\n switch (length) {\r\n // new Date()\r\n case 0:\r\n dt = new Date();\r\n break;\r\n // new Date(long)\r\n case 1:\r\n dt = new Date(args[0]);\r\n break;\r\n // new Date(year, month)\r\n case 2:\r\n dt = new Date(args[0], args[1]);\r\n break;\r\n // new Date(year, month, day)\r\n case 3:\r\n dt = new Date(args[0], args[1], args[2]);\r\n break;\r\n // new Date(year, month, day, hour)\r\n case 4:\r\n dt = new Date(args[0], args[1], args[2], args[3]);\r\n break;\r\n // new Date(year, month, day, hour, minute)\r\n case 5:\r\n dt = new Date(args[0], args[1], args[2], args[3], args[4]);\r\n break;\r\n // new Date(year, month, day, hour, minute, second)\r\n case 6:\r\n dt = new Date(args[0], args[1], args[2], args[3], args[4], args[5]);\r\n break;\r\n // new Date(year, month, day, hour, minute, second, millisecond)\r\n case 7:\r\n dt = new Date(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\r\n break;\r\n default:\r\n dt = new Date();\r\n break;\r\n }\r\n if (BI.isNotNull(BI.timeZone)) {\r\n // BI-33791 1901年以前的东8区标准是GMT+0805, 统一无论是什么时间,都以整的0800这样的为基准\r\n return dt.getTime() - BI.timeZone - new Date().getTimezoneOffset() * 60000;\r\n }\r\n return dt.getTime();\r\n\r\n }\r\n });\r\n})();\r\n","(function (global, undefined) {\n \"use strict\";\n\n if (global.setImmediate) {\n return;\n }\n\n var nextHandle = 1; // Spec says greater than zero\n var tasksByHandle = {};\n var currentlyRunningATask = false;\n var doc = global.document;\n var registerImmediate;\n\n function setImmediate(callback) {\n // Callback can either be a function or a string\n if (typeof callback !== \"function\") {\n callback = new Function(\"\" + callback);\n }\n // Copy function arguments\n var args = new Array(arguments.length - 1);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 1];\n }\n // Store and register the task\n var task = { callback: callback, args: args };\n tasksByHandle[nextHandle] = task;\n registerImmediate(nextHandle);\n return nextHandle++;\n }\n\n function clearImmediate(handle) {\n delete tasksByHandle[handle];\n }\n\n function run(task) {\n var callback = task.callback;\n var args = task.args;\n switch (args.length) {\n case 0:\n callback();\n break;\n case 1:\n callback(args[0]);\n break;\n case 2:\n callback(args[0], args[1]);\n break;\n case 3:\n callback(args[0], args[1], args[2]);\n break;\n default:\n callback.apply(undefined, args);\n break;\n }\n }\n\n function runIfPresent(handle) {\n // From the spec: \"Wait until any invocations of this algorithm started before this one have completed.\"\n // So if we're currently running a task, we'll need to delay this invocation.\n if (currentlyRunningATask) {\n // Delay by doing a setTimeout. setImmediate was tried instead, but in Firefox 7 it generated a\n // \"too much recursion\" error.\n setTimeout(runIfPresent, 0, handle);\n } else {\n var task = tasksByHandle[handle];\n if (task) {\n currentlyRunningATask = true;\n try {\n run(task);\n } finally {\n clearImmediate(handle);\n currentlyRunningATask = false;\n }\n }\n }\n }\n\n function installNextTickImplementation() {\n registerImmediate = function(handle) {\n process.nextTick(function () { runIfPresent(handle); });\n };\n }\n\n function canUsePostMessage() {\n // The test against `importScripts` prevents this implementation from being installed inside a web worker,\n // where `global.postMessage` means something completely different and can't be used for this purpose.\n if (global.postMessage && !global.importScripts) {\n var postMessageIsAsynchronous = true;\n var oldOnMessage = global.onmessage;\n global.onmessage = function() {\n postMessageIsAsynchronous = false;\n };\n global.postMessage(\"\", \"*\");\n global.onmessage = oldOnMessage;\n return postMessageIsAsynchronous;\n }\n }\n\n function installPostMessageImplementation() {\n // Installs an event handler on `global` for the `message` event: see\n // * https://developer.mozilla.org/en/DOM/window.postMessage\n // * http://www.whatwg.org/specs/web-apps/current-work/multipage/comms.html#crossDocumentMessages\n\n var messagePrefix = \"setImmediate$\" + Math.random() + \"$\";\n var onGlobalMessage = function(event) {\n if (event.source === global &&\n typeof event.data === \"string\" &&\n event.data.indexOf(messagePrefix) === 0) {\n runIfPresent(+event.data.slice(messagePrefix.length));\n }\n };\n\n if (global.addEventListener) {\n global.addEventListener(\"message\", onGlobalMessage, false);\n } else {\n global.attachEvent(\"onmessage\", onGlobalMessage);\n }\n\n registerImmediate = function(handle) {\n global.postMessage(messagePrefix + handle, \"*\");\n };\n }\n\n function installMessageChannelImplementation() {\n var channel = new MessageChannel();\n channel.port1.onmessage = function(event) {\n var handle = event.data;\n runIfPresent(handle);\n };\n\n registerImmediate = function(handle) {\n channel.port2.postMessage(handle);\n };\n }\n\n function installReadyStateChangeImplementation() {\n var html = doc.documentElement;\n registerImmediate = function(handle) {\n // Create a