Page Menu
Home
In-Portal Phabricator
Search
Configure Global Search
Log In
Files
F1032160
forms.js
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Wed, Jun 18, 10:38 AM
Size
12 KB
Mime Type
text/plain
Expires
Fri, Jun 20, 10:38 AM (1 h, 23 m)
Engine
blob
Format
Raw Data
Handle
666767
Attached To
rINP In-Portal
forms.js
View Options
var
last_shown_error
=
false
;
var
errors
=
{};
var
first_error
=
{};
var
fields
=
{};
function
show_form_error
(
prefix
,
field
,
sticky
)
{
if
(
isset
(
errors
[
prefix
])
&&
isset
(
errors
[
prefix
][
field
])
)
{
span
=
document
.
getElementById
(
'error_msg_'
+
prefix
);
span
.
innerHTML
=
fields
[
prefix
][
field
]
+
' - '
+
errors
[
prefix
][
field
];
if
(
sticky
)
{
last_shown_error
=
field
;
}
}
}
function
hide_form_error
(
prefix
)
{
span
=
document
.
getElementById
(
'error_msg_'
+
prefix
);
if
(
!
span
)
{
return
;
}
span
.
innerHTML
=
'<br/>'
;
if
(
typeof
(
last_shown_error
)
!=
'undefined'
&&
last_shown_error
)
{
show_form_error
(
prefix
,
last_shown_error
);
}
}
function
add_form_error
(
prefix
,
field
,
element
,
error_msg
,
block_name
)
{
if
(
error_msg
==
''
)
{
// no error message - do nothing
return
;
}
if
(
typeof
(
errors
[
prefix
])
==
'undefined'
)
{
errors
[
prefix
]
=
{};
}
errors
[
prefix
][
field
]
=
error_msg
;
var
$input_fields
=
$
(
'#'
+
jq
(
element
));
switch
(
block_name
)
{
case
'inp_edit_timezone'
:
$input_fields
=
$input_fields
.
add
(
'#timezone_group'
);
break
;
case
'cf:datetime'
:
case
'inp_edit_date_time'
:
$input_fields
=
$input_fields
.
add
(
'#'
+
jq
(
element
.
replace
(
field
,
field
+
'_date'
)));
$input_fields
=
$input_fields
.
add
(
'#'
+
jq
(
element
.
replace
(
field
,
field
+
'_time'
)));
break
;
case
'inp_edit_combo_target'
:
$input_fields
=
$input_fields
.
add
(
'#'
+
jq
(
element
.
replace
(
field
,
field
+
'Type'
)));
break
;
case
'cf:multiselect'
:
case
'inp_edit_multioptions'
:
$input_fields
=
$
(
'#'
+
jq
(
element
)
+
'_select'
);
break
;
case
'cf:checkbox'
:
case
'inp_edit_checkbox'
:
$input_fields
=
$
(
'#_cb_'
+
jq
(
element
));
break
;
case
'cf:radio'
:
case
'inp_edit_radio'
:
case
'inp_edit_checkboxes'
:
$input_fields
=
$
(
"input[id^='"
+
jq
(
element
)
+
"_']"
);
break
;
case
'inp_edit_weight'
:
$input_fields
=
$input_fields
.
add
(
'#'
+
jq
(
element
.
replace
(
field
,
field
+
'_a'
)));
$input_fields
=
$input_fields
.
add
(
'#'
+
jq
(
element
.
replace
(
field
,
field
+
'_b'
)));
break
;
case
'inp_edit_picker'
:
$input_fields
=
$
(
'#'
+
jq
(
element
)
+
'_selected'
);
break
;
case
'inp_edit_cron_box'
:
$input_fields
=
$input_fields
.
add
(
'#'
+
jq
(
element
.
replace
(
field
,
field
+
'Hints'
)));
break
;
}
if
(
$input_fields
.
length
>
0
)
{
// some controls don't have element to focus on (e.g. swf uploader)
$input_fields
.
focus
(
function
(
$e
)
{
show_form_error
(
prefix
,
field
,
true
);
});
$input_fields
.
blur
(
function
(
$e
)
{
last_shown_error
=
false
;
});
}
/*else {
console.log('error: focusing failed for [', prefix, '.', field, '] = ', element);
}*/
if
(
typeof
(
first_error
[
prefix
])
==
'undefined'
||
first_error
[
prefix
]
==
false
)
{
first_error
[
prefix
]
=
[
field
,
$input_fields
.
length
>
0
?
$input_fields
.
first
().
attr
(
'id'
)
:
element
];
}
}
function
FCKeditor_OnComplete
(
editor
)
{
Form
.
Resize
();
}
function
InitEditors
()
{
if
(
!
$
.
isEmptyObject
(
$CKEditors
)
)
{
// process all CKEditor instances
CKEDITOR
.
on
(
'instanceReady'
,
function
(
ev
)
{
FCKeditor_OnComplete
(
CKEDITOR
.
instances
[
ev
.
editor
.
name
]
);
}
);
ckeditors_apply_typekit
();
for
(
var
$editor_id
in
$CKEditors
)
{
CKEDITOR
.
replace
(
$editor_id
,
$CKEditors
[
$editor_id
]);
}
}
// process all CodePress instances
if
(
$
.
isFunction
(
window
.
CodePress
))
{
CodePress
.
run
(
/*FCKeditor_OnComplete*/
);
}
}
function
Form
()
{}
Form
=
new
Form
();
Form
.
Controls
=
new
Array
();
Form
.
Div
=
false
;
Form
.
MinControlsHeight
=
0
;
Form
.
Options
=
new
Object
();
Form
.
FlexibleCount
=
0
;
Form
.
ScrollerW
=
17
;
Form
.
ScrollerH
=
17
;
Form
.
HasChanged
=
false
;
Form
.
reizeTimeoutId
=
false
;
Form
.
Init
=
function
(
id
)
{
this
.
Div
=
document
.
getElementById
(
id
);
if
(
!
this
.
Div
)
{
return
;
}
for
(
var
i
=
0
;
i
<
this
.
Controls
.
length
;
i
++
)
{
dim
=
getDimensions
(
document
.
getElementById
(
this
.
Controls
[
i
])
);
options
=
this
.
Options
[
this
.
Controls
[
i
]];
if
(
options
.
height
)
{
// fixed height
options
.
min_height
=
options
.
height
;
options
.
max_height
=
options
.
height
;
}
if
(
!
options
.
min_height
)
{
options
.
min_height
=
$
(
jq
(
'#'
+
this
.
Controls
[
i
])
).
outerHeight
();
// dim.innerHeight
}
// if ( $( jq('#' + this.Controls[i]) ).parents('tr:first').is(':visible') ) {
this
.
MinControlsHeight
+=
options
.
min_height
;
// }
if
(
dim
.
innerHeight
<
options
.
min_height
)
{
document
.
getElementById
(
this
.
Controls
[
i
]).
style
.
height
=
options
.
min_height
+
'px'
;
}
// alert('adding element '+this.Controls[i]+' height: '+options.min_height+' total: '+this.MinControlsHeight)
}
// all <script> tags will be executed again after wrap method is called, so remove them to prevent that
$
(
'script'
,
this
.
Div
).
remove
();
$
(
this
.
Div
).
wrap
(
'<div id="'
+
this
.
Div
.
id
+
'_container" style="position: relative; overflow: auto; width: 100%;"></div>'
);
Application
.
removeDebuggerStatistics
();
this
.
Table
=
$
(
'table:first'
,
this
.
Div
).
get
(
0
);
this
.
Table
.
style
.
height
=
'auto'
;
// this.Table.style.width = 'auto';
this
.
MinHeight
=
this
.
Table
.
offsetHeight
;
this
.
MinWidth
=
this
.
Table
.
offsetWidth
;
// alert('Measuring min width now')
// Call the "resize" event using debounce technique.
$
(
window
).
resize
(
function
()
{
clearTimeout
(
Form
.
reizeTimeoutId
);
Form
.
reizeTimeoutId
=
setTimeout
(
function
()
{
Form
.
Resize
();
},
100
);
});
this
.
Resize
(
false
);
this
.
displayFirstError
();
if
(
_Simultaneous_Edit_Message
!=
''
)
{
alert
(
_Simultaneous_Edit_Message
);
}
this
.
InitOnChange
();
Application
.
processHooks
(
'm:OnAfterFormInit'
);
InitEditors
();
};
Form
.
displayFirstError
=
function
()
{
if
(
isset
(
first_error
))
{
for
(
var
i
in
first_error
)
{
if
(
first_error
[
i
]
!=
false
)
{
if
(
document
.
getElementById
(
first_error
[
i
][
1
]))
{
// some controls don't have element to focus on (e.g. swf uploader)
document
.
getElementById
(
first_error
[
i
][
1
]).
focus
();
}
show_form_error
(
i
,
first_error
[
i
][
0
],
true
);
// alert('focused on '+first_error[i][1])
}
}
}
};
Form
.
InitOnChange
=
function
()
{
var
inputs
=
window
.
document
.
getElementsByTagName
(
'INPUT'
);
var
selects
=
window
.
document
.
getElementsByTagName
(
'SELECT'
);
var
textareas
=
window
.
document
.
getElementsByTagName
(
'TEXTAREA'
);
var
groups
=
[
inputs
,
selects
,
textareas
];
for
(
var
g
=
0
;
g
<
groups
.
length
;
g
++
)
{
for
(
var
i
=
0
;
i
<
groups
[
g
].
length
;
i
++
)
{
var
elem
=
groups
[
g
][
i
];
if
(
elem
.
tagName
==
'INPUT'
&&
elem
.
type
==
'hidden'
)
continue
;
addEvent
(
elem
,
elem
.
type
==
'button'
?
'click'
:
'change'
,
function
()
{
Form
.
Changed
()});
}
}
};
Form
.
Changed
=
function
()
{
this
.
HasChanged
=
true
;
};
Form
.
addControl
=
function
(
id
,
options
)
{
this
.
Controls
.
push
(
id
);
if
(
!
options
)
{
options
=
{
coeff
:
1
,
max_height
:
0
,
min_height
:
0
};
}
else
{
if
(
typeof
(
options
[
'coeff'
])
==
'undefined'
)
options
[
'coeff'
]
=
1
;
if
(
typeof
(
options
[
'max_height'
])
==
'undefined'
)
options
[
'max_height'
]
=
0
;
if
(
typeof
(
options
[
'min_height'
])
==
'undefined'
)
options
[
'min_height'
]
=
0
;
}
options
[
'real_height'
]
=
0
;
this
.
Options
[
id
]
=
options
;
// for future use
// print_pre(this.Options[id]);
};
Form
.
_parseSize
=
function
(
$size
)
{
if
(
$size
.
toString
().
match
(
/^([\d]+)px$/
))
{
return
parseInt
(
RegExp
.
$1
);
}
return
parseInt
(
$size
);
};
Form
.
Resize
=
function
(
$init_done
)
{
if
(
!
this
.
Div
)
{
return
;
}
if
(
(
$init_done
===
true
||
$init_done
===
undefined
)
&&
!
$
.
isEmptyObject
(
$CKEditors
)
)
{
// process all CKEditor instances
for
(
var
$editor_id
in
$CKEditors
)
{
var
$ckeditor_textarea
=
$
(
'#'
+
jq
(
$editor_id
)
);
CKEDITOR
.
instances
[
$editor_id
].
resize
(
$ckeditor_textarea
.
width
(),
$ckeditor_textarea
.
height
()
);
}
}
var
h
=
(
document
.
all
?
window
.
document
.
body
.
offsetHeight
:
window
.
innerHeight
);
var
$div
=
$
(
this
.
Div
);
var
pos
=
this
.
GetOffsetWithoutUserScroll
(
$div
);
h
-=
pos
.
top
;
if
(
this
.
Div
.
style
.
height
.
length
)
{
// height set for scroll_container overrides automatic container height detection
h
=
this
.
_parseSize
(
this
.
Div
.
style
.
height
);
}
if
(
$div
.
attr
(
'mode'
)
==
'minimal'
)
{
// height will become minimal required (when data height is smaller, then window)
h
=
this
.
MinHeight
;
}
h
-=
(
$div
.
outerHeight
()
-
$div
.
height
());
// alert('h after correction is '+h);
if
(
use_popups
()
&&
window
.
name
.
match
(
/[\d]+$/
)
)
{
window
.
document
.
body
.
style
.
width
=
'100%'
;
var
w
=
(
document
.
all
?
window
.
document
.
body
.
offsetWidth
:
window
.
innerWidth
);
w
-=
pos
.
left
+
(
$div
.
outerWidth
()
-
$div
.
width
());
}
else
{
var
w
=
$
(
window
.
document
.
body
).
outerWidth
(
false
);
w
-=
(
$div
.
outerWidth
()
-
$div
.
width
());
}
scroller_height
=
this
.
MinWidth
>
w
?
this
.
ScrollerH
:
0
;
// width of 1st table in scroll_container is larger, then window width?
scroller_width
=
this
.
MinHeight
>
h
-
scroller_height
?
this
.
ScrollerW
:
0
;
// table height > total height - scroller_height -> vertical scroller is found
scroller_height
=
this
.
MinWidth
>
w
-
scroller_width
?
this
.
ScrollerH
:
0
;
// table width > total width - scroller_width -> horizontal scroller is found
var
st
=
document
.
getElementById
(
'width_status'
);
if
(
st
)
st
.
innerHTML
=
'minWdith: '
+
this
.
MinWidth
+
' minHeight: '
+
this
.
MinHeight
+
' w: '
+
w
+
' h: '
+
h
+
' scroll_w: '
+
scroller_width
+
' scroll_h: '
+
scroller_height
;
// alert('scroller W x H = '+scroller_width+' x '+scroller_height);
// alert('resize: '+w+'x'+h)
this
.
Table
.
style
.
width
=
(
w
-
scroller_width
)
+
'px'
;
this
.
Div
.
parentNode
.
style
.
width
=
w
+
'px'
;
this
.
Div
.
style
.
width
=
(
w
-
scroller_width
)
+
'px'
;
this
.
Div
.
parentNode
.
style
.
height
=
h
+
'px'
;
var
count
=
this
.
Controls
.
length
;
// -count here is adjustment - 1px for each control
var
split
=
h
/*- (count * 2)*/
-
this
.
MinHeight
+
this
.
MinControlsHeight
;
if
(
split
<
this
.
MinControlsHeight
)
{
split
=
this
.
MinControlsHeight
;
}
this
.
ResetHeights
();
var
used
=
this
.
SetMinHeights
();
split
-=
used
;
var
cur_diff
=
0
;
var
iterations
=
0
;
do
{
var
prev_diff
=
cur_diff
;
var
cur_diff
=
this
.
SplitExtra
(
split
);
split
=
cur_diff
;
iterations
++
;
}
while
(
cur_diff
!=
0
&&
cur_diff
!=
prev_diff
&&
iterations
<
10
);
for
(
var
i
=
0
;
i
<
this
.
Controls
.
length
;
i
++
)
{
document
.
getElementById
(
this
.
Controls
[
i
]).
style
.
height
=
this
.
Options
[
this
.
Controls
[
i
]
][
'real_height'
]
+
'px'
;
// document.getElementById(this.Controls[i]).value = this.Options[this.Controls[i]]['real_height'];
}
// alert('h is: '+h+' min height is '+this.MinHeight+' MinControlsHeight is '+this.MinControlsHeight+' -> '+split+' to split between '+count);
// print_pre(this.Controls)
};
Form
.
GetOffsetWithoutUserScroll
=
function
(
$div
)
{
var
$ret
,
$wrapper_div
=
$div
.
parent
(),
$old_scroll_top
=
$wrapper_div
.
scrollTop
();
$wrapper_div
.
scrollTop
(
0
);
$ret
=
$div
.
offset
();
$wrapper_div
.
scrollTop
(
$old_scroll_top
);
return
$ret
;
};
Form
.
ResetHeights
=
function
()
{
for
(
var
i
=
0
;
i
<
this
.
Controls
.
length
;
i
++
)
{
var
options
=
this
.
Options
[
this
.
Controls
[
i
]]
options
[
'real_height'
]
=
0
;
options
.
fixed
=
false
;
}
this
.
FlexibleCount
=
this
.
Controls
.
length
;
};
// Enlarge heights when possible
// Return any not split pixels number
Form
.
SplitExtra
=
function
(
split
)
{
var
number
=
0
;
for
(
var
i
=
0
;
i
<
this
.
Controls
.
length
;
i
++
)
{
var
options
=
this
.
Options
[
this
.
Controls
[
i
]
];
if
(
options
[
'max_height'
]
==
0
||
options
[
'real_height'
]
<
options
.
max_height
)
{
number
++
;
}
}
if
(
number
==
0
)
{
return
0
;
}
var
delta
=
Math
.
floor
(
split
/
number
);
// alert('splitting '+split+' between '+number+' delta is '+delta)
var
added
=
0
;
for
(
var
i
=
0
;
i
<
this
.
Controls
.
length
;
i
++
)
{
var
options
=
this
.
Options
[
this
.
Controls
[
i
]];
var
to_add
;
if
(
options
[
'max_height'
]
!=
0
&&
options
[
'real_height'
]
+
delta
>
options
[
'max_height'
])
{
to_add
=
options
[
'max_height'
]
-
options
[
'real_height'
];
}
else
{
to_add
=
delta
;
}
// alert('delta: '+delta+' current real: '+options['real_height']+' min: '+options['min_height']+' max:'+options['max_height']+' to_add: '+to_add)
options
[
'real_height'
]
=
options
[
'real_height'
]
+
to_add
;
added
+=
to_add
;
}
// alert('added total '+added)
// removing extra added from the last (any) control
if
(
added
>
split
)
{
extra
=
added
-
split
;
options
[
'real_height'
]
-=
extra
;
added
-=
extra
;
}
return
split
-
added
;
};
Form
.
SetMinHeights
=
function
()
{
var
used
=
0
;
for
(
var
i
=
0
;
i
<
this
.
Controls
.
length
;
i
++
)
{
var
options
=
this
.
Options
[
this
.
Controls
[
i
]]
if
(
options
[
'real_height'
]
<
options
[
'min_height'
])
{
options
[
'real_height'
]
=
options
.
min_height
;
used
+=
options
.
min_height
;
}
}
return
used
;
};
Event Timeline
Log In to Comment