Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
guns-vip
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
chenjunxiong
guns-vip
Commits
389b0796
Commit
389b0796
authored
Nov 06, 2018
by
fengshuonan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
个人信息页面
parent
abf52034
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
176 additions
and
142 deletions
+176
-142
src/main/webapp/WEB-INF/common/_container.html
+6
-0
src/main/webapp/WEB-INF/system/user/user_chpwd.html
+2
-2
src/main/webapp/WEB-INF/system/user/user_view.html
+131
-57
src/main/webapp/assets/common/plugins/cropper/cropper.min.css
+10
-0
src/main/webapp/assets/common/plugins/cropper/cropper.min.js
+11
-0
src/main/webapp/assets/modular/system/user/user_view.js
+16
-83
No files found.
src/main/webapp/WEB-INF/common/_container.html
View file @
389b0796
...
...
@@ -59,6 +59,9 @@
@if(array.contain(plugins,"sweet-alert")){
<link
href=
"${ctxPath}/assets/common/plugins/sweetalert/sweetalert.css"
rel=
"stylesheet"
type=
"text/css"
/>
@}
@if(array.contain(plugins,"cropper")){
<link
href=
"${ctxPath}/assets/common/plugins/cropper/cropper.min.css"
rel=
"stylesheet"
type=
"text/css"
/>
@}
@}
<!--其他业务用的css-->
...
...
@@ -160,6 +163,9 @@
@if(array.contain(plugins,"laydate")){
<script
src=
"${ctxPath}/assets/common/plugins/laydate/laydate.js"
></script>
@}
@if(array.contain(plugins,"cropper")){
<script
src=
"${ctxPath}/assets/common/plugins/cropper/cropper.min.js"
></script>
@}
@}
<!--其他业务用的js-->
...
...
src/main/webapp/WEB-INF/system/user/user_chpwd.html
View file @
389b0796
...
...
@@ -33,10 +33,10 @@
<hr/>
<div
class=
"row"
>
<div
class=
"col-md-12"
>
<button
class=
"btn btn-info"
type=
"button"
id=
"saveButton"
\@
click=
"ensure"
>
<button
class=
"btn btn-info
waves-effect
"
type=
"button"
id=
"saveButton"
\@
click=
"ensure"
>
<i
class=
"ace-icon fa fa-check"
></i>
保存
</button>
<button
class=
"btn btn-danger m-l-10"
type=
"button"
id=
"closeButton"
\@
click=
"reset"
>
<button
class=
"btn btn-danger
waves-effect
m-l-10"
type=
"button"
id=
"closeButton"
\@
click=
"reset"
>
<i
class=
"ace-icon fa fa-close"
></i>
重置
</button>
</div>
...
...
src/main/webapp/WEB-INF/system/user/user_view.html
View file @
389b0796
@layout("/common/_container.html"){
<div
class=
"col-sm-6 col-sm-offset-3"
>
<div
class=
"ibox float-e-margins"
>
<div
class=
"ibox-title"
>
<h5>
用户管理
</h5>
</div>
<div
class=
"ibox-content"
>
<div
class=
"row row-lg"
>
@layout("/common/_container.html",{plugins:["cropper"],js:["/assets/modular/system/user/user_view.js"]}){
<div
class=
"row"
>
<div
class=
"col-lg-4 col-xlg-3 col-md-5"
>
<div
class=
"card"
>
<div
class=
"card-block"
>
<center
class=
"m-t-30"
><img
src=
"${avatar}"
class=
"img-circle"
width=
"150"
/>
<h4
class=
"card-title m-t-10"
>
Hanna Gover
</h4>
<h6
class=
"card-subtitle"
>
Accoubts Manager Amix corp
</h6>
<div
class=
"row text-center justify-content-md-center"
>
<div
class=
"col-4"
><a
href=
"javascript:void(0)"
class=
"link"
><i
class=
"icon-people"
></i>
<font
class=
"font-medium"
>
254
</font></a></div>
<div
class=
"col-4"
><a
href=
"javascript:void(0)"
class=
"link"
><i
class=
"icon-picture"
></i>
<font
class=
"font-medium"
>
54
</font></a></div>
</div>
</center>
</div>
<div>
<hr>
</div>
<div
class=
"card-block"
>
<small
class=
"text-muted"
>
Email address
</small>
<h6>
hannagover\@gmail.com
</h6>
<small
class=
"text-muted p-t-30 db"
>
Phone
</small>
<h6>
+91 654 784 547
</h6>
<small
class=
"text-muted p-t-30 db"
>
Address
</small>
<h6>
71 Pilgrim Avenue Chevy Chase, MD 20815
</h6>
<div
class=
"map-box"
>
<iframe
src=
"https://www.google.com/maps/embed?pb=!1m18!1m12!1m3!1d470029.1604841957!2d72.29955005258641!3d23.019996818380896!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!3m3!1m2!1s0x395e848aba5bd449%3A0x4fcedd11614f6516!2sAhmedabad%2C+Gujarat!5e0!3m2!1sen!2sin!4v1493204785508"
width=
"100%"
height=
"150"
frameborder=
"0"
style=
"border:0"
allowfullscreen
></iframe>
</div>
<small
class=
"text-muted p-t-30 db"
>
Social Profile
</small>
<br/>
<button
class=
"btn btn-circle btn-secondary"
><i
class=
"fa fa-facebook"
></i></button>
<button
class=
"btn btn-circle btn-secondary"
><i
class=
"fa fa-twitter"
></i></button>
<button
class=
"btn btn-circle btn-secondary"
><i
class=
"fa fa-youtube"
></i></button>
</div>
</div>
</div>
<div
class=
"col-lg-8 col-xlg-9 col-md-7"
>
<div
class=
"card"
>
<!-- Nav tabs -->
<ul
class=
"nav nav-tabs profile-tab"
role=
"tablist"
>
<li
class=
"nav-item"
><a
class=
"nav-link active"
data-toggle=
"tab"
href=
"#personal"
role=
"tab"
>
个人信息
</a></li>
<li
class=
"nav-item"
><a
class=
"nav-link"
data-toggle=
"tab"
href=
"#avatar"
role=
"tab"
>
修改头像
</a></li>
<li
class=
"nav-item"
><a
class=
"nav-link"
data-toggle=
"tab"
href=
"#loginLog"
role=
"tab"
>
登录日志
</a></li>
</ul>
<!-- Tab panes -->
<div
class=
"tab-content"
>
<div
class=
"tab-pane active"
id=
"personal"
role=
"tabpanel"
>
<div
class=
"card-block"
>
<form
class=
"form-horizontal form-material"
>
<div
class=
"form-group"
>
<label
class=
"col-md-12"
>
Full Name
</label>
<div
class=
"col-md-12"
>
<input
type=
"text"
placeholder=
"Johnathan Doe"
class=
"form-control form-control-line"
>
</div>
</div>
<div
class=
"form-group"
>
<label
for=
"example-email"
class=
"col-md-12"
>
Email
</label>
<div
class=
"col-md-12"
>
<input
type=
"email"
placeholder=
"johnathan\@admin.com"
class=
"form-control form-control-line"
name=
"example-email"
id=
"example-email"
>
</div>
</div>
<div
class=
"form-group"
>
<label
class=
"col-md-12"
>
Password
</label>
<div
class=
"col-md-12"
>
<input
type=
"password"
value=
"password"
class=
"form-control form-control-line"
>
</div>
</div>
<div
class=
"form-group"
>
<label
class=
"col-md-12"
>
Phone No
</label>
<div
class=
"col-md-12"
>
<input
type=
"text"
placeholder=
"123 456 7890"
class=
"form-control form-control-line"
>
</div>
</div>
<div
class=
"form-group"
>
<label
class=
"col-md-12"
>
Message
</label>
<div
class=
"col-md-12"
>
<textarea
rows=
"5"
class=
"form-control form-control-line"
></textarea>
</div>
</div>
<div
class=
"form-group"
>
<label
class=
"col-sm-12"
>
Select Country
</label>
<div
class=
"col-sm-12"
>
<div
class=
"ibox float-e-margins"
>
<div
class=
"ibox-content"
style=
"border:none !important; "
>
<div
class=
"form-horizontal"
id=
"userInfoForm"
>
<input
type=
"hidden"
id=
"id"
value=
"${user.id}"
>
<input
type=
"hidden"
id=
"sexValue"
value=
"${user.sex}"
>
<div
class=
"row"
>
<div
class=
"col-sm-6 b-r"
>
<
#
avatar
id=
"avatar"
name=
"头像"
underline=
"true"
avatarImg=
"${user.avatar}"
/>
<
#
input
id=
"account"
name=
"账户"
underline=
"true"
value=
"${user.account}"
disabled=
"disabled"
/>
<
#
select
id=
"sex"
name=
"性别"
underline=
"true"
value=
"${user.sex}"
>
<option
value=
"1"
>
男
</option>
<option
value=
"2"
>
女
</option>
</
#
select>
<
#
input
id=
"roleid"
name=
"角色"
underline=
"true"
value=
"${roleName}"
disabled=
"disabled"
/>
<
#
input
id=
"email"
name=
"邮箱"
type=
"email"
value=
"${user.email}"
/>
<select
class=
"form-control form-control-line"
>
<option>
London
</option>
<option>
India
</option>
<option>
Usa
</option>
<option>
Canada
</option>
<option>
Thailand
</option>
</select>
</div>
</div>
<div
class=
"form-group"
>
<div
class=
"col-sm-12"
>
<button
class=
"btn btn-success"
>
Update Profile
</button>
</div>
</div>
</form>
</div>
</div>
<div
class=
"tab-pane"
id=
"avatar"
role=
"tabpanel"
>
<div
class=
"card-block"
style=
"height: 500px;"
>
<div>
<img
style=
"max-width: 100%;"
id=
"cropperImage"
src=
"${avatar}"
>
</div>
</div>
</div>
<div
class=
"tab-pane"
id=
"loginLog"
role=
"tabpanel"
>
<div
class=
"card-block"
>
<div
class=
"profiletimeline"
>
<div
class=
"sl-item"
>
<div
class=
"sl-left"
><img
src=
"${avatar}"
alt=
"user"
class=
"img-circle"
/></div>
<div
class=
"sl-right"
>
<div><a
href=
"#"
class=
"link"
>
John Doe
</a>
<span
class=
"sl-date"
>
5 minutes ago
</span>
<blockquote
class=
"m-t-10"
>
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt
</blockquote>
</div>
<div
class=
"col-sm-6"
>
<div
id=
"driverInfoContent"
>
<
#
input
id=
"name"
name=
"姓名"
underline=
"true"
value=
"${user.name}"
/>
<
#
input
id=
"birthday"
name=
"出生日期"
underline=
"true"
type=
"text"
value=
"${user.birthday}"
/>
<
#
input
id=
"citySel"
name=
"部门"
underline=
"true"
readonly=
"readonly"
value=
"${deptName}"
hidden=
"deptid"
hiddenValue=
"${user.deptid}"
clickFun=
"UserInfoDlg.showInfoDeptSelectTree(); return false;"
style=
"background-color: #ffffff !important;"
selectFlag=
"true"
selectId=
"menuContent"
selectTreeId=
"treeDemo"
selectStyle=
"width:250px !important;"
/>
<
#
input
id=
"phone"
name=
"电话"
value=
"${user.phone}"
/>
</div>
</div>
<hr>
<div
class=
"sl-item"
>
<div
class=
"sl-left"
><img
src=
"${avatar}"
alt=
"user"
class=
"img-circle"
/></div>
<div
class=
"sl-right"
>
<div><a
href=
"#"
class=
"link"
>
John Doe
</a>
<span
class=
"sl-date"
>
5 minutes ago
</span>
<blockquote
class=
"m-t-10"
>
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt
</blockquote>
</div>
<div
class=
"progress progress-striped"
id=
"progressTipArea"
style=
"margin-top: 20px;"
>
<div
id=
"progressBar"
style=
"width: 0%"
aria-valuemax=
"100"
aria-valuemin=
"0"
aria-valuenow=
"0"
role=
"progressbar"
class=
"progress-bar progress-bar-info"
>
</div>
</div>
<div
class=
"row btn-group-m-t"
>
<div
class=
"col-sm-10"
>
<
#
button
btnCss=
"info"
name=
"提交"
id=
"ensure"
icon=
"fa-check"
clickFun=
"UserInfoDlg.editSubmit()"
/>
<hr>
<div
class=
"sl-item"
>
<div
class=
"sl-left"
><img
src=
"${avatar}"
alt=
"user"
class=
"img-circle"
/></div>
<div
class=
"sl-right"
>
<div><a
href=
"#"
class=
"link"
>
John Doe
</a>
<span
class=
"sl-date"
>
5 minutes ago
</span>
<blockquote
class=
"m-t-10"
>
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt
</blockquote>
</div>
</div>
</div>
...
...
@@ -66,10 +146,4 @@
</div>
</div>
</div>
<script
src=
"${ctxPath}/static/modular/system/user/user_info.js"
></script>
<script>
laydate
.
render
({
elem
:
'#birthday'
});
</script>
@}
src/main/webapp/assets/common/plugins/cropper/cropper.min.css
0 → 100644
View file @
389b0796
/*!
* Cropper.js v1.4.3
* https://fengyuanchen.github.io/cropperjs
*
* Copyright 2015-present Chen Fengyuan
* Released under the MIT license
*
* Date: 2018-10-24T13:07:11.429Z
*/
.cropper-container
{
direction
:
ltr
;
font-size
:
0
;
line-height
:
0
;
position
:
relative
;
-ms-touch-action
:
none
;
touch-action
:
none
;
-webkit-user-select
:
none
;
-moz-user-select
:
none
;
-ms-user-select
:
none
;
user-select
:
none
}
.cropper-container
img
{
display
:
block
;
height
:
100%
;
image-orientation
:
0deg
;
max-height
:
none
!important
;
max-width
:
none
!important
;
min-height
:
0
!important
;
min-width
:
0
!important
;
width
:
100%
}
.cropper-canvas
,
.cropper-crop-box
,
.cropper-drag-box
,
.cropper-modal
,
.cropper-wrap-box
{
bottom
:
0
;
left
:
0
;
position
:
absolute
;
right
:
0
;
top
:
0
}
.cropper-canvas
,
.cropper-wrap-box
{
overflow
:
hidden
}
.cropper-drag-box
{
background-color
:
#fff
;
opacity
:
0
}
.cropper-modal
{
background-color
:
#000
;
opacity
:
.5
}
.cropper-view-box
{
display
:
block
;
height
:
100%
;
outline-color
:
rgba
(
51
,
153
,
255
,
.75
);
outline
:
1px
solid
#39f
;
overflow
:
hidden
;
width
:
100%
}
.cropper-dashed
{
border
:
0
dashed
#eee
;
display
:
block
;
opacity
:
.5
;
position
:
absolute
}
.cropper-dashed.dashed-h
{
border-bottom-width
:
1px
;
border-top-width
:
1px
;
height
:
33.33333%
;
left
:
0
;
top
:
33.33333%
;
width
:
100%
}
.cropper-dashed.dashed-v
{
border-left-width
:
1px
;
border-right-width
:
1px
;
height
:
100%
;
left
:
33.33333%
;
top
:
0
;
width
:
33.33333%
}
.cropper-center
{
display
:
block
;
height
:
0
;
left
:
50%
;
opacity
:
.75
;
position
:
absolute
;
top
:
50%
;
width
:
0
}
.cropper-center
:after
,
.cropper-center
:before
{
background-color
:
#eee
;
content
:
" "
;
display
:
block
;
position
:
absolute
}
.cropper-center
:before
{
height
:
1px
;
left
:
-3px
;
top
:
0
;
width
:
7px
}
.cropper-center
:after
{
height
:
7px
;
left
:
0
;
top
:
-3px
;
width
:
1px
}
.cropper-face
,
.cropper-line
,
.cropper-point
{
display
:
block
;
height
:
100%
;
opacity
:
.1
;
position
:
absolute
;
width
:
100%
}
.cropper-face
{
background-color
:
#fff
;
left
:
0
;
top
:
0
}
.cropper-line
{
background-color
:
#39f
}
.cropper-line.line-e
{
cursor
:
ew-resize
;
right
:
-3px
;
top
:
0
;
width
:
5px
}
.cropper-line.line-n
{
cursor
:
ns-resize
;
height
:
5px
;
left
:
0
;
top
:
-3px
}
.cropper-line.line-w
{
cursor
:
ew-resize
;
left
:
-3px
;
top
:
0
;
width
:
5px
}
.cropper-line.line-s
{
bottom
:
-3px
;
cursor
:
ns-resize
;
height
:
5px
;
left
:
0
}
.cropper-point
{
background-color
:
#39f
;
height
:
5px
;
opacity
:
.75
;
width
:
5px
}
.cropper-point.point-e
{
cursor
:
ew-resize
;
margin-top
:
-3px
;
right
:
-3px
;
top
:
50%
}
.cropper-point.point-n
{
cursor
:
ns-resize
;
left
:
50%
;
margin-left
:
-3px
;
top
:
-3px
}
.cropper-point.point-w
{
cursor
:
ew-resize
;
left
:
-3px
;
margin-top
:
-3px
;
top
:
50%
}
.cropper-point.point-s
{
bottom
:
-3px
;
cursor
:
s-resize
;
left
:
50%
;
margin-left
:
-3px
}
.cropper-point.point-ne
{
cursor
:
nesw-resize
;
right
:
-3px
;
top
:
-3px
}
.cropper-point.point-nw
{
cursor
:
nwse-resize
;
left
:
-3px
;
top
:
-3px
}
.cropper-point.point-sw
{
bottom
:
-3px
;
cursor
:
nesw-resize
;
left
:
-3px
}
.cropper-point.point-se
{
bottom
:
-3px
;
cursor
:
nwse-resize
;
height
:
20px
;
opacity
:
1
;
right
:
-3px
;
width
:
20px
}
@media
(
min-width
:
768px
){
.cropper-point.point-se
{
height
:
15px
;
width
:
15px
}}
@media
(
min-width
:
992px
){
.cropper-point.point-se
{
height
:
10px
;
width
:
10px
}}
@media
(
min-width
:
1200px
){
.cropper-point.point-se
{
height
:
5px
;
opacity
:
.75
;
width
:
5px
}}
.cropper-point.point-se
:before
{
background-color
:
#39f
;
bottom
:
-50%
;
content
:
" "
;
display
:
block
;
height
:
200%
;
opacity
:
0
;
position
:
absolute
;
right
:
-50%
;
width
:
200%
}
.cropper-invisible
{
opacity
:
0
}
.cropper-bg
{
background-image
:
url("")
}
.cropper-hide
{
display
:
block
;
height
:
0
;
position
:
absolute
;
width
:
0
}
.cropper-hidden
{
display
:
none
!important
}
.cropper-move
{
cursor
:
move
}
.cropper-crop
{
cursor
:
crosshair
}
.cropper-disabled
.cropper-drag-box
,
.cropper-disabled
.cropper-face
,
.cropper-disabled
.cropper-line
,
.cropper-disabled
.cropper-point
{
cursor
:
not-allowed
}
\ No newline at end of file
src/main/webapp/assets/common/plugins/cropper/cropper.min.js
0 → 100644
View file @
389b0796
/*!
* Cropper.js v1.4.3
* https://fengyuanchen.github.io/cropperjs
*
* Copyright 2015-present Chen Fengyuan
* Released under the MIT license
*
* Date: 2018-10-24T13:07:15.032Z
*/
!
function
(
t
,
i
){
"object"
==
typeof
exports
&&
"undefined"
!=
typeof
module
?
module
.
exports
=
i
():
"function"
==
typeof
define
&&
define
.
amd
?
define
(
i
):
t
.
Cropper
=
i
()}(
this
,
function
(){
"use strict"
;
function
i
(
t
){
return
(
i
=
"function"
==
typeof
Symbol
&&
"symbol"
==
typeof
Symbol
.
iterator
?
function
(
t
){
return
typeof
t
}:
function
(
t
){
return
t
&&
"function"
==
typeof
Symbol
&&
t
.
constructor
===
Symbol
&&
t
!==
Symbol
.
prototype
?
"symbol"
:
typeof
t
})(
t
)}
function
n
(
t
,
i
){
for
(
var
e
=
0
;
e
<
i
.
length
;
e
++
){
var
a
=
i
[
e
];
a
.
enumerable
=
a
.
enumerable
||!
1
,
a
.
configurable
=!
0
,
"value"
in
a
&&
(
a
.
writable
=!
0
),
Object
.
defineProperty
(
t
,
a
.
key
,
a
)}}
function
bt
(
t
){
return
function
(
t
){
if
(
Array
.
isArray
(
t
)){
for
(
var
i
=
0
,
e
=
new
Array
(
t
.
length
);
i
<
t
.
length
;
i
++
)
e
[
i
]
=
t
[
i
];
return
e
}}(
t
)
||
function
(
t
){
if
(
Symbol
.
iterator
in
Object
(
t
)
||
"[object Arguments]"
===
Object
.
prototype
.
toString
.
call
(
t
))
return
Array
.
from
(
t
)}(
t
)
||
function
(){
throw
new
TypeError
(
"Invalid attempt to spread non-iterable instance"
)}()}
var
o
=
"undefined"
!=
typeof
window
,
h
=
o
?
window
:{},
d
=
"cropper"
,
k
=
"all"
,
T
=
"crop"
,
E
=
"move"
,
W
=
"zoom"
,
N
=
"e"
,
H
=
"w"
,
L
=
"s"
,
O
=
"n"
,
z
=
"ne"
,
Y
=
"nw"
,
X
=
"se"
,
R
=
"sw"
,
r
=
""
.
concat
(
d
,
"-crop"
),
t
=
""
.
concat
(
d
,
"-disabled"
),
S
=
""
.
concat
(
d
,
"-hidden"
),
l
=
""
.
concat
(
d
,
"-hide"
),
p
=
""
.
concat
(
d
,
"-invisible"
),
s
=
""
.
concat
(
d
,
"-modal"
),
m
=
""
.
concat
(
d
,
"-move"
),
g
=
""
.
concat
(
d
,
"Action"
),
u
=
""
.
concat
(
d
,
"Preview"
),
c
=
"crop"
,
f
=
"move"
,
v
=
"none"
,
a
=
"crop"
,
w
=
"cropend"
,
b
=
"cropmove"
,
x
=
"cropstart"
,
y
=
"dblclick"
,
M
=
h
.
PointerEvent
?
"pointerdown"
:
"touchstart mousedown"
,
C
=
h
.
PointerEvent
?
"pointermove"
:
"touchmove mousemove"
,
D
=
h
.
PointerEvent
?
"pointerup pointercancel"
:
"touchend touchcancel mouseup"
,
B
=
"ready"
,
A
=
"resize"
,
I
=
"wheel mousewheel DOMMouseScroll"
,
j
=
"zoom"
,
U
=
"image/jpeg"
,
P
=
/^
(?:
e|w|s|n|se|sw|ne|nw|all|crop|move|zoom
)
$/
,
q
=
/^data:/
,
$
=
/^data:image
\/
jpeg;base64,/
,
Q
=
/^
(?:
img|canvas
)
$/i
,
Z
=
{
viewMode
:
0
,
dragMode
:
c
,
initialAspectRatio
:
NaN
,
aspectRatio
:
NaN
,
data
:
null
,
preview
:
""
,
responsive
:
!
0
,
restore
:
!
0
,
checkCrossOrigin
:
!
0
,
checkOrientation
:
!
0
,
modal
:
!
0
,
guides
:
!
0
,
center
:
!
0
,
highlight
:
!
0
,
background
:
!
0
,
autoCrop
:
!
0
,
autoCropArea
:.
8
,
movable
:
!
0
,
rotatable
:
!
0
,
scalable
:
!
0
,
zoomable
:
!
0
,
zoomOnTouch
:
!
0
,
zoomOnWheel
:
!
0
,
wheelZoomRatio
:.
1
,
cropBoxMovable
:
!
0
,
cropBoxResizable
:
!
0
,
toggleDragModeOnDblclick
:
!
0
,
minCanvasWidth
:
0
,
minCanvasHeight
:
0
,
minCropBoxWidth
:
0
,
minCropBoxHeight
:
0
,
minContainerWidth
:
200
,
minContainerHeight
:
100
,
ready
:
null
,
cropstart
:
null
,
cropmove
:
null
,
cropend
:
null
,
crop
:
null
,
zoom
:
null
},
e
=
Number
.
isNaN
||
h
.
isNaN
;
function
F
(
t
){
return
"number"
==
typeof
t
&&!
e
(
t
)}
function
K
(
t
){
return
void
0
===
t
}
function
G
(
t
){
return
"object"
===
i
(
t
)
&&
null
!==
t
}
var
V
=
Object
.
prototype
.
hasOwnProperty
;
function
J
(
t
){
if
(
!
G
(
t
))
return
!
1
;
try
{
var
i
=
t
.
constructor
,
e
=
i
.
prototype
;
return
i
&&
e
&&
V
.
call
(
e
,
"isPrototypeOf"
)}
catch
(
t
){
return
!
1
}}
function
_
(
t
){
return
"function"
==
typeof
t
}
function
tt
(
i
,
e
){
if
(
i
&&
_
(
e
))
if
(
Array
.
isArray
(
i
)
||
F
(
i
.
length
)){
var
t
,
a
=
i
.
length
;
for
(
t
=
0
;
t
<
a
&&!
1
!==
e
.
call
(
i
,
i
[
t
],
t
,
i
);
t
+=
1
);}
else
G
(
i
)
&&
Object
.
keys
(
i
).
forEach
(
function
(
t
){
e
.
call
(
i
,
i
[
t
],
t
,
i
)});
return
i
}
var
it
=
Object
.
assign
||
function
(
e
){
for
(
var
t
=
arguments
.
length
,
i
=
new
Array
(
1
<
t
?
t
-
1
:
0
),
a
=
1
;
a
<
t
;
a
++
)
i
[
a
-
1
]
=
arguments
[
a
];
return
G
(
e
)
&&
0
<
i
.
length
&&
i
.
forEach
(
function
(
i
){
G
(
i
)
&&
Object
.
keys
(
i
).
forEach
(
function
(
t
){
e
[
t
]
=
i
[
t
]})}),
e
},
et
=
/
\.\d
*
(?:
0|9
){12}\d
*$/
;
function
xt
(
t
){
var
i
=
1
<
arguments
.
length
&&
void
0
!==
arguments
[
1
]?
arguments
[
1
]:
1
e11
;
return
et
.
test
(
t
)?
Math
.
round
(
t
*
i
)
/
i
:
t
}
var
at
=
/^
(?:
width|height|left|top|marginLeft|marginTop
)
$/
;
function
nt
(
t
,
i
){
var
e
=
t
.
style
;
tt
(
i
,
function
(
t
,
i
){
at
.
test
(
i
)
&&
F
(
t
)
&&
(
t
+=
"px"
),
e
[
i
]
=
t
})}
function
ot
(
t
,
i
){
if
(
i
)
if
(
F
(
t
.
length
))
tt
(
t
,
function
(
t
){
ot
(
t
,
i
)});
else
if
(
t
.
classList
)
t
.
classList
.
add
(
i
);
else
{
var
e
=
t
.
className
.
trim
();
e
?
e
.
indexOf
(
i
)
<
0
&&
(
t
.
className
=
""
.
concat
(
e
,
" "
).
concat
(
i
)):
t
.
className
=
i
}}
function
ht
(
t
,
i
){
i
&&
(
F
(
t
.
length
)?
tt
(
t
,
function
(
t
){
ht
(
t
,
i
)}):
t
.
classList
?
t
.
classList
.
remove
(
i
):
0
<=
t
.
className
.
indexOf
(
i
)
&&
(
t
.
className
=
t
.
className
.
replace
(
i
,
""
)))}
function
rt
(
t
,
i
,
e
){
i
&&
(
F
(
t
.
length
)?
tt
(
t
,
function
(
t
){
rt
(
t
,
i
,
e
)}):
e
?
ot
(
t
,
i
):
ht
(
t
,
i
))}
var
st
=
/
([
a-z
\d])([
A-Z
])
/g
;
function
ct
(
t
){
return
t
.
replace
(
st
,
"$1-$2"
).
toLowerCase
()}
function
dt
(
t
,
i
){
return
G
(
t
[
i
])?
t
[
i
]:
t
.
dataset
?
t
.
dataset
[
i
]:
t
.
getAttribute
(
"data-"
.
concat
(
ct
(
i
)))}
function
lt
(
t
,
i
,
e
){
G
(
e
)?
t
[
i
]
=
e
:
t
.
dataset
?
t
.
dataset
[
i
]
=
e
:
t
.
setAttribute
(
"data-"
.
concat
(
ct
(
i
)),
e
)}
var
pt
=
/
\s\s
*/
,
mt
=
function
(){
var
t
=!
1
;
if
(
o
){
var
i
=!
1
,
e
=
function
(){},
a
=
Object
.
defineProperty
({},
"once"
,{
get
:
function
(){
return
t
=!
0
,
i
},
set
:
function
(
t
){
i
=
t
}});
h
.
addEventListener
(
"test"
,
e
,
a
),
h
.
removeEventListener
(
"test"
,
e
,
a
)}
return
t
}();
function
gt
(
e
,
t
,
a
){
var
n
=
3
<
arguments
.
length
&&
void
0
!==
arguments
[
3
]?
arguments
[
3
]:{},
o
=
a
;
t
.
trim
().
split
(
pt
).
forEach
(
function
(
t
){
if
(
!
mt
){
var
i
=
e
.
listeners
;
i
&&
i
[
t
]
&&
i
[
t
][
a
]
&&
(
o
=
i
[
t
][
a
],
delete
i
[
t
][
a
],
0
===
Object
.
keys
(
i
[
t
]).
length
&&
delete
i
[
t
],
0
===
Object
.
keys
(
i
).
length
&&
delete
e
.
listeners
)}
e
.
removeEventListener
(
t
,
o
,
n
)})}
function
ut
(
o
,
t
,
h
){
var
r
=
3
<
arguments
.
length
&&
void
0
!==
arguments
[
3
]?
arguments
[
3
]:{},
s
=
h
;
t
.
trim
().
split
(
pt
).
forEach
(
function
(
a
){
if
(
r
.
once
&&!
mt
){
var
t
=
o
.
listeners
,
n
=
void
0
===
t
?{}:
t
;
s
=
function
(){
delete
n
[
a
][
h
],
o
.
removeEventListener
(
a
,
s
,
r
);
for
(
var
t
=
arguments
.
length
,
i
=
new
Array
(
t
),
e
=
0
;
e
<
t
;
e
++
)
i
[
e
]
=
arguments
[
e
];
h
.
apply
(
o
,
i
)},
n
[
a
]
||
(
n
[
a
]
=
{}),
n
[
a
][
h
]
&&
o
.
removeEventListener
(
a
,
n
[
a
][
h
],
r
),
n
[
a
][
h
]
=
s
,
o
.
listeners
=
n
}
o
.
addEventListener
(
a
,
s
,
r
)})}
function
ft
(
t
,
i
,
e
){
var
a
;
return
_
(
Event
)
&&
_
(
CustomEvent
)?
a
=
new
CustomEvent
(
i
,{
detail
:
e
,
bubbles
:
!
0
,
cancelable
:
!
0
}):(
a
=
document
.
createEvent
(
"CustomEvent"
)).
initCustomEvent
(
i
,
!
0
,
!
0
,
e
),
t
.
dispatchEvent
(
a
)}
function
vt
(
t
){
var
i
=
t
.
getBoundingClientRect
();
return
{
left
:
i
.
left
+
(
window
.
pageXOffset
-
document
.
documentElement
.
clientLeft
),
top
:
i
.
top
+
(
window
.
pageYOffset
-
document
.
documentElement
.
clientTop
)}}
var
wt
=
h
.
location
,
yt
=
/^
(
https
?
:
)\/\/([^
:
/
?#
]
+
)
:
?(\d
*
)
/i
;
function
Mt
(
t
){
var
i
=
t
.
match
(
yt
);
return
i
&&
(
i
[
1
]
!==
wt
.
protocol
||
i
[
2
]
!==
wt
.
hostname
||
i
[
3
]
!==
wt
.
port
)}
function
Ct
(
t
){
var
i
=
"timestamp="
.
concat
((
new
Date
).
getTime
());
return
t
+
(
-
1
===
t
.
indexOf
(
"?"
)?
"?"
:
"&"
)
+
i
}
function
Dt
(
t
){
var
i
=
t
.
rotate
,
e
=
t
.
scaleX
,
a
=
t
.
scaleY
,
n
=
t
.
translateX
,
o
=
t
.
translateY
,
h
=
[];
F
(
n
)
&&
0
!==
n
&&
h
.
push
(
"translateX("
.
concat
(
n
,
"px)"
)),
F
(
o
)
&&
0
!==
o
&&
h
.
push
(
"translateY("
.
concat
(
o
,
"px)"
)),
F
(
i
)
&&
0
!==
i
&&
h
.
push
(
"rotate("
.
concat
(
i
,
"deg)"
)),
F
(
e
)
&&
1
!==
e
&&
h
.
push
(
"scaleX("
.
concat
(
e
,
")"
)),
F
(
a
)
&&
1
!==
a
&&
h
.
push
(
"scaleY("
.
concat
(
a
,
")"
));
var
r
=
h
.
length
?
h
.
join
(
" "
):
"none"
;
return
{
WebkitTransform
:
r
,
msTransform
:
r
,
transform
:
r
}}
function
Bt
(
t
,
i
){
var
e
=
t
.
pageX
,
a
=
t
.
pageY
,
n
=
{
endX
:
e
,
endY
:
a
};
return
i
?
n
:
it
({
startX
:
e
,
startY
:
a
},
n
)}
var
kt
=
Number
.
isFinite
||
h
.
isFinite
;
function
Tt
(
t
){
var
i
=
t
.
aspectRatio
,
e
=
t
.
height
,
a
=
t
.
width
,
n
=
1
<
arguments
.
length
&&
void
0
!==
arguments
[
1
]?
arguments
[
1
]:
"contain"
,
o
=
function
(
t
){
return
kt
(
t
)
&&
0
<
t
};
if
(
o
(
a
)
&&
o
(
e
)){
var
h
=
e
*
i
;
"contain"
===
n
&&
a
<
h
||
"cover"
===
n
&&
h
<
a
?
e
=
a
/
i
:
a
=
e
*
i
}
else
o
(
a
)?
e
=
a
/
i
:
o
(
e
)
&&
(
a
=
e
*
i
);
return
{
width
:
a
,
height
:
e
}}
var
Et
=
String
.
fromCharCode
;
var
Wt
=
/^data:.*,/
;
function
Nt
(
t
){
var
i
,
e
=
new
DataView
(
t
);
try
{
var
a
,
n
,
o
;
if
(
255
===
e
.
getUint8
(
0
)
&&
216
===
e
.
getUint8
(
1
))
for
(
var
h
=
e
.
byteLength
,
r
=
2
;
r
+
1
<
h
;){
if
(
255
===
e
.
getUint8
(
r
)
&&
225
===
e
.
getUint8
(
r
+
1
)){
n
=
r
;
break
}
r
+=
1
}
if
(
n
){
var
s
=
n
+
10
;
if
(
"Exif"
===
function
(
t
,
i
,
e
){
var
a
,
n
=
""
;
for
(
e
+=
i
,
a
=
i
;
a
<
e
;
a
+=
1
)
n
+=
Et
(
t
.
getUint8
(
a
));
return
n
}(
e
,
n
+
4
,
4
)){
var
c
=
e
.
getUint16
(
s
);
if
(((
a
=
18761
===
c
)
||
19789
===
c
)
&&
42
===
e
.
getUint16
(
s
+
2
,
a
)){
var
d
=
e
.
getUint32
(
s
+
4
,
a
);
8
<=
d
&&
(
o
=
s
+
d
)}}}
if
(
o
){
var
l
,
p
,
m
=
e
.
getUint16
(
o
,
a
);
for
(
p
=
0
;
p
<
m
;
p
+=
1
)
if
(
l
=
o
+
12
*
p
+
2
,
274
===
e
.
getUint16
(
l
,
a
)){
l
+=
8
,
i
=
e
.
getUint16
(
l
,
a
),
e
.
setUint16
(
l
,
1
,
a
);
break
}}}
catch
(
t
){
i
=
1
}
return
i
}
var
Ht
=
{
render
:
function
(){
this
.
initContainer
(),
this
.
initCanvas
(),
this
.
initCropBox
(),
this
.
renderCanvas
(),
this
.
cropped
&&
this
.
renderCropBox
()},
initContainer
:
function
(){
var
t
=
this
.
element
,
i
=
this
.
options
,
e
=
this
.
container
,
a
=
this
.
cropper
;
ot
(
a
,
S
),
ht
(
t
,
S
);
var
n
=
{
width
:
Math
.
max
(
e
.
offsetWidth
,
Number
(
i
.
minContainerWidth
)
||
200
),
height
:
Math
.
max
(
e
.
offsetHeight
,
Number
(
i
.
minContainerHeight
)
||
100
)};
nt
(
a
,{
width
:(
this
.
containerData
=
n
).
width
,
height
:
n
.
height
}),
ot
(
t
,
S
),
ht
(
a
,
S
)},
initCanvas
:
function
(){
var
t
=
this
.
containerData
,
i
=
this
.
imageData
,
e
=
this
.
options
.
viewMode
,
a
=
Math
.
abs
(
i
.
rotate
)
%
180
==
90
,
n
=
a
?
i
.
naturalHeight
:
i
.
naturalWidth
,
o
=
a
?
i
.
naturalWidth
:
i
.
naturalHeight
,
h
=
n
/
o
,
r
=
t
.
width
,
s
=
t
.
height
;
t
.
height
*
h
>
t
.
width
?
3
===
e
?
r
=
t
.
height
*
h
:
s
=
t
.
width
/
h
:
3
===
e
?
s
=
t
.
width
/
h
:
r
=
t
.
height
*
h
;
var
c
=
{
aspectRatio
:
h
,
naturalWidth
:
n
,
naturalHeight
:
o
,
width
:
r
,
height
:
s
};
c
.
left
=
(
t
.
width
-
r
)
/
2
,
c
.
top
=
(
t
.
height
-
s
)
/
2
,
c
.
oldLeft
=
c
.
left
,
c
.
oldTop
=
c
.
top
,
this
.
canvasData
=
c
,
this
.
limited
=
1
===
e
||
2
===
e
,
this
.
limitCanvas
(
!
0
,
!
0
),
this
.
initialImageData
=
it
({},
i
),
this
.
initialCanvasData
=
it
({},
c
)},
limitCanvas
:
function
(
t
,
i
){
var
e
=
this
.
options
,
a
=
this
.
containerData
,
n
=
this
.
canvasData
,
o
=
this
.
cropBoxData
,
h
=
e
.
viewMode
,
r
=
n
.
aspectRatio
,
s
=
this
.
cropped
&&
o
;
if
(
t
){
var
c
=
Number
(
e
.
minCanvasWidth
)
||
0
,
d
=
Number
(
e
.
minCanvasHeight
)
||
0
;
1
<
h
?(
c
=
Math
.
max
(
c
,
a
.
width
),
d
=
Math
.
max
(
d
,
a
.
height
),
3
===
h
&&
(
c
<
d
*
r
?
c
=
d
*
r
:
d
=
c
/
r
)):
0
<
h
&&
(
c
?
c
=
Math
.
max
(
c
,
s
?
o
.
width
:
0
):
d
?
d
=
Math
.
max
(
d
,
s
?
o
.
height
:
0
):
s
&&
((
c
=
o
.
width
)
<
(
d
=
o
.
height
)
*
r
?
c
=
d
*
r
:
d
=
c
/
r
));
var
l
=
Tt
({
aspectRatio
:
r
,
width
:
c
,
height
:
d
});
c
=
l
.
width
,
d
=
l
.
height
,
n
.
minWidth
=
c
,
n
.
minHeight
=
d
,
n
.
maxWidth
=
1
/
0
,
n
.
maxHeight
=
1
/
0
}
if
(
i
)
if
((
s
?
0
:
1
)
<
h
){
var
p
=
a
.
width
-
n
.
width
,
m
=
a
.
height
-
n
.
height
;
n
.
minLeft
=
Math
.
min
(
0
,
p
),
n
.
minTop
=
Math
.
min
(
0
,
m
),
n
.
maxLeft
=
Math
.
max
(
0
,
p
),
n
.
maxTop
=
Math
.
max
(
0
,
m
),
s
&&
this
.
limited
&&
(
n
.
minLeft
=
Math
.
min
(
o
.
left
,
o
.
left
+
(
o
.
width
-
n
.
width
)),
n
.
minTop
=
Math
.
min
(
o
.
top
,
o
.
top
+
(
o
.
height
-
n
.
height
)),
n
.
maxLeft
=
o
.
left
,
n
.
maxTop
=
o
.
top
,
2
===
h
&&
(
n
.
width
>=
a
.
width
&&
(
n
.
minLeft
=
Math
.
min
(
0
,
p
),
n
.
maxLeft
=
Math
.
max
(
0
,
p
)),
n
.
height
>=
a
.
height
&&
(
n
.
minTop
=
Math
.
min
(
0
,
m
),
n
.
maxTop
=
Math
.
max
(
0
,
m
))))}
else
n
.
minLeft
=-
n
.
width
,
n
.
minTop
=-
n
.
height
,
n
.
maxLeft
=
a
.
width
,
n
.
maxTop
=
a
.
height
},
renderCanvas
:
function
(
t
,
i
){
var
e
=
this
.
canvasData
,
a
=
this
.
imageData
;
if
(
i
){
var
n
=
function
(
t
){
var
i
=
t
.
width
,
e
=
t
.
height
,
a
=
t
.
degree
;
if
(
90
==
(
a
=
Math
.
abs
(
a
)
%
180
))
return
{
width
:
e
,
height
:
i
};
var
n
=
a
%
90
*
Math
.
PI
/
180
,
o
=
Math
.
sin
(
n
),
h
=
Math
.
cos
(
n
),
r
=
i
*
h
+
e
*
o
,
s
=
i
*
o
+
e
*
h
;
return
90
<
a
?{
width
:
s
,
height
:
r
}:{
width
:
r
,
height
:
s
}}({
width
:
a
.
naturalWidth
*
Math
.
abs
(
a
.
scaleX
||
1
),
height
:
a
.
naturalHeight
*
Math
.
abs
(
a
.
scaleY
||
1
),
degree
:
a
.
rotate
||
0
}),
o
=
n
.
width
,
h
=
n
.
height
,
r
=
e
.
width
*
(
o
/
e
.
naturalWidth
),
s
=
e
.
height
*
(
h
/
e
.
naturalHeight
);
e
.
left
-=
(
r
-
e
.
width
)
/
2
,
e
.
top
-=
(
s
-
e
.
height
)
/
2
,
e
.
width
=
r
,
e
.
height
=
s
,
e
.
aspectRatio
=
o
/
h
,
e
.
naturalWidth
=
o
,
e
.
naturalHeight
=
h
,
this
.
limitCanvas
(
!
0
,
!
1
)}(
e
.
width
>
e
.
maxWidth
||
e
.
width
<
e
.
minWidth
)
&&
(
e
.
left
=
e
.
oldLeft
),(
e
.
height
>
e
.
maxHeight
||
e
.
height
<
e
.
minHeight
)
&&
(
e
.
top
=
e
.
oldTop
),
e
.
width
=
Math
.
min
(
Math
.
max
(
e
.
width
,
e
.
minWidth
),
e
.
maxWidth
),
e
.
height
=
Math
.
min
(
Math
.
max
(
e
.
height
,
e
.
minHeight
),
e
.
maxHeight
),
this
.
limitCanvas
(
!
1
,
!
0
),
e
.
left
=
Math
.
min
(
Math
.
max
(
e
.
left
,
e
.
minLeft
),
e
.
maxLeft
),
e
.
top
=
Math
.
min
(
Math
.
max
(
e
.
top
,
e
.
minTop
),
e
.
maxTop
),
e
.
oldLeft
=
e
.
left
,
e
.
oldTop
=
e
.
top
,
nt
(
this
.
canvas
,
it
({
width
:
e
.
width
,
height
:
e
.
height
},
Dt
({
translateX
:
e
.
left
,
translateY
:
e
.
top
}))),
this
.
renderImage
(
t
),
this
.
cropped
&&
this
.
limited
&&
this
.
limitCropBox
(
!
0
,
!
0
)},
renderImage
:
function
(
t
){
var
i
=
this
.
canvasData
,
e
=
this
.
imageData
,
a
=
e
.
naturalWidth
*
(
i
.
width
/
i
.
naturalWidth
),
n
=
e
.
naturalHeight
*
(
i
.
height
/
i
.
naturalHeight
);
it
(
e
,{
width
:
a
,
height
:
n
,
left
:(
i
.
width
-
a
)
/
2
,
top
:(
i
.
height
-
n
)
/
2
}),
nt
(
this
.
image
,
it
({
width
:
e
.
width
,
height
:
e
.
height
},
Dt
(
it
({
translateX
:
e
.
left
,
translateY
:
e
.
top
},
e
)))),
t
&&
this
.
output
()},
initCropBox
:
function
(){
var
t
=
this
.
options
,
i
=
this
.
canvasData
,
e
=
t
.
aspectRatio
||
t
.
initialAspectRatio
,
a
=
Number
(
t
.
autoCropArea
)
||
.
8
,
n
=
{
width
:
i
.
width
,
height
:
i
.
height
};
e
&&
(
i
.
height
*
e
>
i
.
width
?
n
.
height
=
n
.
width
/
e
:
n
.
width
=
n
.
height
*
e
),
this
.
cropBoxData
=
n
,
this
.
limitCropBox
(
!
0
,
!
0
),
n
.
width
=
Math
.
min
(
Math
.
max
(
n
.
width
,
n
.
minWidth
),
n
.
maxWidth
),
n
.
height
=
Math
.
min
(
Math
.
max
(
n
.
height
,
n
.
minHeight
),
n
.
maxHeight
),
n
.
width
=
Math
.
max
(
n
.
minWidth
,
n
.
width
*
a
),
n
.
height
=
Math
.
max
(
n
.
minHeight
,
n
.
height
*
a
),
n
.
left
=
i
.
left
+
(
i
.
width
-
n
.
width
)
/
2
,
n
.
top
=
i
.
top
+
(
i
.
height
-
n
.
height
)
/
2
,
n
.
oldLeft
=
n
.
left
,
n
.
oldTop
=
n
.
top
,
this
.
initialCropBoxData
=
it
({},
n
)},
limitCropBox
:
function
(
t
,
i
){
var
e
=
this
.
options
,
a
=
this
.
containerData
,
n
=
this
.
canvasData
,
o
=
this
.
cropBoxData
,
h
=
this
.
limited
,
r
=
e
.
aspectRatio
;
if
(
t
){
var
s
=
Number
(
e
.
minCropBoxWidth
)
||
0
,
c
=
Number
(
e
.
minCropBoxHeight
)
||
0
,
d
=
h
?
Math
.
min
(
a
.
width
,
n
.
width
,
n
.
width
+
n
.
left
,
a
.
width
-
n
.
left
):
a
.
width
,
l
=
h
?
Math
.
min
(
a
.
height
,
n
.
height
,
n
.
height
+
n
.
top
,
a
.
height
-
n
.
top
):
a
.
height
;
s
=
Math
.
min
(
s
,
a
.
width
),
c
=
Math
.
min
(
c
,
a
.
height
),
r
&&
(
s
&&
c
?
s
<
c
*
r
?
c
=
s
/
r
:
s
=
c
*
r
:
s
?
c
=
s
/
r
:
c
&&
(
s
=
c
*
r
),
d
<
l
*
r
?
l
=
d
/
r
:
d
=
l
*
r
),
o
.
minWidth
=
Math
.
min
(
s
,
d
),
o
.
minHeight
=
Math
.
min
(
c
,
l
),
o
.
maxWidth
=
d
,
o
.
maxHeight
=
l
}
i
&&
(
o
.
maxTop
=
h
?(
o
.
minLeft
=
Math
.
max
(
0
,
n
.
left
),
o
.
minTop
=
Math
.
max
(
0
,
n
.
top
),
o
.
maxLeft
=
Math
.
min
(
a
.
width
,
n
.
left
+
n
.
width
)
-
o
.
width
,
Math
.
min
(
a
.
height
,
n
.
top
+
n
.
height
)
-
o
.
height
):(
o
.
minLeft
=
0
,
o
.
minTop
=
0
,
o
.
maxLeft
=
a
.
width
-
o
.
width
,
a
.
height
-
o
.
height
))},
renderCropBox
:
function
(){
var
t
=
this
.
options
,
i
=
this
.
containerData
,
e
=
this
.
cropBoxData
;(
e
.
width
>
e
.
maxWidth
||
e
.
width
<
e
.
minWidth
)
&&
(
e
.
left
=
e
.
oldLeft
),(
e
.
height
>
e
.
maxHeight
||
e
.
height
<
e
.
minHeight
)
&&
(
e
.
top
=
e
.
oldTop
),
e
.
width
=
Math
.
min
(
Math
.
max
(
e
.
width
,
e
.
minWidth
),
e
.
maxWidth
),
e
.
height
=
Math
.
min
(
Math
.
max
(
e
.
height
,
e
.
minHeight
),
e
.
maxHeight
),
this
.
limitCropBox
(
!
1
,
!
0
),
e
.
left
=
Math
.
min
(
Math
.
max
(
e
.
left
,
e
.
minLeft
),
e
.
maxLeft
),
e
.
top
=
Math
.
min
(
Math
.
max
(
e
.
top
,
e
.
minTop
),
e
.
maxTop
),
e
.
oldLeft
=
e
.
left
,
e
.
oldTop
=
e
.
top
,
t
.
movable
&&
t
.
cropBoxMovable
&&
lt
(
this
.
face
,
g
,
e
.
width
>=
i
.
width
&&
e
.
height
>=
i
.
height
?
E
:
k
),
nt
(
this
.
cropBox
,
it
({
width
:
e
.
width
,
height
:
e
.
height
},
Dt
({
translateX
:
e
.
left
,
translateY
:
e
.
top
}))),
this
.
cropped
&&
this
.
limited
&&
this
.
limitCanvas
(
!
0
,
!
0
),
this
.
disabled
||
this
.
output
()},
output
:
function
(){
this
.
preview
(),
ft
(
this
.
element
,
a
,
this
.
getData
())}},
Lt
=
{
initPreview
:
function
(){
var
e
=
this
.
crossOrigin
,
t
=
this
.
options
.
preview
,
a
=
e
?
this
.
crossOriginUrl
:
this
.
url
,
i
=
document
.
createElement
(
"img"
);
if
(
e
&&
(
i
.
crossOrigin
=
e
),
i
.
src
=
a
,
this
.
viewBox
.
appendChild
(
i
),
this
.
viewBoxImage
=
i
,
t
){
var
n
=
t
;
"string"
==
typeof
t
?
n
=
this
.
element
.
ownerDocument
.
querySelectorAll
(
t
):
t
.
querySelector
&&
(
n
=
[
t
]),
tt
(
this
.
previews
=
n
,
function
(
t
){
var
i
=
document
.
createElement
(
"img"
);
lt
(
t
,
u
,{
width
:
t
.
offsetWidth
,
height
:
t
.
offsetHeight
,
html
:
t
.
innerHTML
}),
e
&&
(
i
.
crossOrigin
=
e
),
i
.
src
=
a
,
i
.
style
.
cssText
=
'display:block;width:100%;height:auto;min-width:0!important;min-height:0!important;max-width:none!important;max-height:none!important;image-orientation:0deg!important;"'
,
t
.
innerHTML
=
""
,
t
.
appendChild
(
i
)})}},
resetPreview
:
function
(){
tt
(
this
.
previews
,
function
(
t
){
var
i
=
dt
(
t
,
u
);
nt
(
t
,{
width
:
i
.
width
,
height
:
i
.
height
}),
t
.
innerHTML
=
i
.
html
,
function
(
i
,
e
){
if
(
G
(
i
[
e
]))
try
{
delete
i
[
e
]}
catch
(
t
){
i
[
e
]
=
void
0
}
else
if
(
i
.
dataset
)
try
{
delete
i
.
dataset
[
e
]}
catch
(
t
){
i
.
dataset
[
e
]
=
void
0
}
else
i
.
removeAttribute
(
"data-"
.
concat
(
ct
(
e
)))}(
t
,
u
)})},
preview
:
function
(){
var
r
=
this
.
imageData
,
t
=
this
.
canvasData
,
i
=
this
.
cropBoxData
,
s
=
i
.
width
,
c
=
i
.
height
,
d
=
r
.
width
,
l
=
r
.
height
,
p
=
i
.
left
-
t
.
left
-
r
.
left
,
m
=
i
.
top
-
t
.
top
-
r
.
top
;
this
.
cropped
&&!
this
.
disabled
&&
(
nt
(
this
.
viewBoxImage
,
it
({
width
:
d
,
height
:
l
},
Dt
(
it
({
translateX
:
-
p
,
translateY
:
-
m
},
r
)))),
tt
(
this
.
previews
,
function
(
t
){
var
i
=
dt
(
t
,
u
),
e
=
i
.
width
,
a
=
i
.
height
,
n
=
e
,
o
=
a
,
h
=
1
;
s
&&
(
o
=
c
*
(
h
=
e
/
s
)),
c
&&
a
<
o
&&
(
n
=
s
*
(
h
=
a
/
c
),
o
=
a
),
nt
(
t
,{
width
:
n
,
height
:
o
}),
nt
(
t
.
getElementsByTagName
(
"img"
)[
0
],
it
({
width
:
d
*
h
,
height
:
l
*
h
},
Dt
(
it
({
translateX
:
-
p
*
h
,
translateY
:
-
m
*
h
},
r
))))}))}},
Ot
=
{
bind
:
function
(){
var
t
=
this
.
element
,
i
=
this
.
options
,
e
=
this
.
cropper
;
_
(
i
.
cropstart
)
&&
ut
(
t
,
x
,
i
.
cropstart
),
_
(
i
.
cropmove
)
&&
ut
(
t
,
b
,
i
.
cropmove
),
_
(
i
.
cropend
)
&&
ut
(
t
,
w
,
i
.
cropend
),
_
(
i
.
crop
)
&&
ut
(
t
,
a
,
i
.
crop
),
_
(
i
.
zoom
)
&&
ut
(
t
,
j
,
i
.
zoom
),
ut
(
e
,
M
,
this
.
onCropStart
=
this
.
cropStart
.
bind
(
this
)),
i
.
zoomable
&&
i
.
zoomOnWheel
&&
ut
(
e
,
I
,
this
.
onWheel
=
this
.
wheel
.
bind
(
this
)),
i
.
toggleDragModeOnDblclick
&&
ut
(
e
,
y
,
this
.
onDblclick
=
this
.
dblclick
.
bind
(
this
)),
ut
(
t
.
ownerDocument
,
C
,
this
.
onCropMove
=
this
.
cropMove
.
bind
(
this
)),
ut
(
t
.
ownerDocument
,
D
,
this
.
onCropEnd
=
this
.
cropEnd
.
bind
(
this
)),
i
.
responsive
&&
ut
(
window
,
A
,
this
.
onResize
=
this
.
resize
.
bind
(
this
))},
unbind
:
function
(){
var
t
=
this
.
element
,
i
=
this
.
options
,
e
=
this
.
cropper
;
_
(
i
.
cropstart
)
&&
gt
(
t
,
x
,
i
.
cropstart
),
_
(
i
.
cropmove
)
&&
gt
(
t
,
b
,
i
.
cropmove
),
_
(
i
.
cropend
)
&&
gt
(
t
,
w
,
i
.
cropend
),
_
(
i
.
crop
)
&&
gt
(
t
,
a
,
i
.
crop
),
_
(
i
.
zoom
)
&&
gt
(
t
,
j
,
i
.
zoom
),
gt
(
e
,
M
,
this
.
onCropStart
),
i
.
zoomable
&&
i
.
zoomOnWheel
&&
gt
(
e
,
I
,
this
.
onWheel
),
i
.
toggleDragModeOnDblclick
&&
gt
(
e
,
y
,
this
.
onDblclick
),
gt
(
t
.
ownerDocument
,
C
,
this
.
onCropMove
),
gt
(
t
.
ownerDocument
,
D
,
this
.
onCropEnd
),
i
.
responsive
&&
gt
(
window
,
A
,
this
.
onResize
)}},
zt
=
{
resize
:
function
(){
var
t
=
this
.
options
,
i
=
this
.
container
,
e
=
this
.
containerData
,
a
=
Number
(
t
.
minContainerWidth
)
||
200
,
n
=
Number
(
t
.
minContainerHeight
)
||
100
;
if
(
!
(
this
.
disabled
||
e
.
width
<=
a
||
e
.
height
<=
n
)){
var
o
,
h
,
r
=
i
.
offsetWidth
/
e
.
width
;
if
(
1
!==
r
||
i
.
offsetHeight
!==
e
.
height
)
t
.
restore
&&
(
o
=
this
.
getCanvasData
(),
h
=
this
.
getCropBoxData
()),
this
.
render
(),
t
.
restore
&&
(
this
.
setCanvasData
(
tt
(
o
,
function
(
t
,
i
){
o
[
i
]
=
t
*
r
})),
this
.
setCropBoxData
(
tt
(
h
,
function
(
t
,
i
){
h
[
i
]
=
t
*
r
})))}},
dblclick
:
function
(){
var
t
,
i
;
this
.
disabled
||
this
.
options
.
dragMode
===
v
||
this
.
setDragMode
((
t
=
this
.
dragBox
,
i
=
r
,(
t
.
classList
?
t
.
classList
.
contains
(
i
):
-
1
<
t
.
className
.
indexOf
(
i
))?
f
:
c
))},
wheel
:
function
(
t
){
var
i
=
this
,
e
=
Number
(
this
.
options
.
wheelZoomRatio
)
||
.
1
,
a
=
1
;
this
.
disabled
||
(
t
.
preventDefault
(),
this
.
wheeling
||
(
this
.
wheeling
=!
0
,
setTimeout
(
function
(){
i
.
wheeling
=!
1
},
50
),
t
.
deltaY
?
a
=
0
<
t
.
deltaY
?
1
:
-
1
:
t
.
wheelDelta
?
a
=-
t
.
wheelDelta
/
120
:
t
.
detail
&&
(
a
=
0
<
t
.
detail
?
1
:
-
1
),
this
.
zoom
(
-
a
*
e
,
t
)))},
cropStart
:
function
(
t
){
if
(
!
this
.
disabled
){
var
i
,
e
=
this
.
options
,
a
=
this
.
pointers
;
t
.
changedTouches
?
tt
(
t
.
changedTouches
,
function
(
t
){
a
[
t
.
identifier
]
=
Bt
(
t
)}):
a
[
t
.
pointerId
||
0
]
=
Bt
(
t
),
i
=
1
<
Object
.
keys
(
a
).
length
&&
e
.
zoomable
&&
e
.
zoomOnTouch
?
W
:
dt
(
t
.
target
,
g
),
P
.
test
(
i
)
&&!
1
!==
ft
(
this
.
element
,
x
,{
originalEvent
:
t
,
action
:
i
})
&&
(
t
.
preventDefault
(),
this
.
action
=
i
,
this
.
cropping
=!
1
,
i
===
T
&&
(
this
.
cropping
=!
0
,
ot
(
this
.
dragBox
,
s
)))}},
cropMove
:
function
(
t
){
var
i
=
this
.
action
;
if
(
!
this
.
disabled
&&
i
){
var
e
=
this
.
pointers
;
t
.
preventDefault
(),
!
1
!==
ft
(
this
.
element
,
b
,{
originalEvent
:
t
,
action
:
i
})
&&
(
t
.
changedTouches
?
tt
(
t
.
changedTouches
,
function
(
t
){
it
(
e
[
t
.
identifier
]
||
{},
Bt
(
t
,
!
0
))}):
it
(
e
[
t
.
pointerId
||
0
]
||
{},
Bt
(
t
,
!
0
)),
this
.
change
(
t
))}},
cropEnd
:
function
(
t
){
if
(
!
this
.
disabled
){
var
i
=
this
.
action
,
e
=
this
.
pointers
;
t
.
changedTouches
?
tt
(
t
.
changedTouches
,
function
(
t
){
delete
e
[
t
.
identifier
]}):
delete
e
[
t
.
pointerId
||
0
],
i
&&
(
t
.
preventDefault
(),
Object
.
keys
(
e
).
length
||
(
this
.
action
=
""
),
this
.
cropping
&&
(
this
.
cropping
=!
1
,
rt
(
this
.
dragBox
,
s
,
this
.
cropped
&&
this
.
options
.
modal
)),
ft
(
this
.
element
,
w
,{
originalEvent
:
t
,
action
:
i
}))}}},
Yt
=
{
change
:
function
(
t
){
var
i
,
e
=
this
.
options
,
a
=
this
.
canvasData
,
n
=
this
.
containerData
,
o
=
this
.
cropBoxData
,
h
=
this
.
pointers
,
r
=
this
.
action
,
s
=
e
.
aspectRatio
,
c
=
o
.
left
,
d
=
o
.
top
,
l
=
o
.
width
,
p
=
o
.
height
,
m
=
c
+
l
,
g
=
d
+
p
,
u
=
0
,
f
=
0
,
v
=
n
.
width
,
w
=
n
.
height
,
b
=!
0
;
!
s
&&
t
.
shiftKey
&&
(
s
=
l
&&
p
?
l
/
p
:
1
),
this
.
limited
&&
(
u
=
o
.
minLeft
,
f
=
o
.
minTop
,
v
=
u
+
Math
.
min
(
n
.
width
,
a
.
width
,
a
.
left
+
a
.
width
),
w
=
f
+
Math
.
min
(
n
.
height
,
a
.
height
,
a
.
top
+
a
.
height
));
var
x
,
y
,
M
,
C
=
h
[
Object
.
keys
(
h
)[
0
]],
D
=
{
x
:
C
.
endX
-
C
.
startX
,
y
:
C
.
endY
-
C
.
startY
},
B
=
function
(
t
){
switch
(
t
){
case
N
:
m
+
D
.
x
>
v
&&
(
D
.
x
=
v
-
m
);
break
;
case
H
:
c
+
D
.
x
<
u
&&
(
D
.
x
=
u
-
c
);
break
;
case
O
:
d
+
D
.
y
<
f
&&
(
D
.
y
=
f
-
d
);
break
;
case
L
:
g
+
D
.
y
>
w
&&
(
D
.
y
=
w
-
g
)}};
switch
(
r
){
case
k
:
c
+=
D
.
x
,
d
+=
D
.
y
;
break
;
case
N
:
if
(
0
<=
D
.
x
&&
(
v
<=
m
||
s
&&
(
d
<=
f
||
w
<=
g
))){
b
=!
1
;
break
}
B
(
N
),(
l
+=
D
.
x
)
<
0
&&
(
r
=
H
,
c
-=
l
=-
l
),
s
&&
(
p
=
l
/
s
,
d
+=
(
o
.
height
-
p
)
/
2
);
break
;
case
O
:
if
(
D
.
y
<=
0
&&
(
d
<=
f
||
s
&&
(
c
<=
u
||
v
<=
m
))){
b
=!
1
;
break
}
B
(
O
),
p
-=
D
.
y
,
d
+=
D
.
y
,
p
<
0
&&
(
r
=
L
,
d
-=
p
=-
p
),
s
&&
(
l
=
p
*
s
,
c
+=
(
o
.
width
-
l
)
/
2
);
break
;
case
H
:
if
(
D
.
x
<=
0
&&
(
c
<=
u
||
s
&&
(
d
<=
f
||
w
<=
g
))){
b
=!
1
;
break
}
B
(
H
),
l
-=
D
.
x
,
c
+=
D
.
x
,
l
<
0
&&
(
r
=
N
,
c
-=
l
=-
l
),
s
&&
(
p
=
l
/
s
,
d
+=
(
o
.
height
-
p
)
/
2
);
break
;
case
L
:
if
(
0
<=
D
.
y
&&
(
w
<=
g
||
s
&&
(
c
<=
u
||
v
<=
m
))){
b
=!
1
;
break
}
B
(
L
),(
p
+=
D
.
y
)
<
0
&&
(
r
=
O
,
d
-=
p
=-
p
),
s
&&
(
l
=
p
*
s
,
c
+=
(
o
.
width
-
l
)
/
2
);
break
;
case
z
:
if
(
s
){
if
(
D
.
y
<=
0
&&
(
d
<=
f
||
v
<=
m
)){
b
=!
1
;
break
}
B
(
O
),
p
-=
D
.
y
,
d
+=
D
.
y
,
l
=
p
*
s
}
else
B
(
O
),
B
(
N
),
0
<=
D
.
x
?
m
<
v
?
l
+=
D
.
x
:
D
.
y
<=
0
&&
d
<=
f
&&
(
b
=!
1
):
l
+=
D
.
x
,
D
.
y
<=
0
?
f
<
d
&&
(
p
-=
D
.
y
,
d
+=
D
.
y
):(
p
-=
D
.
y
,
d
+=
D
.
y
);
l
<
0
&&
p
<
0
?(
r
=
R
,
d
-=
p
=-
p
,
c
-=
l
=-
l
):
l
<
0
?(
r
=
Y
,
c
-=
l
=-
l
):
p
<
0
&&
(
r
=
X
,
d
-=
p
=-
p
);
break
;
case
Y
:
if
(
s
){
if
(
D
.
y
<=
0
&&
(
d
<=
f
||
c
<=
u
)){
b
=!
1
;
break
}
B
(
O
),
p
-=
D
.
y
,
d
+=
D
.
y
,
l
=
p
*
s
,
c
+=
o
.
width
-
l
}
else
B
(
O
),
B
(
H
),
D
.
x
<=
0
?
u
<
c
?(
l
-=
D
.
x
,
c
+=
D
.
x
):
D
.
y
<=
0
&&
d
<=
f
&&
(
b
=!
1
):(
l
-=
D
.
x
,
c
+=
D
.
x
),
D
.
y
<=
0
?
f
<
d
&&
(
p
-=
D
.
y
,
d
+=
D
.
y
):(
p
-=
D
.
y
,
d
+=
D
.
y
);
l
<
0
&&
p
<
0
?(
r
=
X
,
d
-=
p
=-
p
,
c
-=
l
=-
l
):
l
<
0
?(
r
=
z
,
c
-=
l
=-
l
):
p
<
0
&&
(
r
=
R
,
d
-=
p
=-
p
);
break
;
case
R
:
if
(
s
){
if
(
D
.
x
<=
0
&&
(
c
<=
u
||
w
<=
g
)){
b
=!
1
;
break
}
B
(
H
),
l
-=
D
.
x
,
c
+=
D
.
x
,
p
=
l
/
s
}
else
B
(
L
),
B
(
H
),
D
.
x
<=
0
?
u
<
c
?(
l
-=
D
.
x
,
c
+=
D
.
x
):
0
<=
D
.
y
&&
w
<=
g
&&
(
b
=!
1
):(
l
-=
D
.
x
,
c
+=
D
.
x
),
0
<=
D
.
y
?
g
<
w
&&
(
p
+=
D
.
y
):
p
+=
D
.
y
;
l
<
0
&&
p
<
0
?(
r
=
z
,
d
-=
p
=-
p
,
c
-=
l
=-
l
):
l
<
0
?(
r
=
X
,
c
-=
l
=-
l
):
p
<
0
&&
(
r
=
Y
,
d
-=
p
=-
p
);
break
;
case
X
:
if
(
s
){
if
(
0
<=
D
.
x
&&
(
v
<=
m
||
w
<=
g
)){
b
=!
1
;
break
}
B
(
N
),
p
=
(
l
+=
D
.
x
)
/
s
}
else
B
(
L
),
B
(
N
),
0
<=
D
.
x
?
m
<
v
?
l
+=
D
.
x
:
0
<=
D
.
y
&&
w
<=
g
&&
(
b
=!
1
):
l
+=
D
.
x
,
0
<=
D
.
y
?
g
<
w
&&
(
p
+=
D
.
y
):
p
+=
D
.
y
;
l
<
0
&&
p
<
0
?(
r
=
Y
,
d
-=
p
=-
p
,
c
-=
l
=-
l
):
l
<
0
?(
r
=
R
,
c
-=
l
=-
l
):
p
<
0
&&
(
r
=
z
,
d
-=
p
=-
p
);
break
;
case
E
:
this
.
move
(
D
.
x
,
D
.
y
),
b
=!
1
;
break
;
case
W
:
this
.
zoom
((
y
=
it
({},
x
=
h
),
M
=
[],
tt
(
x
,
function
(
r
,
t
){
delete
y
[
t
],
tt
(
y
,
function
(
t
){
var
i
=
Math
.
abs
(
r
.
startX
-
t
.
startX
),
e
=
Math
.
abs
(
r
.
startY
-
t
.
startY
),
a
=
Math
.
abs
(
r
.
endX
-
t
.
endX
),
n
=
Math
.
abs
(
r
.
endY
-
t
.
endY
),
o
=
Math
.
sqrt
(
i
*
i
+
e
*
e
),
h
=
(
Math
.
sqrt
(
a
*
a
+
n
*
n
)
-
o
)
/
o
;
M
.
push
(
h
)})}),
M
.
sort
(
function
(
t
,
i
){
return
Math
.
abs
(
t
)
<
Math
.
abs
(
i
)}),
M
[
0
]),
t
),
b
=!
1
;
break
;
case
T
:
if
(
!
D
.
x
||!
D
.
y
){
b
=!
1
;
break
}
i
=
vt
(
this
.
cropper
),
c
=
C
.
startX
-
i
.
left
,
d
=
C
.
startY
-
i
.
top
,
l
=
o
.
minWidth
,
p
=
o
.
minHeight
,
0
<
D
.
x
?
r
=
0
<
D
.
y
?
X
:
z
:
D
.
x
<
0
&&
(
c
-=
l
,
r
=
0
<
D
.
y
?
R
:
Y
),
D
.
y
<
0
&&
(
d
-=
p
),
this
.
cropped
||
(
ht
(
this
.
cropBox
,
S
),
this
.
cropped
=!
0
,
this
.
limited
&&
this
.
limitCropBox
(
!
0
,
!
0
))}
b
&&
(
o
.
width
=
l
,
o
.
height
=
p
,
o
.
left
=
c
,
o
.
top
=
d
,
this
.
action
=
r
,
this
.
renderCropBox
()),
tt
(
h
,
function
(
t
){
t
.
startX
=
t
.
endX
,
t
.
startY
=
t
.
endY
})}},
Xt
=
{
crop
:
function
(){
return
!
this
.
ready
||
this
.
cropped
||
this
.
disabled
||
(
this
.
cropped
=!
0
,
this
.
limitCropBox
(
!
0
,
!
0
),
this
.
options
.
modal
&&
ot
(
this
.
dragBox
,
s
),
ht
(
this
.
cropBox
,
S
),
this
.
setCropBoxData
(
this
.
initialCropBoxData
)),
this
},
reset
:
function
(){
return
this
.
ready
&&!
this
.
disabled
&&
(
this
.
imageData
=
it
({},
this
.
initialImageData
),
this
.
canvasData
=
it
({},
this
.
initialCanvasData
),
this
.
cropBoxData
=
it
({},
this
.
initialCropBoxData
),
this
.
renderCanvas
(),
this
.
cropped
&&
this
.
renderCropBox
()),
this
},
clear
:
function
(){
return
this
.
cropped
&&!
this
.
disabled
&&
(
it
(
this
.
cropBoxData
,{
left
:
0
,
top
:
0
,
width
:
0
,
height
:
0
}),
this
.
cropped
=!
1
,
this
.
renderCropBox
(),
this
.
limitCanvas
(
!
0
,
!
0
),
this
.
renderCanvas
(),
ht
(
this
.
dragBox
,
s
),
ot
(
this
.
cropBox
,
S
)),
this
},
replace
:
function
(
i
){
var
t
=
1
<
arguments
.
length
&&
void
0
!==
arguments
[
1
]
&&
arguments
[
1
];
return
!
this
.
disabled
&&
i
&&
(
this
.
isImg
&&
(
this
.
element
.
src
=
i
),
t
?(
this
.
url
=
i
,
this
.
image
.
src
=
i
,
this
.
ready
&&
(
this
.
viewBoxImage
.
src
=
i
,
tt
(
this
.
previews
,
function
(
t
){
t
.
getElementsByTagName
(
"img"
)[
0
].
src
=
i
}))):(
this
.
isImg
&&
(
this
.
replaced
=!
0
),
this
.
options
.
data
=
null
,
this
.
uncreate
(),
this
.
load
(
i
))),
this
},
enable
:
function
(){
return
this
.
ready
&&
this
.
disabled
&&
(
this
.
disabled
=!
1
,
ht
(
this
.
cropper
,
t
)),
this
},
disable
:
function
(){
return
this
.
ready
&&!
this
.
disabled
&&
(
this
.
disabled
=!
0
,
ot
(
this
.
cropper
,
t
)),
this
},
destroy
:
function
(){
var
t
=
this
.
element
;
return
t
[
d
]
&&
(
t
[
d
]
=
void
0
,
this
.
isImg
&&
this
.
replaced
&&
(
t
.
src
=
this
.
originalUrl
),
this
.
uncreate
()),
this
},
move
:
function
(
t
){
var
i
=
1
<
arguments
.
length
&&
void
0
!==
arguments
[
1
]?
arguments
[
1
]:
t
,
e
=
this
.
canvasData
,
a
=
e
.
left
,
n
=
e
.
top
;
return
this
.
moveTo
(
K
(
t
)?
t
:
a
+
Number
(
t
),
K
(
i
)?
i
:
n
+
Number
(
i
))},
moveTo
:
function
(
t
){
var
i
=
1
<
arguments
.
length
&&
void
0
!==
arguments
[
1
]?
arguments
[
1
]:
t
,
e
=
this
.
canvasData
,
a
=!
1
;
return
t
=
Number
(
t
),
i
=
Number
(
i
),
this
.
ready
&&!
this
.
disabled
&&
this
.
options
.
movable
&&
(
F
(
t
)
&&
(
e
.
left
=
t
,
a
=!
0
),
F
(
i
)
&&
(
e
.
top
=
i
,
a
=!
0
),
a
&&
this
.
renderCanvas
(
!
0
)),
this
},
zoom
:
function
(
t
,
i
){
var
e
=
this
.
canvasData
;
return
t
=
(
t
=
Number
(
t
))
<
0
?
1
/
(
1
-
t
):
1
+
t
,
this
.
zoomTo
(
e
.
width
*
t
/
e
.
naturalWidth
,
null
,
i
)},
zoomTo
:
function
(
t
,
i
,
e
){
var
a
,
n
,
o
,
h
=
this
.
options
,
r
=
this
.
canvasData
,
s
=
r
.
width
,
c
=
r
.
height
,
d
=
r
.
naturalWidth
,
l
=
r
.
naturalHeight
;
if
(
0
<=
(
t
=
Number
(
t
))
&&
this
.
ready
&&!
this
.
disabled
&&
h
.
zoomable
){
var
p
=
d
*
t
,
m
=
l
*
t
;
if
(
!
1
===
ft
(
this
.
element
,
j
,{
ratio
:
t
,
oldRatio
:
s
/
d
,
originalEvent
:
e
}))
return
this
;
if
(
e
){
var
g
=
this
.
pointers
,
u
=
vt
(
this
.
cropper
),
f
=
g
&&
Object
.
keys
(
g
).
length
?(
o
=
n
=
a
=
0
,
tt
(
g
,
function
(
t
){
var
i
=
t
.
startX
,
e
=
t
.
startY
;
a
+=
i
,
n
+=
e
,
o
+=
1
}),{
pageX
:
a
/=
o
,
pageY
:
n
/=
o
}):{
pageX
:
e
.
pageX
,
pageY
:
e
.
pageY
};
r
.
left
-=
(
p
-
s
)
*
((
f
.
pageX
-
u
.
left
-
r
.
left
)
/
s
),
r
.
top
-=
(
m
-
c
)
*
((
f
.
pageY
-
u
.
top
-
r
.
top
)
/
c
)}
else
J
(
i
)
&&
F
(
i
.
x
)
&&
F
(
i
.
y
)?(
r
.
left
-=
(
p
-
s
)
*
((
i
.
x
-
r
.
left
)
/
s
),
r
.
top
-=
(
m
-
c
)
*
((
i
.
y
-
r
.
top
)
/
c
)):(
r
.
left
-=
(
p
-
s
)
/
2
,
r
.
top
-=
(
m
-
c
)
/
2
);
r
.
width
=
p
,
r
.
height
=
m
,
this
.
renderCanvas
(
!
0
)}
return
this
},
rotate
:
function
(
t
){
return
this
.
rotateTo
((
this
.
imageData
.
rotate
||
0
)
+
Number
(
t
))},
rotateTo
:
function
(
t
){
return
F
(
t
=
Number
(
t
))
&&
this
.
ready
&&!
this
.
disabled
&&
this
.
options
.
rotatable
&&
(
this
.
imageData
.
rotate
=
t
%
360
,
this
.
renderCanvas
(
!
0
,
!
0
)),
this
},
scaleX
:
function
(
t
){
var
i
=
this
.
imageData
.
scaleY
;
return
this
.
scale
(
t
,
F
(
i
)?
i
:
1
)},
scaleY
:
function
(
t
){
var
i
=
this
.
imageData
.
scaleX
;
return
this
.
scale
(
F
(
i
)?
i
:
1
,
t
)},
scale
:
function
(
t
){
var
i
=
1
<
arguments
.
length
&&
void
0
!==
arguments
[
1
]?
arguments
[
1
]:
t
,
e
=
this
.
imageData
,
a
=!
1
;
return
t
=
Number
(
t
),
i
=
Number
(
i
),
this
.
ready
&&!
this
.
disabled
&&
this
.
options
.
scalable
&&
(
F
(
t
)
&&
(
e
.
scaleX
=
t
,
a
=!
0
),
F
(
i
)
&&
(
e
.
scaleY
=
i
,
a
=!
0
),
a
&&
this
.
renderCanvas
(
!
0
,
!
0
)),
this
},
getData
:
function
(){
var
e
,
t
=
0
<
arguments
.
length
&&
void
0
!==
arguments
[
0
]
&&
arguments
[
0
],
i
=
this
.
options
,
a
=
this
.
imageData
,
n
=
this
.
canvasData
,
o
=
this
.
cropBoxData
;
if
(
this
.
ready
&&
this
.
cropped
){
e
=
{
x
:
o
.
left
-
n
.
left
,
y
:
o
.
top
-
n
.
top
,
width
:
o
.
width
,
height
:
o
.
height
};
var
h
=
a
.
width
/
a
.
naturalWidth
;
if
(
tt
(
e
,
function
(
t
,
i
){
e
[
i
]
=
t
/
h
}),
t
){
var
r
=
Math
.
round
(
e
.
y
+
e
.
height
),
s
=
Math
.
round
(
e
.
x
+
e
.
width
);
e
.
x
=
Math
.
round
(
e
.
x
),
e
.
y
=
Math
.
round
(
e
.
y
),
e
.
width
=
s
-
e
.
x
,
e
.
height
=
r
-
e
.
y
}}
else
e
=
{
x
:
0
,
y
:
0
,
width
:
0
,
height
:
0
};
return
i
.
rotatable
&&
(
e
.
rotate
=
a
.
rotate
||
0
),
i
.
scalable
&&
(
e
.
scaleX
=
a
.
scaleX
||
1
,
e
.
scaleY
=
a
.
scaleY
||
1
),
e
},
setData
:
function
(
t
){
var
i
=
this
.
options
,
e
=
this
.
imageData
,
a
=
this
.
canvasData
,
n
=
{};
if
(
this
.
ready
&&!
this
.
disabled
&&
J
(
t
)){
var
o
=!
1
;
i
.
rotatable
&&
F
(
t
.
rotate
)
&&
t
.
rotate
!==
e
.
rotate
&&
(
e
.
rotate
=
t
.
rotate
,
o
=!
0
),
i
.
scalable
&&
(
F
(
t
.
scaleX
)
&&
t
.
scaleX
!==
e
.
scaleX
&&
(
e
.
scaleX
=
t
.
scaleX
,
o
=!
0
),
F
(
t
.
scaleY
)
&&
t
.
scaleY
!==
e
.
scaleY
&&
(
e
.
scaleY
=
t
.
scaleY
,
o
=!
0
)),
o
&&
this
.
renderCanvas
(
!
0
,
!
0
);
var
h
=
e
.
width
/
e
.
naturalWidth
;
F
(
t
.
x
)
&&
(
n
.
left
=
t
.
x
*
h
+
a
.
left
),
F
(
t
.
y
)
&&
(
n
.
top
=
t
.
y
*
h
+
a
.
top
),
F
(
t
.
width
)
&&
(
n
.
width
=
t
.
width
*
h
),
F
(
t
.
height
)
&&
(
n
.
height
=
t
.
height
*
h
),
this
.
setCropBoxData
(
n
)}
return
this
},
getContainerData
:
function
(){
return
this
.
ready
?
it
({},
this
.
containerData
):{}},
getImageData
:
function
(){
return
this
.
sized
?
it
({},
this
.
imageData
):{}},
getCanvasData
:
function
(){
var
i
=
this
.
canvasData
,
e
=
{};
return
this
.
ready
&&
tt
([
"left"
,
"top"
,
"width"
,
"height"
,
"naturalWidth"
,
"naturalHeight"
],
function
(
t
){
e
[
t
]
=
i
[
t
]}),
e
},
setCanvasData
:
function
(
t
){
var
i
=
this
.
canvasData
,
e
=
i
.
aspectRatio
;
return
this
.
ready
&&!
this
.
disabled
&&
J
(
t
)
&&
(
F
(
t
.
left
)
&&
(
i
.
left
=
t
.
left
),
F
(
t
.
top
)
&&
(
i
.
top
=
t
.
top
),
F
(
t
.
width
)?(
i
.
width
=
t
.
width
,
i
.
height
=
t
.
width
/
e
):
F
(
t
.
height
)
&&
(
i
.
height
=
t
.
height
,
i
.
width
=
t
.
height
*
e
),
this
.
renderCanvas
(
!
0
)),
this
},
getCropBoxData
:
function
(){
var
t
,
i
=
this
.
cropBoxData
;
return
this
.
ready
&&
this
.
cropped
&&
(
t
=
{
left
:
i
.
left
,
top
:
i
.
top
,
width
:
i
.
width
,
height
:
i
.
height
}),
t
||
{}},
setCropBoxData
:
function
(
t
){
var
i
,
e
,
a
=
this
.
cropBoxData
,
n
=
this
.
options
.
aspectRatio
;
return
this
.
ready
&&
this
.
cropped
&&!
this
.
disabled
&&
J
(
t
)
&&
(
F
(
t
.
left
)
&&
(
a
.
left
=
t
.
left
),
F
(
t
.
top
)
&&
(
a
.
top
=
t
.
top
),
F
(
t
.
width
)
&&
t
.
width
!==
a
.
width
&&
(
i
=!
0
,
a
.
width
=
t
.
width
),
F
(
t
.
height
)
&&
t
.
height
!==
a
.
height
&&
(
e
=!
0
,
a
.
height
=
t
.
height
),
n
&&
(
i
?
a
.
height
=
a
.
width
/
n
:
e
&&
(
a
.
width
=
a
.
height
*
n
)),
this
.
renderCropBox
()),
this
},
getCroppedCanvas
:
function
(){
var
t
=
0
<
arguments
.
length
&&
void
0
!==
arguments
[
0
]?
arguments
[
0
]:{};
if
(
!
this
.
ready
||!
window
.
HTMLCanvasElement
)
return
null
;
var
i
,
e
,
a
,
n
,
o
,
h
,
r
,
s
,
c
,
d
,
l
,
p
,
m
,
g
,
u
,
f
,
v
,
w
,
b
,
x
,
y
,
M
,
C
,
D
,
B
,
k
,
T
,
E
,
W
,
N
,
H
,
L
,
O
,
z
,
Y
,
X
,
R
,
S
,
A
,
I
,
j
,
U
=
this
.
canvasData
,
P
=
(
i
=
this
.
image
,
e
=
this
.
imageData
,
a
=
U
,
n
=
t
,
o
=
e
.
aspectRatio
,
h
=
e
.
naturalWidth
,
r
=
e
.
naturalHeight
,
s
=
e
.
rotate
,
c
=
void
0
===
s
?
0
:
s
,
d
=
e
.
scaleX
,
l
=
void
0
===
d
?
1
:
d
,
p
=
e
.
scaleY
,
m
=
void
0
===
p
?
1
:
p
,
g
=
a
.
aspectRatio
,
u
=
a
.
naturalWidth
,
f
=
a
.
naturalHeight
,
v
=
n
.
fillColor
,
w
=
void
0
===
v
?
"transparent"
:
v
,
b
=
n
.
imageSmoothingEnabled
,
x
=
void
0
===
b
||
b
,
y
=
n
.
imageSmoothingQuality
,
M
=
void
0
===
y
?
"low"
:
y
,
C
=
n
.
maxWidth
,
D
=
void
0
===
C
?
1
/
0
:
C
,
B
=
n
.
maxHeight
,
k
=
void
0
===
B
?
1
/
0
:
B
,
T
=
n
.
minWidth
,
E
=
void
0
===
T
?
0
:
T
,
W
=
n
.
minHeight
,
N
=
void
0
===
W
?
0
:
W
,
H
=
document
.
createElement
(
"canvas"
),
L
=
H
.
getContext
(
"2d"
),
O
=
Tt
({
aspectRatio
:
g
,
width
:
D
,
height
:
k
}),
z
=
Tt
({
aspectRatio
:
g
,
width
:
E
,
height
:
N
},
"cover"
),
Y
=
Math
.
min
(
O
.
width
,
Math
.
max
(
z
.
width
,
u
)),
X
=
Math
.
min
(
O
.
height
,
Math
.
max
(
z
.
height
,
f
)),
R
=
Tt
({
aspectRatio
:
o
,
width
:
D
,
height
:
k
}),
S
=
Tt
({
aspectRatio
:
o
,
width
:
E
,
height
:
N
},
"cover"
),
A
=
Math
.
min
(
R
.
width
,
Math
.
max
(
S
.
width
,
h
)),
I
=
Math
.
min
(
R
.
height
,
Math
.
max
(
S
.
height
,
r
)),
j
=
[
-
A
/
2
,
-
I
/
2
,
A
,
I
],
H
.
width
=
xt
(
Y
),
H
.
height
=
xt
(
X
),
L
.
fillStyle
=
w
,
L
.
fillRect
(
0
,
0
,
Y
,
X
),
L
.
save
(),
L
.
translate
(
Y
/
2
,
X
/
2
),
L
.
rotate
(
c
*
Math
.
PI
/
180
),
L
.
scale
(
l
,
m
),
L
.
imageSmoothingEnabled
=
x
,
L
.
imageSmoothingQuality
=
M
,
L
.
drawImage
.
apply
(
L
,[
i
].
concat
(
bt
(
j
.
map
(
function
(
t
){
return
Math
.
floor
(
xt
(
t
))})))),
L
.
restore
(),
H
);
if
(
!
this
.
cropped
)
return
P
;
var
q
=
this
.
getData
(),
$
=
q
.
x
,
Q
=
q
.
y
,
Z
=
q
.
width
,
F
=
q
.
height
,
K
=
P
.
width
/
Math
.
floor
(
U
.
naturalWidth
);
1
!==
K
&&
(
$
*=
K
,
Q
*=
K
,
Z
*=
K
,
F
*=
K
);
var
G
=
Z
/
F
,
V
=
Tt
({
aspectRatio
:
G
,
width
:
t
.
maxWidth
||
1
/
0
,
height
:
t
.
maxHeight
||
1
/
0
}),
J
=
Tt
({
aspectRatio
:
G
,
width
:
t
.
minWidth
||
0
,
height
:
t
.
minHeight
||
0
},
"cover"
),
_
=
Tt
({
aspectRatio
:
G
,
width
:
t
.
width
||
(
1
!==
K
?
P
.
width
:
Z
),
height
:
t
.
height
||
(
1
!==
K
?
P
.
height
:
F
)}),
tt
=
_
.
width
,
it
=
_
.
height
;
tt
=
Math
.
min
(
V
.
width
,
Math
.
max
(
J
.
width
,
tt
)),
it
=
Math
.
min
(
V
.
height
,
Math
.
max
(
J
.
height
,
it
));
var
et
=
document
.
createElement
(
"canvas"
),
at
=
et
.
getContext
(
"2d"
);
et
.
width
=
xt
(
tt
),
et
.
height
=
xt
(
it
),
at
.
fillStyle
=
t
.
fillColor
||
"transparent"
,
at
.
fillRect
(
0
,
0
,
tt
,
it
);
var
nt
=
t
.
imageSmoothingEnabled
,
ot
=
void
0
===
nt
||
nt
,
ht
=
t
.
imageSmoothingQuality
;
at
.
imageSmoothingEnabled
=
ot
,
ht
&&
(
at
.
imageSmoothingQuality
=
ht
);
var
rt
,
st
,
ct
,
dt
,
lt
,
pt
,
mt
=
P
.
width
,
gt
=
P
.
height
,
ut
=
$
,
ft
=
Q
;
ut
<=-
Z
||
mt
<
ut
?
lt
=
ct
=
rt
=
ut
=
0
:
ut
<=
0
?(
ct
=-
ut
,
ut
=
0
,
lt
=
rt
=
Math
.
min
(
mt
,
Z
+
ut
)):
ut
<=
mt
&&
(
ct
=
0
,
lt
=
rt
=
Math
.
min
(
Z
,
mt
-
ut
)),
rt
<=
0
||
ft
<=-
F
||
gt
<
ft
?
pt
=
dt
=
st
=
ft
=
0
:
ft
<=
0
?(
dt
=-
ft
,
ft
=
0
,
pt
=
st
=
Math
.
min
(
gt
,
F
+
ft
)):
ft
<=
gt
&&
(
dt
=
0
,
pt
=
st
=
Math
.
min
(
F
,
gt
-
ft
));
var
vt
=
[
ut
,
ft
,
rt
,
st
];
if
(
0
<
lt
&&
0
<
pt
){
var
wt
=
tt
/
Z
;
vt
.
push
(
ct
*
wt
,
dt
*
wt
,
lt
*
wt
,
pt
*
wt
)}
return
at
.
drawImage
.
apply
(
at
,[
P
].
concat
(
bt
(
vt
.
map
(
function
(
t
){
return
Math
.
floor
(
xt
(
t
))})))),
et
},
setAspectRatio
:
function
(
t
){
var
i
=
this
.
options
;
return
this
.
disabled
||
K
(
t
)
||
(
i
.
aspectRatio
=
Math
.
max
(
0
,
t
)
||
NaN
,
this
.
ready
&&
(
this
.
initCropBox
(),
this
.
cropped
&&
this
.
renderCropBox
())),
this
},
setDragMode
:
function
(
t
){
var
i
=
this
.
options
,
e
=
this
.
dragBox
,
a
=
this
.
face
;
if
(
this
.
ready
&&!
this
.
disabled
){
var
n
=
t
===
c
,
o
=
i
.
movable
&&
t
===
f
;
t
=
n
||
o
?
t
:
v
,
i
.
dragMode
=
t
,
lt
(
e
,
g
,
t
),
rt
(
e
,
r
,
n
),
rt
(
e
,
m
,
o
),
i
.
cropBoxMovable
||
(
lt
(
a
,
g
,
t
),
rt
(
a
,
r
,
n
),
rt
(
a
,
m
,
o
))}
return
this
}},
Rt
=
h
.
Cropper
,
St
=
function
(){
function
e
(
t
){
var
i
=
1
<
arguments
.
length
&&
void
0
!==
arguments
[
1
]?
arguments
[
1
]:{};
if
(
function
(
t
,
i
){
if
(
!
(
t
instanceof
i
))
throw
new
TypeError
(
"Cannot call a class as a function"
)}(
this
,
e
),
!
t
||!
Q
.
test
(
t
.
tagName
))
throw
new
Error
(
"The first argument is required and must be an <img> or <canvas> element."
);
this
.
element
=
t
,
this
.
options
=
it
({},
Z
,
J
(
i
)
&&
i
),
this
.
cropped
=!
1
,
this
.
disabled
=!
1
,
this
.
pointers
=
{},
this
.
ready
=!
1
,
this
.
reloading
=!
1
,
this
.
replaced
=!
1
,
this
.
sized
=!
1
,
this
.
sizing
=!
1
,
this
.
init
()}
var
t
,
i
,
a
;
return
t
=
e
,
a
=
[{
key
:
"noConflict"
,
value
:
function
(){
return
window
.
Cropper
=
Rt
,
e
}},{
key
:
"setDefaults"
,
value
:
function
(
t
){
it
(
Z
,
J
(
t
)
&&
t
)}}],(
i
=
[{
key
:
"init"
,
value
:
function
(){
var
t
,
i
=
this
.
element
,
e
=
i
.
tagName
.
toLowerCase
();
if
(
!
i
[
d
]){
if
(
i
[
d
]
=
this
,
"img"
===
e
){
if
(
this
.
isImg
=!
0
,
t
=
i
.
getAttribute
(
"src"
)
||
""
,
!
(
this
.
originalUrl
=
t
))
return
;
t
=
i
.
src
}
else
"canvas"
===
e
&&
window
.
HTMLCanvasElement
&&
(
t
=
i
.
toDataURL
());
this
.
load
(
t
)}}},{
key
:
"load"
,
value
:
function
(
t
){
var
i
=
this
;
if
(
t
){
this
.
url
=
t
,
this
.
imageData
=
{};
var
e
=
this
.
element
,
a
=
this
.
options
;
if
(
a
.
rotatable
||
a
.
scalable
||
(
a
.
checkOrientation
=!
1
),
a
.
checkOrientation
&&
window
.
ArrayBuffer
)
if
(
q
.
test
(
t
))
$
.
test
(
t
)?
this
.
read
((
n
=
t
.
replace
(
Wt
,
""
),
o
=
atob
(
n
),
h
=
new
ArrayBuffer
(
o
.
length
),
tt
(
r
=
new
Uint8Array
(
h
),
function
(
t
,
i
){
r
[
i
]
=
o
.
charCodeAt
(
i
)}),
h
)):
this
.
clone
();
else
{
var
n
,
o
,
h
,
r
,
s
=
new
XMLHttpRequest
,
c
=
this
.
clone
.
bind
(
this
);
this
.
reloading
=!
0
,(
this
.
xhr
=
s
).
ontimeout
=
c
,
s
.
onabort
=
c
,
s
.
onerror
=
c
,
s
.
onprogress
=
function
(){
s
.
getResponseHeader
(
"content-type"
)
!==
U
&&
s
.
abort
()},
s
.
onload
=
function
(){
i
.
read
(
s
.
response
)},
s
.
onloadend
=
function
(){
i
.
reloading
=!
1
,
i
.
xhr
=
null
},
a
.
checkCrossOrigin
&&
Mt
(
t
)
&&
e
.
crossOrigin
&&
(
t
=
Ct
(
t
)),
s
.
open
(
"GET"
,
t
),
s
.
responseType
=
"arraybuffer"
,
s
.
withCredentials
=
"use-credentials"
===
e
.
crossOrigin
,
s
.
send
()}
else
this
.
clone
()}}},{
key
:
"read"
,
value
:
function
(
t
){
var
i
=
this
.
options
,
e
=
this
.
imageData
,
a
=
Nt
(
t
),
n
=
0
,
o
=
1
,
h
=
1
;
if
(
1
<
a
){
this
.
url
=
function
(
t
,
i
){
for
(
var
e
=
[],
a
=
new
Uint8Array
(
t
);
0
<
a
.
length
;)
e
.
push
(
Et
.
apply
(
void
0
,
bt
(
a
.
subarray
(
0
,
8192
)))),
a
=
a
.
subarray
(
8192
);
return
"data:"
.
concat
(
i
,
";base64,"
).
concat
(
btoa
(
e
.
join
(
""
)))}(
t
,
U
);
var
r
=
function
(
t
){
var
i
=
0
,
e
=
1
,
a
=
1
;
switch
(
t
){
case
2
:
e
=-
1
;
break
;
case
3
:
i
=-
180
;
break
;
case
4
:
a
=-
1
;
break
;
case
5
:
i
=
90
,
a
=-
1
;
break
;
case
6
:
i
=
90
;
break
;
case
7
:
i
=
90
,
e
=-
1
;
break
;
case
8
:
i
=-
90
}
return
{
rotate
:
i
,
scaleX
:
e
,
scaleY
:
a
}}(
a
);
n
=
r
.
rotate
,
o
=
r
.
scaleX
,
h
=
r
.
scaleY
}
i
.
rotatable
&&
(
e
.
rotate
=
n
),
i
.
scalable
&&
(
e
.
scaleX
=
o
,
e
.
scaleY
=
h
),
this
.
clone
()}},{
key
:
"clone"
,
value
:
function
(){
var
t
,
i
,
e
=
this
.
element
,
a
=
this
.
url
;
this
.
options
.
checkCrossOrigin
&&
Mt
(
a
)
&&
(
i
=
(
t
=
e
.
crossOrigin
)?
a
:(
t
=
"anonymous"
,
Ct
(
a
))),
this
.
crossOrigin
=
t
,
this
.
crossOriginUrl
=
i
;
var
n
=
document
.
createElement
(
"img"
);
t
&&
(
n
.
crossOrigin
=
t
),
n
.
src
=
i
||
a
,(
this
.
image
=
n
).
onload
=
this
.
start
.
bind
(
this
),
n
.
onerror
=
this
.
stop
.
bind
(
this
),
ot
(
n
,
l
),
e
.
parentNode
.
insertBefore
(
n
,
e
.
nextSibling
)}},{
key
:
"start"
,
value
:
function
(){
var
e
=
this
,
t
=
this
.
isImg
?
this
.
element
:
this
.
image
;
t
.
onload
=
null
,
t
.
onerror
=
null
,
this
.
sizing
=!
0
;
var
i
=
h
.
navigator
&&
/
(
Macintosh|iPhone|iPod|iPad
)
.*AppleWebKit/i
.
test
(
h
.
navigator
.
userAgent
),
a
=
function
(
t
,
i
){
it
(
e
.
imageData
,{
naturalWidth
:
t
,
naturalHeight
:
i
,
aspectRatio
:
t
/
i
}),
e
.
sizing
=!
1
,
e
.
sized
=!
0
,
e
.
build
()};
if
(
!
t
.
naturalWidth
||
i
){
var
n
=
document
.
createElement
(
"img"
),
o
=
document
.
body
||
document
.
documentElement
;(
this
.
sizingImage
=
n
).
onload
=
function
(){
a
(
n
.
width
,
n
.
height
),
i
||
o
.
removeChild
(
n
)},
n
.
src
=
t
.
src
,
i
||
(
n
.
style
.
cssText
=
"left:0;max-height:none!important;max-width:none!important;min-height:0!important;min-width:0!important;opacity:0;position:absolute;top:0;z-index:-1;"
,
o
.
appendChild
(
n
))}
else
a
(
t
.
naturalWidth
,
t
.
naturalHeight
)}},{
key
:
"stop"
,
value
:
function
(){
var
t
=
this
.
image
;
t
.
onload
=
null
,
t
.
onerror
=
null
,
t
.
parentNode
.
removeChild
(
t
),
this
.
image
=
null
}},{
key
:
"build"
,
value
:
function
(){
if
(
this
.
sized
&&!
this
.
ready
){
var
t
=
this
.
element
,
i
=
this
.
options
,
e
=
this
.
image
,
a
=
t
.
parentNode
,
n
=
document
.
createElement
(
"div"
);
n
.
innerHTML
=
'<div class="cropper-container" touch-action="none"><div class="cropper-wrap-box"><div class="cropper-canvas"></div></div><div class="cropper-drag-box"></div><div class="cropper-crop-box"><span class="cropper-view-box"></span><span class="cropper-dashed dashed-h"></span><span class="cropper-dashed dashed-v"></span><span class="cropper-center"></span><span class="cropper-face"></span><span class="cropper-line line-e" data-cropper-action="e"></span><span class="cropper-line line-n" data-cropper-action="n"></span><span class="cropper-line line-w" data-cropper-action="w"></span><span class="cropper-line line-s" data-cropper-action="s"></span><span class="cropper-point point-e" data-cropper-action="e"></span><span class="cropper-point point-n" data-cropper-action="n"></span><span class="cropper-point point-w" data-cropper-action="w"></span><span class="cropper-point point-s" data-cropper-action="s"></span><span class="cropper-point point-ne" data-cropper-action="ne"></span><span class="cropper-point point-nw" data-cropper-action="nw"></span><span class="cropper-point point-sw" data-cropper-action="sw"></span><span class="cropper-point point-se" data-cropper-action="se"></span></div></div>'
;
var
o
=
n
.
querySelector
(
"."
.
concat
(
d
,
"-container"
)),
h
=
o
.
querySelector
(
"."
.
concat
(
d
,
"-canvas"
)),
r
=
o
.
querySelector
(
"."
.
concat
(
d
,
"-drag-box"
)),
s
=
o
.
querySelector
(
"."
.
concat
(
d
,
"-crop-box"
)),
c
=
s
.
querySelector
(
"."
.
concat
(
d
,
"-face"
));
this
.
container
=
a
,
this
.
cropper
=
o
,
this
.
canvas
=
h
,
this
.
dragBox
=
r
,
this
.
cropBox
=
s
,
this
.
viewBox
=
o
.
querySelector
(
"."
.
concat
(
d
,
"-view-box"
)),
this
.
face
=
c
,
h
.
appendChild
(
e
),
ot
(
t
,
S
),
a
.
insertBefore
(
o
,
t
.
nextSibling
),
this
.
isImg
||
ht
(
e
,
l
),
this
.
initPreview
(),
this
.
bind
(),
i
.
initialAspectRatio
=
Math
.
max
(
0
,
i
.
initialAspectRatio
)
||
NaN
,
i
.
aspectRatio
=
Math
.
max
(
0
,
i
.
aspectRatio
)
||
NaN
,
i
.
viewMode
=
Math
.
max
(
0
,
Math
.
min
(
3
,
Math
.
round
(
i
.
viewMode
)))
||
0
,
ot
(
s
,
S
),
i
.
guides
||
ot
(
s
.
getElementsByClassName
(
""
.
concat
(
d
,
"-dashed"
)),
S
),
i
.
center
||
ot
(
s
.
getElementsByClassName
(
""
.
concat
(
d
,
"-center"
)),
S
),
i
.
background
&&
ot
(
o
,
""
.
concat
(
d
,
"-bg"
)),
i
.
highlight
||
ot
(
c
,
p
),
i
.
cropBoxMovable
&&
(
ot
(
c
,
m
),
lt
(
c
,
g
,
k
)),
i
.
cropBoxResizable
||
(
ot
(
s
.
getElementsByClassName
(
""
.
concat
(
d
,
"-line"
)),
S
),
ot
(
s
.
getElementsByClassName
(
""
.
concat
(
d
,
"-point"
)),
S
)),
this
.
render
(),
this
.
ready
=!
0
,
this
.
setDragMode
(
i
.
dragMode
),
i
.
autoCrop
&&
this
.
crop
(),
this
.
setData
(
i
.
data
),
_
(
i
.
ready
)
&&
ut
(
t
,
B
,
i
.
ready
,{
once
:
!
0
}),
ft
(
t
,
B
)}}},{
key
:
"unbuild"
,
value
:
function
(){
this
.
ready
&&
(
this
.
ready
=!
1
,
this
.
unbind
(),
this
.
resetPreview
(),
this
.
cropper
.
parentNode
.
removeChild
(
this
.
cropper
),
ht
(
this
.
element
,
S
))}},{
key
:
"uncreate"
,
value
:
function
(){
this
.
ready
?(
this
.
unbuild
(),
this
.
ready
=!
1
,
this
.
cropped
=!
1
):
this
.
sizing
?(
this
.
sizingImage
.
onload
=
null
,
this
.
sizing
=!
1
,
this
.
sized
=!
1
):
this
.
reloading
?(
this
.
xhr
.
onabort
=
null
,
this
.
xhr
.
abort
()):
this
.
image
&&
this
.
stop
()}}])
&&
n
(
t
.
prototype
,
i
),
a
&&
n
(
t
,
a
),
e
}();
return
it
(
St
.
prototype
,
Ht
,
Lt
,
Ot
,
zt
,
Yt
,
Xt
),
St
});
\ No newline at end of file
src/main/webapp/assets/modular/system/user/user_view.js
View file @
389b0796
/**
* 用户详情对话框(可用于添加和修改对话框)
*/
var
User
InfoDlg
=
{
var
User
ViewPage
=
{
data
:
{
id
:
""
,
account
:
""
,
...
...
@@ -21,16 +21,16 @@ var UserInfoDlg = {
/**
* 关闭此对话框
*/
User
InfoDlg
.
close
=
function
()
{
parent
.
layer
.
close
(
window
.
parent
.
MgrUser
.
layerIndex
);
User
ViewPage
.
close
=
function
()
{
};
/**
* 验证表单
*/
User
InfoDlg
.
validateForm
=
function
()
{
User
ViewPage
.
validateForm
=
function
()
{
var
data
=
User
InfoDlg
.
data
;
var
data
=
User
ViewPage
.
data
;
if
(
data
.
account
&&
data
.
password
&&
data
.
name
&&
data
.
deptid
)
{
return
true
;
...
...
@@ -50,86 +50,19 @@ UserInfoDlg.validateForm = function () {
}
};
/**
* 提交添加用户
*/
UserInfoDlg
.
addSubmit
=
function
()
{
var
ajax
=
new
$ax
(
Feng
.
ctxPath
+
"/mgr/add"
,
function
(
data
)
{
window
.
parent
.
Feng
.
success
(
"添加成功!"
);
window
.
parent
.
MgrUser
.
table
.
refresh
();
UserInfoDlg
.
close
();
},
function
(
data
)
{
window
.
parent
.
Feng
.
error
(
"添加失败!"
+
data
.
responseJSON
.
message
+
"!"
);
});
ajax
.
set
(
this
.
data
);
ajax
.
start
();
};
/**
* 提交修改
*/
UserInfoDlg
.
editSubmit
=
function
()
{
var
ajax
=
new
$ax
(
Feng
.
ctxPath
+
"/mgr/edit"
,
function
(
data
)
{
Feng
.
success
(
"修改成功!"
);
if
(
window
.
parent
.
MgrUser
!==
undefined
)
{
window
.
parent
.
MgrUser
.
table
.
refresh
();
UserInfoDlg
.
close
();
}
},
function
(
data
)
{
Feng
.
error
(
"修改失败!"
+
data
.
responseJSON
.
message
+
"!"
);
});
ajax
.
set
(
this
.
data
);
ajax
.
start
();
};
/**
* 修改密码
*/
UserInfoDlg
.
chPwd
=
function
()
{
var
ajax
=
new
$ax
(
Feng
.
ctxPath
+
"/mgr/changePwd"
,
function
(
data
)
{
Feng
.
success
(
"修改成功!"
);
},
function
(
data
)
{
Feng
.
error
(
"修改失败!"
+
data
.
responseJSON
.
message
+
"!"
);
});
ajax
.
set
(
"oldPwd"
);
ajax
.
set
(
"newPwd"
);
ajax
.
set
(
"rePwd"
);
ajax
.
start
();
};
$
(
function
()
{
UserInfoDlg
.
app
=
new
Vue
({
el
:
'#userForm'
,
data
:
UserInfoDlg
.
data
,
methods
:
{
submitForm
:
function
(
e
)
{
var
result
=
UserInfoDlg
.
validateForm
();
if
(
result
===
true
)
{
UserInfoDlg
.
addSubmit
();
}
else
{
Feng
.
alert
(
result
);
e
.
preventDefault
();
}
var
image
=
document
.
getElementById
(
'cropperImage'
);
var
cropper
=
new
Cropper
(
image
,
{
aspectRatio
:
16
/
9
,
crop
(
event
)
{
console
.
log
(
event
.
detail
.
x
);
console
.
log
(
event
.
detail
.
y
);
console
.
log
(
event
.
detail
.
width
);
console
.
log
(
event
.
detail
.
height
);
console
.
log
(
event
.
detail
.
rotate
);
console
.
log
(
event
.
detail
.
scaleX
);
console
.
log
(
event
.
detail
.
scaleY
);
},
showDeptSelectTree
:
function
()
{
var
formName
=
encodeURIComponent
(
"parent.UserInfoDlg.app.deptName"
);
var
formId
=
encodeURIComponent
(
"parent.UserInfoDlg.app.deptid"
);
var
treeUrl
=
encodeURIComponent
(
Feng
.
ctxPath
+
"/dept/tree"
);
layer
.
open
({
type
:
2
,
title
:
'部门选择'
,
area
:
[
'300px'
,
'400px'
],
content
:
Feng
.
ctxPath
+
'/system/commonTree?formName='
+
formName
+
"&formId="
+
formId
+
"&treeUrl="
+
treeUrl
});
}
}
});
laydate
.
render
({
elem
:
'#birthday'
});
});
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment