Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
synergy-various-libraries
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
community
synergy-various-libraries
Commits
35a2f510
Commit
35a2f510
authored
Oct 23, 2018
by
Sergey Antonovich
🇯🇵
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add new file
parent
b7e62f40
Pipeline
#63
canceled with stages
Changes
1
Pipelines
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
503 additions
and
0 deletions
+503
-0
Library/mobile_adaptability_form_teamplate.js
Library/mobile_adaptability_form_teamplate.js
+503
-0
No files found.
Library/mobile_adaptability_form_teamplate.js
0 → 100644
View file @
35a2f510
'
use strict
'
;
var
PLAYER_PARENT_HANDLER
=
'
#form_player_div
'
;
var
portal
=
{
player
:
null
,
clearPlayer
:
function
()
{
if
(
portal
.
player
)
{
portal
.
player
.
destroy
();
}
},
createPlayer
:
function
(){
portal
.
clearPlayer
();
portal
.
player
=
AS
.
FORMS
.
createPlayer
();
AS
.
FORMS
.
bus
.
on
(
'
formShow
'
,
function
(
event
,
fModel
,
fView
){
fModel
.
on
(
'
dataLoad
'
,
function
(
event
,
dModel
){
if
(
/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i
.
test
(
navigator
.
userAgent
)){
var
__checkInvalidErrors
=
function
(){
$
(
'
.asf-invalidInput
'
).
each
(
function
(
k
,
i
){
var
block
=
$
(
i
).
parent
();
if
(
$
(
i
).
hasClass
(
'
asf-invalidInput
'
)){
//block.find('.asf-label').css('color','rgb(255, 19, 0)');
block
.
find
(
'
.asf-label
'
).
addClass
(
'
mw-invalid-label-color-error
'
);
block
.
addClass
(
'
mw-invalid-color-error
'
);
//block.css('border-bottom-color','rgb(255, 19, 0)');
if
(
$
(
i
).
hasClass
(
'
asf-container
'
))
//$(i).css('border-bottom-color','rgb(255, 19, 0)');
$
(
i
).
addClass
(
'
mw-invalid-color-error
'
);
$
(
i
).
removeClass
(
'
asf-invalidInput
'
);
}
else
{
block
.
find
(
'
.asf-label
'
).
addClass
(
'
mw-invalid-label-color-success
'
);
//block.find('.asf-label').css('color','rgb(63, 162, 63)');
//block.css('border-bottom-color','rgb(187, 187, 187)');
block
.
addClass
(
'
mw-invalid-color-success
'
);
}
});
};
var
__select
=
function
(
combobox
){
var
items
=
combobox
.
listElements
.
slice
();
if
(
!
Array
.
isArray
(
items
))
items
=
[
items
];
items
.
forEach
(
function
(
item
,
key
){
items
[
key
]
=
'
<option value="
'
+
item
.
value
+
'
"
'
+
(
combobox
.
getValue
()
==
item
.
value
?
'
selected
'
:
''
)
+
'
>
'
+
item
.
label
+
'
</option>
'
});
var
box
=
$
(
'
<select class="mobile-window-system-select">
'
+
items
.
join
(
''
)
+
'
</select>
'
);
box
.
on
(
'
change
'
,
function
(){
combobox
.
setValue
(
""
+
box
.
val
());
});
var
container
=
$
(
fView
.
getViewWithId
(
combobox
.
asfProperty
.
id
).
container
);
container
.
append
(
box
);
container
.
find
(
'
.asf-dropdown-button
'
).
off
();
container
.
find
(
'
.asf-dropdown-input
'
).
off
();
};
var
__date
=
function
(
date
){
var
container
=
$
(
fView
.
getViewWithId
(
date
.
asfProperty
.
id
).
container
);
var
box
=
$
(
'
<input type="date" class="mobile-window-system-date">
'
);
var
curDate
=
new
Date
(
""
+
date
.
getValue
());
var
month
=
{
0
:
'
01
'
,
1
:
'
02
'
,
2
:
'
03
'
,
3
:
'
04
'
,
4
:
'
05
'
,
5
:
'
06
'
,
6
:
'
07
'
,
7
:
'
08
'
,
8
:
'
09
'
,
9
:
'
10
'
,
10
:
'
11
'
,
11
:
'
12
'
}[
curDate
.
getMonth
()];
box
.
on
(
'
change
'
,
function
(){
AS
.
FORMS
.
ApiUtils
.
formatDate
(
$
(
this
).
val
()
+
'
00:00:00
'
,
date
.
asfProperty
.
config
.
dateFormat
).
then
(
function
(
resFormatDate
){
date
.
setValue
(
""
+
resFormatDate
);
if
(
resFormatDate
){
container
.
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
'
0
'
,
'
font-size
'
:
'
10px
'
,
'
color
'
:
'
rgb(63, 162, 63)
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
rgb(63, 162, 63)
'
},
200
);
container
.
find
(
'
.asf-dateBox
'
).
animate
({
'
opacity
'
:
'
1
'
},
200
);
}
else
{
container
.
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
container
.
find
(
'
.mobile-window-systemAlign
'
).
position
().
top
,
'
font-size
'
:
'
12px
'
,
'
color
'
:
'
rgb(187, 187, 187)
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
rgb(187, 187, 187)
'
},
200
);
container
.
find
(
'
.asf-dateBox
'
).
animate
({
'
opacity
'
:
'
0
'
},
200
);
}
});
});
box
.
val
(
curDate
.
getFullYear
()
+
'
.
'
+
month
+
curDate
.
getDate
());
container
.
append
(
box
);
container
.
find
(
'
.asf-calendar-button
'
).
off
();
container
.
find
(
'
.asf-dateBox
'
).
off
();
};
$
(
'
.mobile-window-system-date
'
).
remove
();
$
(
'
.mobile-window-system-select
'
).
remove
();
$
(
'
.asf-emptyCell
'
).
parent
().
hide
();
fModel
.
value
.
data
.
forEach
(
function
(
item
){
var
container
=
$
(
fView
.
getViewWithId
(
item
.
id
).
container
);
var
parent
=
container
.
parent
();
$
(
'
<div class="mobile-window-systemAlign"></div>
'
).
appendTo
(
container
);
container
.
parent
().
attr
(
'
colspan
'
,
'
1
'
);
var
placeholder
=
(
fView
.
getViewWithId
(
item
.
id
+
'
-label
'
)
?
""
+
dModel
.
getModelWithId
(
item
.
id
+
'
-label
'
).
getValue
()
:
false
);
/**
* Является ли компонент скрытым - для скрытия его в мобильной версии
*/
var
visible
=
!
container
.
is
(
'
:visible
'
);
/**
* Переопределение отображения компонентов по их типу
*/
switch
(
item
.
type
.
toLowerCase
()){
/**
* LABEL
*/
case
'
label
'
:
container
.
css
({
'
border
'
:
'
0
'
,
'
border-radius
'
:
'
0
'
,
'
border-bottom
'
:
'
1px solid rgb(187, 187, 187)
'
,
'
display
'
:
'
flex
'
,
'
align-items
'
:
'
center
'
});
if
(
!
/title$/
.
test
(
item
.
id
)){
parent
.
hide
();
}
else
{
container
.
find
(
'
.asf-label
'
).
css
({
'
position
'
:
'
relative
'
,
'
color
'
:
'
#000
'
,
'
padding-bottom
'
:
'
5px
'
});
}
break
;
/**
* TEXTBOX & NUMERICINPUT
*/
case
'
textbox
'
:
case
'
numericinput
'
:
var
box
=
$
(
'
<div class="mobile-window-system-box"></div>
'
);
box
.
css
(
'
opacity
'
,
'
1
'
);
box
.
on
(
'
click
'
,
function
(){
container
.
find
(
'
input
'
).
focus
();
$
(
this
).
hide
();
container
.
find
(
'
input
'
).
animate
({
'
opacity
'
:
'
1
'
},
200
);
});
container
.
append
(
box
);
container
.
css
({
'
border
'
:
'
0
'
,
'
border-radius
'
:
'
0
'
,
'
border-bottom
'
:
'
1px solid rgb(187, 187, 187)
'
,
'
display
'
:
'
flex
'
,
'
align-items
'
:
'
center
'
});
container
.
css
(
'
min-height
'
,
'
35px
'
);
container
.
find
(
'
.asf-label
'
).
text
(
placeholder
?
placeholder
:
''
);
container
.
find
(
'
.asf-label
'
).
click
(
function
(){
container
.
find
(
'
input
'
).
focus
();
});
container
.
find
(
'
input
'
).
css
({
'
padding-left
'
:
'
6px
'
,
'
padding-top
'
:
'
5px
'
,
'
opacity
'
:
'
0
'
});
container
.
find
(
'
input
'
).
attr
(
'
placeholder
'
,
''
);
container
.
find
(
'
input
'
).
focus
(
function
(){
if
(
$
(
this
).
val
()
&&
dModel
.
getModelWithId
(
item
.
id
).
inputUtils
.
defaultValue
!=
$
(
this
).
val
())
return
;
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
'
0
'
,
'
font-size
'
:
'
10px
'
,
'
color
'
:
'
rgb(63, 162, 63)
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
rgb(63, 162, 63)
'
},
200
);
container
.
find
(
'
.mobile-window-system-box
'
).
hide
();
container
.
find
(
'
input
'
).
animate
({
'
opacity
'
:
'
1
'
},
200
);
});
container
.
find
(
'
input
'
).
blur
(
function
(){
if
(
!
$
(
this
).
val
()
||
dModel
.
getModelWithId
(
item
.
id
).
inputUtils
.
defaultValue
==
$
(
this
).
val
()){
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
container
.
find
(
'
.mobile-window-systemAlign
'
).
position
().
top
,
'
font-size
'
:
'
12px
'
,
'
color
'
:
'
#a0a0a0
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
#a0a0a0
'
},
200
);
container
.
find
(
'
.mobile-window-system-box
'
).
show
();
container
.
find
(
'
input
'
).
animate
({
'
opacity
'
:
'
0
'
},
200
);
}
});
container
.
find
(
'
input
'
).
on
(
'
input
'
,
function
(){
if
(
$
(
this
).
hasClass
(
'
asf-invalidInput
'
)){
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
css
(
'
color
'
,
'
rgb(255, 19, 0)
'
);
$
(
this
).
parent
().
css
(
'
border-bottom-color
'
,
'
rgb(255, 19, 0)
'
);
}
else
{
if
(
$
(
this
).
val
()){
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
css
(
'
color
'
,
'
rgb(63, 162, 63)
'
);
$
(
this
).
parent
().
css
(
'
border-bottom-color
'
,
'
rgb(63, 162, 63)
'
);
}
else
{
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
css
(
'
color
'
,
'
rgb(187, 187, 187)
'
);
$
(
this
).
parent
().
css
(
'
border-bottom-color
'
,
'
rgb(187, 187, 187)
'
);
}
}
});
break
;
/**
* TEXTAREA
*/
case
'
textarea
'
:
container
.
css
({
'
border
'
:
'
0
'
,
'
border-radius
'
:
'
0
'
,
'
border-bottom
'
:
'
1px solid rgb(187, 187, 187)
'
,
'
display
'
:
'
flex
'
,
'
align-items
'
:
'
center
'
});
container
.
css
({
'
min-height
'
:
'
65px
'
});
container
.
find
(
'
.asf-label
'
).
text
(
placeholder
?
placeholder
:
''
);
container
.
find
(
'
.asf-label
'
).
click
(
function
(){
container
.
find
(
'
textarea
'
).
focus
();
});
container
.
find
(
'
textarea
'
).
css
({
'
padding-left
'
:
'
6px
'
,
'
padding-top
'
:
'
10px
'
,
'
resize
'
:
'
none
'
});
container
.
find
(
'
textarea
'
).
attr
(
'
placeholder
'
,
''
);
container
.
find
(
'
textarea
'
).
focus
(
function
(){
if
(
$
(
this
).
val
())
return
;
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
'
0
'
,
'
font-size
'
:
'
10px
'
,
'
color
'
:
'
rgb(63, 162, 63)
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
rgb(63, 162, 63)
'
},
200
);
});
container
.
find
(
'
textarea
'
).
blur
(
function
(){
if
(
!
$
(
this
).
val
()){
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
container
.
find
(
'
.mobile-window-systemAlign
'
).
position
().
top
,
'
font-size
'
:
'
12px
'
,
'
color
'
:
'
#a0a0a0
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
#a0a0a0
'
},
200
);
}
});
container
.
find
(
'
textarea
'
).
on
(
'
textarea
'
,
function
(){
if
(
$
(
this
).
hasClass
(
'
asf-invalidInput
'
)){
$
(
this
).
parent
().
css
(
'
border-bottom-color
'
,
'
rgb(255, 19, 0)
'
);
}
else
{
$
(
this
).
parent
().
css
(
'
border-bottom-color
'
,
'
rgb(187, 187, 187)
'
);
}
});
break
;
/**
* LISTBOX
*/
case
'
listbox
'
:
__select
(
dModel
.
getModelWithId
(
item
.
id
));
container
.
find
(
'
.asf-label
'
).
text
(
placeholder
?
placeholder
:
''
);
container
.
find
(
'
.asf-label
'
).
click
(
function
(){
container
.
find
(
'
textarea
'
).
focus
();
});
container
.
css
({
'
border
'
:
'
0
'
,
'
border-radius
'
:
'
0
'
,
'
border-bottom
'
:
'
1px solid rgb(187, 187, 187)
'
,
'
padding
'
:
'
5px 0 5px 5px
'
,
'
width
'
:
'
calc(100% - 5px)
'
});
container
.
css
({
'
display
'
:
'
block
'
});
container
.
find
(
'
.asf-dropdown-input
'
).
css
({
'
border
'
:
'
0
'
,
'
padding-top
'
:
'
4px
'
});
container
.
find
(
'
.asf-dropdown-button
'
).
css
({
'
background
'
:
'
url() no-repeat center
'
,
'
border
'
:
'
0
'
});
container
.
find
(
'
input
'
).
on
(
'
input
'
,
function
(){
if
(
$
(
this
).
hasClass
(
'
asf-invalidInput
'
)){
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
css
(
'
color
'
,
'
rgb(255, 19, 0)
'
);
$
(
this
).
parent
().
css
(
'
border-bottom-color
'
,
'
rgb(255, 19, 0)
'
);
}
else
{
$
(
this
).
parent
().
find
(
'
.asf-label
'
).
css
(
'
color
'
,
'
rgb(63, 162, 63)
'
);
$
(
this
).
parent
().
css
(
'
border-bottom-color
'
,
'
rgb(187, 187, 187)
'
);
}
});
if
(
$
(
container
).
find
(
'
.asf-dropdown-input
'
).
text
()){
container
.
find
(
'
.asf-label
'
).
css
(
'
color
'
,
'
rgb(63, 162, 63)
'
);
container
.
css
(
'
border-bottom-color
'
,
'
rgb(63, 162, 63)
'
);
}
else
{
container
.
find
(
'
.asf-label
'
).
css
(
'
color
'
,
'
#a0a0a0
'
);
container
.
css
(
'
border-bottom-color
'
,
'
#a0a0a0
'
);
}
dModel
.
getModelWithId
(
item
.
id
).
on
(
'
valueChange
'
,
function
(){
var
curModel
=
dModel
.
getModelWithId
(
item
.
id
);
if
(
!
curModel
.
getTextValue
()){
container
.
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
(
parseInt
(
container
.
find
(
'
.mobile-window-systemAlign
'
).
position
().
top
)
-
20
)
+
'
px
'
,
'
font-size
'
:
'
12px
'
,
'
color
'
:
'
#a0a0a0
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
#a0a0a0
'
},
200
);
}
else
{
container
.
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
'
0
'
,
'
font-size
'
:
'
10px
'
,
'
color
'
:
'
rgb(63, 162, 63)
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
rgb(63, 162, 63)
'
},
200
);
}
});
if
(
!
dModel
.
getModelWithId
(
item
.
id
).
getTextValue
()){
container
.
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
(
parseInt
(
container
.
find
(
'
.mobile-window-systemAlign
'
).
position
().
top
)
-
20
)
+
'
px
'
,
'
font-size
'
:
'
12px
'
,
'
color
'
:
'
#a0a0a0
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
#a0a0a0
'
},
200
);
}
else
{
container
.
find
(
'
.asf-label
'
).
animate
({
'
top
'
:
'
0
'
,
'
font-size
'
:
'
10px
'
,
'
color
'
:
'
rgb(63, 162, 63)
'
},
200
);
container
.
animate
({
'
border-bottom-color
'
:
'
rgb(63, 162, 63)
'
},
200
);
}
break
;
/**
* CHECKBOX & RADIOBOX
*/
case
'
check
'
:
case
'
radio
'
:
dModel
.
getModelWithId
(
item
.
id
).
on
(
'
dataLoad
'
,
function
(){
var
customLabel
=
$
(
'
<div class="asf-label" id="mw-label-listbox">
'
+
(
placeholder
?
placeholder
:
''
)
+
'
</div>
'
);
customLabel
.
css
({
'
top
'
:
'
0
'
,
'
font-size
'
:
'
10px
'
});
$
(
container
).
prepend
(
customLabel
);
dModel
.
getModelWithId
(
item
.
id
).
on
(
'
valueChange
'
,
function
(){
if
(
dModel
.
getModelWithId
(
item
.
id
).
getValue
()){
container
.
find
(
'
.asf-label
'
).
css
({
'
color
'
:
'
rgb(63, 162, 63)
'
});
container
.
css
({
'
border-bottom
'
:
'
1px solid rgb(63, 162, 63)
'
,
});
}
else
{
container
.
find
(
'
.asf-label
'
).
css
({
'
color
'
:
'
rgb(187, 187, 187)
'
});
container
.
css
({
'
border-bottom
'
:
'
1px solid rgb(187, 187, 187)
'
,
});
}
});
if
(
dModel
.
getModelWithId
(
item
.
id
).
getValue
()){
container
.
find
(
'
.asf-label
'
).
css
({
'
color
'
:
'
rgb(63, 162, 63)
'
});
container
.
css
({
'
border-bottom
'
:
'
1px solid rgb(63, 162, 63)
'
,
});
}
else
{
container
.
find
(
'
.asf-label
'
).
css
({
'
color
'
:
'
rgb(187, 187, 187)
'
});
container
.
css
({
'
border-bottom
'
:
'
1px solid rgb(187, 187, 187)
'
,
});
}
});
break
;
/**
* DATE
*/
case
'
date
'
:
__date
(
dModel
.
getModelWithId
(
item
.
id
));
container
.
find
(
'
.asf-label
'
).
text
(
placeholder
?
placeholder
:
''
);
container
.
css
({
'
width
'
:
'
100%
'
,
'
border-bottom
'
:
'
1px solid rgb(187, 187, 187)
'
,
'
display
'
:
'
flex
'
,
'
align-items
'
:
'
center
'
});
container
.
find
(
'
.asf-calendar-button
'
).
css
({
'
background
'
:
'
url() no-repeat center
'
,
'
border
'
:
'
0
'
});
container
.
find
(
'
.asf-dateBox
'
).
css
({
'
width
'
:
'
100%
'
,
'
max-width
'
:
'
unset
'
,
'
border
'
:
'
0
'
,
'
border-radius
'
:
'
0
'
,
'
opacity
'
:
'
0
'
});
if
(
dModel
.
getModelWithId
(
item
.
id
).
getValue
()){
container
.
find
(
'
.asf-label
'
).
css
({
'
top
'
:
'
0
'
,
'
font-size
'
:
'
10px
'
,
'
color
'
:
'
rgb(63, 162, 63)
'
});
container
.
css
(
'
border-bottom-color
'
,
'
rgb(63, 162, 63)
'
);
container
.
find
(
'
.asf-dateBox
'
).
css
(
'
opacity
'
,
'
1
'
);
}
else
{
container
.
find
(
'
.asf-label
'
).
css
({
'
top
'
:
container
.
find
(
'
.mobile-window-systemAlign
'
).
position
().
top
,
'
font-size
'
:
'
12px
'
,
'
color
'
:
'
rgb(187, 187, 187)
'
});
container
.
css
(
'
border-bottom-color
'
,
'
rgb(187, 187, 187)
'
);
}
break
;
}
if
(
visible
)
container
.
hide
();
});
}
$
(
fView
.
container
).
append
(
'
<div style="display: flex;justify-content: center;align-items: center;"><div class="send" style=" padding: 15px 20px;background: #557fd2;color: #fff;font-weight: bold;font-size: 14px;min-width: 150px;min-height: 15px; text-align: center; cursor: pointer;">Send Form</div></div>
'
)
$
(
fView
.
container
).
find
(
'
.send
'
).
on
(
'
click
'
,
function
(){
if
(
portal
.
player
.
model
.
getErrors
().
length
>
0
){
__checkInvalidErrors
();
}
else
{
// You`r code
}
});
});
});
portal
.
player
.
view
.
setEditable
(
true
);
portal
.
player
.
showFormByCode
(
'
mobile-modal-window-form
'
);
portal
.
player
.
view
.
appendTo
(
$
(
PLAYER_PARENT_HANDLER
));
}
};
$
(
function
(){
AS
.
OPTIONS
.
locale
=
"
ru
"
;
AS
.
OPTIONS
.
coreUrl
=
FORM_PLAYER_URL_PREFIX
;
AS
.
OPTIONS
.
login
=
"
login|$session|$key
"
;
AS
.
OPTIONS
.
password
=
"
password|key|token
"
;
portal
.
createPlayer
();
});
\ No newline at end of file
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