2016-08-09 06:42:21 +00:00
//jumpserver 自定义js 2015-01-29
//此函数用于checkbox的全选和反选
var checked = false ;
function check _all ( form ) {
var checkboxes = document . getElementById ( form ) ;
2016-09-13 13:45:10 +00:00
if ( checked === false ) {
checked = true ;
2016-08-09 06:42:21 +00:00
} else {
2016-09-13 13:45:10 +00:00
checked = false ;
2016-08-09 06:42:21 +00:00
}
for ( var i = 0 ; i < checkboxes . elements . length ; i ++ ) {
if ( checkboxes . elements [ i ] . type == "checkbox" ) {
checkboxes . elements [ i ] . checked = checked ;
}
}
}
function checkAll ( id , name ) {
var checklist = document . getElementsByName ( name ) ;
if ( document . getElementById ( id ) . checked )
{
for ( var i = 0 ; i < checklist . length ; i ++ )
{
checklist [ i ] . checked = 1 ;
}
} else {
for ( var j = 0 ; j < checklist . length ; j ++ )
{
checklist [ j ] . checked = 0 ;
}
}
}
//提取指定行的数据, JSON格式
function GetRowData ( row ) {
var rowData = { } ;
for ( var j = 0 ; j < row . cells . length ; j ++ ) {
name = row . parentNode . rows [ 0 ] . cells [ j ] . getAttribute ( "Name" ) ;
if ( name ) {
var value = row . cells [ j ] . getAttribute ( "Value" ) ;
if ( ! value ) {
value = row . cells [ j ] . innerHTML ;
}
rowData [ name ] = value ;
}
}
return rowData ;
}
//此函数用于在多选提交时至少要选择一行
function GetTableDataBox ( ) {
var tabProduct = document . getElementById ( "editable" ) ;
2016-09-13 13:45:10 +00:00
var tableData = [ ] ;
var returnData = [ ] ;
2016-08-09 06:42:21 +00:00
var checkboxes = document . getElementById ( "contents_form" ) ;
2016-09-13 13:45:10 +00:00
var id _list = [ ] ;
2016-08-09 06:42:21 +00:00
len = checkboxes . elements . length ;
for ( var i = 0 ; i < len ; i ++ ) {
2016-09-13 13:45:10 +00:00
if ( checkboxes . elements [ i ] . type == "checkbox" && checkboxes . elements [ i ] . checked === true && checkboxes . elements [ i ] . value != "checkall" ) {
2016-08-09 06:42:21 +00:00
id _list . push ( i ) ;
}
}
for ( i in id _list ) {
tableData . push ( GetRowData ( tabProduct . rows [ id _list [ i ] ] ) ) ;
}
2016-09-13 13:45:10 +00:00
if ( id _list . length === 0 ) {
2016-08-09 06:42:21 +00:00
alert ( '请至少选择一行!' ) ;
}
returnData . push ( tableData ) ;
returnData . push ( id _list . length ) ;
return returnData ;
}
function move ( from , to , from _o , to _o ) {
$ ( "#" + from + " option" ) . each ( function ( ) {
2016-09-13 13:45:10 +00:00
if ( $ ( this ) . prop ( "selected" ) === true ) {
2016-08-09 06:42:21 +00:00
$ ( "#" + to ) . append ( this ) ;
if ( typeof from _o !== 'undefined' ) {
$ ( "#" + to _o ) . append ( $ ( "#" + from _o + " option[value='" + this . value + "']" ) ) ;
}
}
} ) ;
}
function move _left ( from , to , from _o , to _o ) {
$ ( "#" + from + " option" ) . each ( function ( ) {
2016-09-13 13:45:10 +00:00
if ( $ ( this ) . prop ( "selected" ) === true ) {
2016-08-09 06:42:21 +00:00
$ ( "#" + to ) . append ( this ) ;
if ( typeof from _o !== 'undefined' ) {
$ ( "#" + to _o ) . append ( $ ( "#" + from _o + " option[value='" + this . value + "']" ) ) ;
}
}
$ ( this ) . attr ( "selected" , 'true' ) ;
} ) ;
}
function selectAll ( ) {
2016-09-15 04:20:53 +00:00
// Select all check box
2016-08-09 06:42:21 +00:00
$ ( 'option' ) . each ( function ( ) {
2016-09-13 13:45:10 +00:00
$ ( this ) . attr ( 'selected' , true ) ;
} ) ;
2016-08-09 06:42:21 +00:00
}
2016-09-15 04:20:53 +00:00
function getCookie ( name ) {
var cookieValue = null ;
if ( document . cookie && document . cookie !== '' ) {
var cookies = document . cookie . split ( ';' ) ;
for ( var i = 0 ; i < cookies . length ; i ++ ) {
var cookie = jQuery . trim ( cookies [ i ] ) ;
// Does this cookie string begin with the name we want?
if ( cookie . substring ( 0 , name . length + 1 ) === ( name + '=' ) ) {
cookieValue = decodeURIComponent ( cookie . substring ( name . length + 1 ) ) ;
2017-04-05 11:09:51 +00:00
// break;
2016-09-15 04:20:53 +00:00
}
}
}
return cookieValue ;
}
2016-08-09 06:42:21 +00:00
2016-09-15 04:20:53 +00:00
function csrfSafeMethod ( method ) {
// these HTTP methods do not require CSRF protection
return ( /^(GET|HEAD|OPTIONS|TRACE)$/ . test ( method ) ) ;
}
2016-08-09 06:42:21 +00:00
2016-09-15 04:20:53 +00:00
function setAjaxCSRFToken ( ) {
var csrftoken = getCookie ( 'csrftoken' ) ;
var sessionid = getCookie ( 'sessionid' ) ;
$ . ajaxSetup ( {
beforeSend : function ( xhr , settings ) {
if ( ! csrfSafeMethod ( settings . type ) && ! this . crossDomain ) {
xhr . setRequestHeader ( "X-CSRFToken" , csrftoken ) ;
}
}
2016-08-09 06:42:21 +00:00
} ) ;
2016-09-15 04:20:53 +00:00
}
function activeNav ( ) {
var url _array = document . location . pathname . split ( "/" ) ;
var app = url _array [ 1 ] ;
var resource = url _array [ 2 ] ;
2016-09-26 08:33:10 +00:00
if ( app === '' ) {
$ ( '#index' ) . addClass ( 'active' ) ;
2018-10-15 02:48:24 +00:00
}
2018-11-02 06:38:44 +00:00
else if ( app === 'xpack' && resource === 'cloud' ) {
2018-10-15 02:48:24 +00:00
var item = url _array [ 3 ] ;
$ ( "#" + app ) . addClass ( 'active' ) ;
$ ( '#' + app + ' #' + resource ) . addClass ( 'active' ) ;
$ ( '#' + app + ' #' + resource + ' #' + item + ' a' ) . css ( 'color' , '#ffffff' ) ;
}
2018-10-24 02:48:03 +00:00
else if ( app === 'settings' ) {
$ ( "#" + app ) . addClass ( 'active' ) ;
}
2018-10-15 02:48:24 +00:00
else {
2016-09-15 04:20:53 +00:00
$ ( "#" + app ) . addClass ( 'active' ) ;
$ ( '#' + app + ' #' + resource ) . addClass ( 'active' ) ;
}
2016-09-06 13:03:51 +00:00
}
2019-01-16 10:13:16 +00:00
function formSubmit ( props ) {
/ *
{
"form" : $ ( "form" ) ,
2019-06-13 10:58:43 +00:00
"data" : { } ,
2019-01-16 10:13:16 +00:00
"url" : "" ,
"method" : "POST" ,
"redirect_to" : "" ,
"success" : function ( data , textStatue , jqXHR ) { } ,
2019-06-13 10:58:43 +00:00
"error" : function ( jqXHR , textStatus , errorThrown ) { } ,
"message" : "" ,
2019-01-16 10:13:16 +00:00
}
* /
props = props || { } ;
var data = props . data || props . form . serializeObject ( ) ;
var redirect _to = props . redirect _to ;
$ . ajax ( {
url : props . url ,
type : props . method || 'POST' ,
data : JSON . stringify ( data ) ,
contentType : props . content _type || "application/json; charset=utf-8" ,
dataType : props . data _type || "json"
} ) . done ( function ( data , textState , jqXHR ) {
if ( redirect _to ) {
2019-06-13 10:58:43 +00:00
if ( props . message ) {
var messages = "ed65330a45559c87345a0eb6ac7812d18d0d8976$[[\"__json_message\"\0540\05425\054\"asdfasdf \\u521b\\u5efa\\u6210\\u529f\"]]"
setCookie ( "messages" , messages )
}
2019-01-16 10:13:16 +00:00
location . href = redirect _to ;
} else if ( typeof props . success === 'function' ) {
return props . success ( data , textState , jqXHR ) ;
}
} ) . fail ( function ( jqXHR , textStatus , errorThrown ) {
if ( typeof props . error === 'function' ) {
return props . error ( jqXHR , textStatus , errorThrown )
}
if ( ! props . form ) {
alert ( jqXHR . responseText ) ;
return
}
if ( jqXHR . status === 400 ) {
var errors = jqXHR . responseJSON ;
var noneFieldErrorRef = props . form . children ( '.alert-danger' ) ;
if ( noneFieldErrorRef . length !== 1 ) {
props . form . prepend ( '<div class="alert alert-danger" style="display: none"></div>' ) ;
noneFieldErrorRef = props . form . children ( '.alert-danger' ) ;
}
var noneFieldErrorMsg = "" ;
noneFieldErrorRef . css ( "display" , "none" ) ;
noneFieldErrorRef . html ( "" ) ;
props . form . find ( ".help-block.error" ) . html ( "" ) ;
props . form . find ( ".form-group.has-error" ) . removeClass ( "has-error" ) ;
if ( typeof errors !== "object" ) {
noneFieldErrorMsg = errors ;
if ( noneFieldErrorRef . length === 1 ) {
noneFieldErrorRef . css ( 'display' , 'block' ) ;
noneFieldErrorRef . html ( noneFieldErrorMsg ) ;
}
return
}
$ . each ( errors , function ( k , v ) {
2019-07-17 14:14:39 +00:00
var fieldRef = props . form . find ( '[name="' + k + '"]' ) ;
2019-01-16 10:13:16 +00:00
var formGroupRef = fieldRef . parents ( '.form-group' ) ;
var parentRef = fieldRef . parent ( ) ;
var helpBlockRef = parentRef . children ( '.help-block.error' ) ;
if ( helpBlockRef . length === 0 ) {
parentRef . append ( '<div class="help-block error"></div>' ) ;
helpBlockRef = parentRef . children ( '.help-block.error' ) ;
}
if ( fieldRef . length === 1 && formGroupRef . length === 1 ) {
formGroupRef . addClass ( 'has-error' ) ;
var help _msg = v . join ( "<br/>" ) ;
helpBlockRef . html ( help _msg ) ;
} else {
2019-06-13 10:58:43 +00:00
$ . each ( v , function ( kk , vv ) {
2019-07-17 14:14:39 +00:00
if ( typeof vv === "object" ) {
2019-06-13 10:58:43 +00:00
$ . each ( vv , function ( kkk , vvv ) {
noneFieldErrorMsg += " " + vvv + '<br/>' ;
} )
} else {
noneFieldErrorMsg += vv + '<br/>' ;
}
} )
2019-01-16 10:13:16 +00:00
}
} ) ;
if ( noneFieldErrorRef . length === 1 && noneFieldErrorMsg !== '' ) {
noneFieldErrorRef . css ( 'display' , 'block' ) ;
noneFieldErrorRef . html ( noneFieldErrorMsg ) ;
}
}
} )
}
2019-07-12 10:31:55 +00:00
function requestApi ( props ) {
2017-02-06 15:13:27 +00:00
// props = {url: .., body: , success: , error: , method: ,}
props = props || { } ;
2018-09-07 04:40:26 +00:00
var user _success _message = props . success _message ;
var default _success _message = gettext ( 'Update is successful!' ) ;
var user _fail _message = props . fail _message ;
var default _failed _message = gettext ( 'An unknown error occurred while updating..' ) ;
2018-04-02 08:55:39 +00:00
var flash _message = props . flash _message || true ;
2018-01-12 07:43:26 +00:00
if ( props . flash _message === false ) {
flash _message = false ;
}
2017-02-06 15:13:27 +00:00
$ . ajax ( {
url : props . url ,
type : props . method || "PATCH" ,
data : props . body ,
contentType : props . content _type || "application/json; charset=utf-8" ,
dataType : props . data _type || "json"
} ) . done ( function ( data , textStatue , jqXHR ) {
2018-01-12 07:43:26 +00:00
if ( flash _message ) {
2018-09-07 04:40:26 +00:00
var msg = "" ;
2019-06-28 14:07:22 +00:00
if ( user _success _message ) {
2018-09-07 04:40:26 +00:00
msg = user _success _message ;
} else {
msg = default _success _message ;
}
toastr . success ( msg ) ;
2018-01-12 07:43:26 +00:00
}
2017-02-06 15:13:27 +00:00
if ( typeof props . success === 'function' ) {
return props . success ( data ) ;
2018-06-20 07:58:01 +00:00
}
2017-12-12 04:19:45 +00:00
} ) . fail ( function ( jqXHR , textStatus , errorThrown ) {
2018-01-12 07:43:26 +00:00
if ( flash _message ) {
2018-09-07 04:40:26 +00:00
var msg = "" ;
if ( user _fail _message ) {
msg = user _fail _message ;
} else if ( jqXHR . responseJSON ) {
if ( jqXHR . responseJSON . error ) {
msg = jqXHR . responseJSON . error
} else if ( jqXHR . responseJSON . msg ) {
msg = jqXHR . responseJSON . msg
}
}
if ( msg === "" ) {
msg = default _failed _message ;
}
toastr . error ( msg ) ;
2018-01-12 07:43:26 +00:00
}
2017-02-06 15:13:27 +00:00
if ( typeof props . error === 'function' ) {
2018-08-06 10:17:17 +00:00
return props . error ( jqXHR . responseText , jqXHR . status ) ;
2018-06-20 07:58:01 +00:00
}
2017-02-06 15:13:27 +00:00
} ) ;
2016-11-10 08:59:50 +00:00
// return true;
2016-09-06 13:03:51 +00:00
}
2016-09-07 13:53:27 +00:00
2016-09-15 05:09:24 +00:00
// Sweet Alert for Delete
2017-01-20 12:13:22 +00:00
function objectDelete ( obj , name , url , redirectTo ) {
2016-10-24 11:32:53 +00:00
function doDelete ( ) {
var body = { } ;
var success = function ( ) {
2017-12-21 03:31:13 +00:00
// swal('Deleted!', "[ "+name+"]"+" has been deleted ", "success");
2017-01-20 12:13:22 +00:00
if ( ! redirectTo ) {
$ ( obj ) . parent ( ) . parent ( ) . remove ( ) ;
} else {
window . location . href = redirectTo ;
}
2016-10-24 11:32:53 +00:00
} ;
var fail = function ( ) {
2018-06-20 07:58:01 +00:00
// swal("错误", "删除"+"[ "+name+" ]"+"遇到错误", "error");
2018-09-03 03:24:25 +00:00
swal ( gettext ( 'Error' ) , "[ " + name + " ]" + gettext ( "Being used by the asset, please unbind the asset first." ) , "error" ) ;
2016-10-24 11:32:53 +00:00
} ;
2019-07-12 10:31:55 +00:00
requestApi ( {
2016-10-24 11:32:53 +00:00
url : url ,
body : JSON . stringify ( body ) ,
method : 'DELETE' ,
2018-09-03 03:24:25 +00:00
success _message : gettext ( "Delete the success" ) ,
2016-10-24 11:32:53 +00:00
success : success ,
error : fail
} ) ;
}
2016-09-15 05:09:24 +00:00
swal ( {
2018-09-03 03:24:25 +00:00
title : gettext ( 'Are you sure about deleting it?' ) ,
2016-10-24 11:32:53 +00:00
text : " [" + name + "] " ,
2016-09-15 05:09:24 +00:00
type : "warning" ,
showCancelButton : true ,
2018-09-03 03:24:25 +00:00
cancelButtonText : gettext ( 'Cancel' ) ,
2017-12-21 03:31:13 +00:00
confirmButtonColor : "#ed5565" ,
2018-09-03 03:24:25 +00:00
confirmButtonText : gettext ( 'Confirm' ) ,
2017-12-21 03:31:13 +00:00
closeOnConfirm : true ,
2016-09-15 05:09:24 +00:00
} , function ( ) {
2018-06-20 07:58:01 +00:00
doDelete ( )
2016-09-15 05:09:24 +00:00
} ) ;
}
2018-08-06 08:08:05 +00:00
function orgDelete ( obj , name , url , redirectTo ) {
function doDelete ( ) {
var body = { } ;
var success = function ( ) {
if ( ! redirectTo ) {
$ ( obj ) . parent ( ) . parent ( ) . remove ( ) ;
} else {
window . location . href = redirectTo ;
}
} ;
2018-08-06 10:17:17 +00:00
var fail = function ( responseText , status ) {
if ( status === 400 ) {
2018-09-03 03:24:25 +00:00
swal ( gettext ( "Error" ) , "[ " + name + " ] " + gettext ( "The organization contains undeleted information. Please try again after deleting" ) , "error" ) ;
2018-08-06 10:17:17 +00:00
}
else if ( status === 405 ) {
2018-09-03 03:24:25 +00:00
swal ( gettext ( "Error" ) , " [ " + name + " ] " + gettext ( "Do not perform this operation under this organization. Try again after switching to another organization" ) , "error" ) ;
2018-08-06 10:17:17 +00:00
}
2018-08-06 08:08:05 +00:00
} ;
2019-07-12 10:31:55 +00:00
requestApi ( {
2018-08-06 08:08:05 +00:00
url : url ,
body : JSON . stringify ( body ) ,
method : 'DELETE' ,
2018-09-03 03:24:25 +00:00
success _message : gettext ( "Delete the success" ) ,
2018-08-06 08:08:05 +00:00
success : success ,
error : fail
} ) ;
}
swal ( {
2018-09-03 03:24:25 +00:00
title : gettext ( "Please ensure that the following information in the organization has been deleted" ) ,
text : gettext ( "User list、User group、Asset list、Domain list、Admin user、System user、Labels、Asset permission" ) ,
2018-08-06 08:08:05 +00:00
type : "warning" ,
showCancelButton : true ,
2018-09-03 03:24:25 +00:00
cancelButtonText : gettext ( 'Cancel' ) ,
2018-08-06 08:08:05 +00:00
confirmButtonColor : "#ed5565" ,
2018-09-03 03:24:25 +00:00
confirmButtonText : gettext ( 'Confirm' ) ,
2018-08-06 08:08:05 +00:00
closeOnConfirm : true
} , function ( ) {
doDelete ( ) ;
} ) ;
}
2016-09-26 08:33:10 +00:00
$ . fn . serializeObject = function ( )
{
var o = { } ;
var a = this . serializeArray ( ) ;
$ . each ( a , function ( ) {
if ( o [ this . name ] !== undefined ) {
if ( ! o [ this . name ] . push ) {
o [ this . name ] = [ o [ this . name ] ] ;
}
o [ this . name ] . push ( this . value || '' ) ;
} else {
o [ this . name ] = this . value || '' ;
}
} ) ;
return o ;
} ;
2018-04-10 12:29:06 +00:00
function makeLabel ( data ) {
return "<label class='detail-key'><b>" + data [ 0 ] + ": </b></label>" + data [ 1 ] + "</br>"
}
2016-09-27 13:28:02 +00:00
var jumpserver = { } ;
2016-09-28 13:11:43 +00:00
jumpserver . checked = false ;
2016-11-16 09:38:03 +00:00
jumpserver . selected = { } ;
2018-07-25 03:21:12 +00:00
jumpserver . language = {
2018-09-03 03:24:25 +00:00
processing : gettext ( 'Loading ...' ) ,
search : gettext ( 'Search' ) ,
2018-07-27 10:56:40 +00:00
select : {
rows : {
2018-09-03 03:24:25 +00:00
_ : gettext ( "Selected item %d" ) ,
2018-07-27 10:56:40 +00:00
0 : ""
}
} ,
2018-09-03 03:24:25 +00:00
lengthMenu : gettext ( "Per page _MENU_" ) ,
info : gettext ( 'Displays the results of items _START_ to _END_; A total of _TOTAL_ entries' ) ,
2018-07-25 03:21:12 +00:00
infoFiltered : "" ,
infoEmpty : "" ,
2018-09-03 03:24:25 +00:00
zeroRecords : gettext ( "No match" ) ,
emptyTable : gettext ( 'No record' ) ,
2018-07-25 03:21:12 +00:00
paginate : {
first : "«" ,
previous : "‹ " ,
next : "› " ,
last : "»"
}
} ;
2016-09-27 13:28:02 +00:00
jumpserver . initDataTable = function ( options ) {
// options = {
// ele *: $('#dataTable_id'),
// ajax_url *: '{% url 'users:user-list-api' %}',
// columns *: [{data: ''}, ....],
// dom: 'fltip',
// i18n_url: '{% static "js/...../en-us.json" %}',
// order: [[1, 'asc'], [2, 'asc'], ...],
// buttons: ['excel', 'pdf', 'print'],
// columnDefs: [{target: 0, createdCell: ()=>{}}, ...],
// uc_html: '<a>header button</a>',
2017-12-18 10:38:30 +00:00
// op_html: 'div.btn-group?',
// paging: true
2016-09-27 13:28:02 +00:00
// }
var ele = options . ele || $ ( '.dataTable' ) ;
var columnDefs = [
2017-12-31 03:14:02 +00:00
{
targets : 0 ,
orderable : false ,
createdCell : function ( td , cellData ) {
$ ( td ) . html ( '<input type="checkbox" class="text-center ipt_check" id=99991937>' . replace ( '99991937' , cellData ) ) ;
}
} ,
2018-07-08 05:02:43 +00:00
{ className : 'text-center' , render : $ . fn . dataTable . render . text ( ) , targets : '_all' }
2016-09-27 13:28:02 +00:00
] ;
columnDefs = options . columnDefs ? options . columnDefs . concat ( columnDefs ) : columnDefs ;
2017-12-31 04:20:08 +00:00
var select = {
2019-07-03 10:03:01 +00:00
style : 'multi' ,
selector : 'td:first-child'
} ;
2016-09-27 13:28:02 +00:00
var table = ele . DataTable ( {
2016-11-06 14:45:26 +00:00
pageLength : options . pageLength || 15 ,
2019-07-04 08:13:05 +00:00
dom : options . dom || '<"#uc.pull-left"><"pull-right"<"inline"l><"#fb.inline"><"inline"f><"#fa.inline">>tr<"row m-t"<"col-md-8"<"#op.col-md-6"><"col-md-6 text-center"i>><"col-md-4"p>>' ,
2017-12-12 04:19:45 +00:00
order : options . order || [ ] ,
2017-12-31 03:14:02 +00:00
// select: options.select || 'multi',
2019-07-03 10:03:01 +00:00
searchDelay : 800 ,
2016-11-16 09:38:03 +00:00
buttons : [ ] ,
2016-09-27 13:28:02 +00:00
columnDefs : columnDefs ,
ajax : {
2018-04-10 12:29:06 +00:00
url : options . ajax _url ,
2016-09-27 13:28:02 +00:00
dataSrc : ""
} ,
2016-11-06 14:45:26 +00:00
columns : options . columns || [ ] ,
2017-12-31 04:20:08 +00:00
select : options . select || select ,
2018-07-25 03:21:12 +00:00
language : jumpserver . language ,
2018-04-13 07:48:10 +00:00
lengthMenu : [ [ 10 , 15 , 25 , 50 , - 1 ] , [ 10 , 15 , 25 , 50 , "All" ] ]
2016-09-27 13:28:02 +00:00
} ) ;
2016-11-14 16:48:48 +00:00
table . on ( 'select' , function ( e , dt , type , indexes ) {
var $node = table [ type ] ( indexes ) . nodes ( ) . to$ ( ) ;
$node . find ( 'input.ipt_check' ) . prop ( 'checked' , true ) ;
2016-11-16 09:38:03 +00:00
jumpserver . selected [ $node . find ( 'input.ipt_check' ) . prop ( 'id' ) ] = true
2016-11-14 16:48:48 +00:00
} ) . on ( 'deselect' , function ( e , dt , type , indexes ) {
var $node = table [ type ] ( indexes ) . nodes ( ) . to$ ( ) ;
2018-01-15 09:41:49 +00:00
$node . find ( 'input.ipt_check' ) . prop ( 'checked' , false ) ;
jumpserver . selected [ $node . find ( 'input.ipt_check' ) . prop ( 'id' ) ] = false
2018-01-30 10:07:51 +00:00
} ) . on ( 'draw' , function ( ) {
2018-01-15 09:41:49 +00:00
$ ( '#op' ) . html ( options . op _html || '' ) ;
$ ( '#uc' ) . html ( options . uc _html || '' ) ;
2018-01-30 10:07:51 +00:00
$ ( '[data-toggle="popover"]' ) . popover ( {
html : true ,
placement : 'bottom' ,
2019-06-24 12:16:18 +00:00
trigger : 'click' ,
2018-01-30 10:07:51 +00:00
container : 'body'
2019-06-24 12:16:18 +00:00
} ) . on ( 'click' , function ( e ) {
$ ( '[data-toggle="popover"]' ) . not ( this ) . popover ( 'hide' ) ;
2018-01-30 10:07:51 +00:00
} ) ;
2018-01-15 09:41:49 +00:00
} ) ;
$ ( '.ipt_check_all' ) . on ( 'click' , function ( ) {
2018-02-06 10:32:02 +00:00
if ( $ ( this ) . prop ( "checked" ) ) {
2018-01-15 09:41:49 +00:00
$ ( this ) . closest ( 'table' ) . find ( '.ipt_check' ) . prop ( 'checked' , true ) ;
jumpserver . checked = true ;
2018-01-15 10:32:07 +00:00
table . rows ( { search : 'applied' , page : 'current' } ) . select ( ) ;
2018-01-15 09:41:49 +00:00
} else {
$ ( this ) . closest ( 'table' ) . find ( '.ipt_check' ) . prop ( 'checked' , false ) ;
jumpserver . checked = false ;
2018-01-15 10:32:07 +00:00
table . rows ( { search : 'applied' , page : 'current' } ) . deselect ( ) ;
2018-01-15 09:41:49 +00:00
}
} ) ;
return table ;
} ;
2018-07-25 03:21:12 +00:00
jumpserver . initStaticTable = function ( selector ) {
$ ( selector ) . DataTable ( {
"searching" : false ,
"bInfo" : false ,
"paging" : false ,
"order" : [ ] ,
"language" : jumpserver . language
} ) ;
} ;
2018-01-15 09:41:49 +00:00
jumpserver . initServerSideDataTable = function ( options ) {
// options = {
// ele *: $('#dataTable_id'),
// ajax_url *: '{% url 'users:user-list-api' %}',
// columns *: [{data: ''}, ....],
// dom: 'fltip',
// i18n_url: '{% static "js/...../en-us.json" %}',
// order: [[1, 'asc'], [2, 'asc'], ...],
// buttons: ['excel', 'pdf', 'print'],
// columnDefs: [{target: 0, createdCell: ()=>{}}, ...],
// uc_html: '<a>header button</a>',
// op_html: 'div.btn-group?',
// paging: true
// }
var ele = options . ele || $ ( '.dataTable' ) ;
var columnDefs = [
{
targets : 0 ,
orderable : false ,
createdCell : function ( td , cellData ) {
$ ( td ) . html ( '<input type="checkbox" class="text-center ipt_check" id=99991937>' . replace ( '99991937' , cellData ) ) ;
}
} ,
2019-04-25 06:31:34 +00:00
{
targets : '_all' ,
className : 'text-center' ,
render : $ . fn . dataTable . render . text ( )
}
2018-01-15 09:41:49 +00:00
] ;
columnDefs = options . columnDefs ? options . columnDefs . concat ( columnDefs ) : columnDefs ;
var select = {
style : 'multi' ,
selector : 'td:first-child'
} ;
var table = ele . DataTable ( {
2018-07-25 07:05:28 +00:00
pageLength : options . pageLength || 15 ,
2019-07-03 08:29:39 +00:00
// dom: options.dom || '<"#uc.pull-left">fltr<"row m-t"<"col-md-8"<"#op.col-md-6"><"col-md-6 text-center"i>><"col-md-4"p>>',
dom : options . dom || '<"#uc.pull-left"><"pull-right"<"inline"l><"#fb.inline"><"inline"f><"#fa.inline">>tr<"row m-t"<"col-md-8"<"#op.col-md-6"><"col-md-6 text-center"i>><"col-md-4"p>>' ,
2018-07-25 07:05:28 +00:00
order : options . order || [ ] ,
buttons : [ ] ,
2018-01-15 09:41:49 +00:00
columnDefs : columnDefs ,
serverSide : true ,
processing : true ,
2019-07-03 10:03:01 +00:00
searchDelay : 800 ,
2018-01-15 09:41:49 +00:00
ajax : {
url : options . ajax _url ,
2019-03-18 03:34:13 +00:00
error : function ( jqXHR , textStatus , errorThrown ) {
var msg = gettext ( "Unknown error occur" ) ;
if ( jqXHR . responseJSON ) {
if ( jqXHR . responseJSON . error ) {
msg = jqXHR . responseJSON . error
} else if ( jqXHR . responseJSON . msg ) {
msg = jqXHR . responseJSON . msg
}
}
alert ( msg )
} ,
2018-01-15 09:41:49 +00:00
data : function ( data ) {
delete data . columns ;
2019-01-15 11:01:33 +00:00
if ( data . length !== null ) {
2018-01-15 09:41:49 +00:00
data . limit = data . length ;
delete data . length ;
}
if ( data . start !== null ) {
data . offset = data . start ;
delete data . start ;
}
if ( data . search !== null ) {
var search _val = data . search . value ;
2018-01-26 06:47:10 +00:00
var search _list = search _val . split ( " " ) ;
var search _attr = { } ;
var search _raw = [ ] ;
search _list . map ( function ( val , index ) {
var kv = val . split ( ":" ) ;
if ( kv . length === 2 ) {
2019-07-04 08:08:52 +00:00
var value = kv [ 1 ] ;
value = value . replace ( "+" , " " ) ;
search _attr [ kv [ 0 ] ] = value
2018-01-26 06:47:10 +00:00
} else {
search _raw . push ( kv )
}
} ) ;
data . search = search _raw . join ( "" ) ;
$ . each ( search _attr , function ( k , v ) {
data [ k ] = v
} )
2018-01-15 09:41:49 +00:00
}
if ( data . order !== null && data . order . length === 1 ) {
var col = data . order [ 0 ] . column ;
var order = options . columns [ col ] . data ;
2018-11-12 08:45:57 +00:00
if ( data . order [ 0 ] . dir === "desc" ) {
2018-01-15 09:41:49 +00:00
order = "-" + order ;
}
data . order = order ;
}
} ,
2018-01-15 10:14:58 +00:00
dataFilter : function ( data ) {
var json = jQuery . parseJSON ( data ) ;
json . recordsTotal = json . count ;
json . recordsFiltered = json . count ;
return JSON . stringify ( json ) ; // return JSON string
} ,
2018-01-15 09:41:49 +00:00
dataSrc : "results"
} ,
columns : options . columns || [ ] ,
select : options . select || select ,
2018-07-25 03:21:12 +00:00
language : jumpserver . language ,
2019-06-28 14:07:22 +00:00
lengthMenu : options . lengthMenu || [ [ 15 , 25 , 50 , 9999 ] , [ 15 , 25 , 50 , 'All' ] ]
2018-01-15 09:41:49 +00:00
} ) ;
2018-04-13 07:48:10 +00:00
table . selected = [ ] ;
2018-12-25 05:33:37 +00:00
table . selected _rows = [ ] ;
2018-01-15 09:41:49 +00:00
table . on ( 'select' , function ( e , dt , type , indexes ) {
var $node = table [ type ] ( indexes ) . nodes ( ) . to$ ( ) ;
$node . find ( 'input.ipt_check' ) . prop ( 'checked' , true ) ;
2018-04-13 07:48:10 +00:00
jumpserver . selected [ $node . find ( 'input.ipt_check' ) . prop ( 'id' ) ] = true ;
if ( type === 'row' ) {
var rows = table . rows ( indexes ) . data ( ) ;
$ . each ( rows , function ( id , row ) {
2018-12-25 05:33:37 +00:00
table . selected _rows . push ( row ) ;
2018-11-29 08:01:03 +00:00
if ( row . id && $ . inArray ( row . id , table . selected ) === - 1 ) {
2018-04-13 07:48:10 +00:00
table . selected . push ( row . id )
}
} )
}
2018-01-15 09:41:49 +00:00
} ) . on ( 'deselect' , function ( e , dt , type , indexes ) {
var $node = table [ type ] ( indexes ) . nodes ( ) . to$ ( ) ;
2016-11-14 16:48:48 +00:00
$node . find ( 'input.ipt_check' ) . prop ( 'checked' , false ) ;
2018-04-13 07:48:10 +00:00
jumpserver . selected [ $node . find ( 'input.ipt_check' ) . prop ( 'id' ) ] = false ;
if ( type === 'row' ) {
var rows = table . rows ( indexes ) . data ( ) ;
$ . each ( rows , function ( id , row ) {
if ( row . id ) {
var index = table . selected . indexOf ( row . id ) ;
if ( index > - 1 ) {
table . selected . splice ( index , 1 )
}
}
} )
}
2018-07-25 07:05:28 +00:00
} ) . on ( 'draw' , function ( ) {
2019-06-24 12:16:18 +00:00
$ ( '[data-toggle="popover"]' ) . popover ( {
html : true ,
placement : 'bottom' ,
trigger : 'click' ,
container : 'body'
} ) . on ( 'click' , function ( e ) {
$ ( '[data-toggle="popover"]' ) . not ( this ) . popover ( 'hide' ) ;
} ) ;
2018-04-13 07:48:10 +00:00
var table _data = [ ] ;
$ . each ( table . rows ( ) . data ( ) , function ( id , row ) {
if ( row . id ) {
table _data . push ( row . id )
}
} ) ;
$ . each ( table . selected , function ( id , data ) {
var index = table _data . indexOf ( data ) ;
if ( index > - 1 ) {
table . rows ( index ) . select ( )
}
} ) ;
2019-07-03 08:29:39 +00:00
} ) . on ( "init" , function ( ) {
$ ( '#op' ) . html ( options . op _html || '' ) ;
$ ( '#uc' ) . html ( options . uc _html || '' ) ;
$ ( '#fb' ) . html ( options . fb _html || '' ) ;
$ ( '#fa' ) . html ( options . fa _html || '' ) ;
2016-11-14 16:48:48 +00:00
} ) ;
2018-04-13 07:48:10 +00:00
var table _id = table . settings ( ) [ 0 ] . sTableId ;
$ ( '#' + table _id + ' .ipt_check_all' ) . on ( 'click' , function ( ) {
2018-02-06 10:32:02 +00:00
if ( $ ( this ) . prop ( "checked" ) ) {
$ ( this ) . closest ( 'table' ) . find ( '.ipt_check' ) . prop ( 'checked' , true ) ;
table . rows ( { search : 'applied' , page : 'current' } ) . select ( ) ;
} else {
$ ( this ) . closest ( 'table' ) . find ( '.ipt_check' ) . prop ( 'checked' , false ) ;
table . rows ( { search : 'applied' , page : 'current' } ) . deselect ( ) ;
}
2017-12-31 04:20:08 +00:00
} ) ;
2016-11-14 16:48:48 +00:00
2018-02-06 10:32:02 +00:00
// jumpserver.table = table;
2016-09-27 13:28:02 +00:00
return table ;
2016-10-24 11:32:53 +00:00
} ;
2016-12-14 01:54:16 +00:00
/ * *
* 替换所有匹配exp的字符串为指定字符串
* @ param exp 被替换部分的正则
* @ param newStr 替换成的字符串
* /
String . prototype . replaceAll = function ( exp , newStr ) {
return this . replace ( new RegExp ( exp , "gm" ) , newStr ) ;
} ;
/ * *
* 原型 : 字符串格式化
* @ param args 格式化参数值
* /
String . prototype . format = function ( args ) {
var result = this ;
if ( arguments . length < 1 ) {
return result ;
}
var data = arguments ;
if ( arguments . length == 1 && typeof ( args ) == "object" ) {
data = args ;
}
for ( var key in data ) {
var value = data [ key ] ;
if ( undefined != value ) {
result = result . replaceAll ( "\\{" + key + "\\}" , value ) ;
}
}
return result ;
2017-12-12 06:28:12 +00:00
} ;
2017-12-21 03:31:13 +00:00
2019-05-20 04:30:55 +00:00
function setCookie ( key , value , time ) {
2017-12-21 03:31:13 +00:00
var expires = new Date ( ) ;
2019-05-20 04:30:55 +00:00
if ( ! time ) {
time = expires . getTime ( ) + ( 24 * 60 * 60 * 1000 ) ;
}
expires . setTime ( time ) ;
2018-01-02 09:02:03 +00:00
document . cookie = key + '=' + value + ';expires=' + expires . toUTCString ( ) + ';path=/' ;
}
function delCookie ( key ) {
var expires = new Date ( ) ;
expires . setTime ( expires . getTime ( ) - 1 ) ;
var val = getCookie ( key ) ;
if ( val !== null ) {
document . cookie = key + '=' + val + ";expires" + expires . toUTCString ( ) + ';path=/' ;
}
2017-12-21 03:31:13 +00:00
}
2018-01-30 10:07:51 +00:00
function createPopover ( dataset , title , callback ) {
if ( callback !== undefined ) {
var new _dataset = [ ] ;
$ . each ( dataset , function ( index , value ) {
new _dataset . push ( callback ( value ) )
} ) ;
dataset = new _dataset ;
}
var data _content = dataset . join ( "</br>" ) ;
var html = "<a data-toggle='popover' data-content='" + data _content + "'>" + dataset . length + "</a>" ;
return html ;
2018-02-02 09:06:08 +00:00
}
$ ( function ( ) {
( function ( $ ) {
$ . getUrlParam = function ( name ) {
var reg = new RegExp ( "(^|&)" + name + "=([^&]*)(&|$)" ) ;
var r = window . location . search . substr ( 1 ) . match ( reg ) ;
if ( r != null ) return unescape ( r [ 2 ] ) ; return null ;
}
} ) ( jQuery ) ;
} ) ;
function getUrlParam ( name ) {
var reg = new RegExp ( "(^|&)" + name + "=([^&]*)(&|$)" ) ;
var r = window . location . search . substr ( 1 ) . match ( reg ) ;
if ( r != null ) return unescape ( r [ 2 ] ) ; return null ;
}
function setUrlParam ( url , name , value ) {
var urlArray = url . split ( "?" ) ;
if ( urlArray . length === 1 ) {
url += "?" + name + "=" + value ;
} else {
var oriParam = urlArray [ 1 ] . split ( "&" ) ;
var oriParamMap = { } ;
$ . each ( oriParam , function ( index , value ) {
var v = value . split ( "=" ) ;
oriParamMap [ v [ 0 ] ] = v [ 1 ] ;
} ) ;
oriParamMap [ name ] = value ;
url = urlArray [ 0 ] + "?" ;
var newParam = [ ] ;
$ . each ( oriParamMap , function ( index , value ) {
newParam . push ( index + "=" + value ) ;
} ) ;
url += newParam . join ( "&" )
}
return url
}
2018-06-05 09:26:31 +00:00
2018-11-22 04:27:27 +00:00
// Password check rules
var rules _short _map _id = {
'min' : 'id_security_password_min_length' ,
'upper' : 'id_security_password_upper_case' ,
'lower' : 'id_security_password_lower_case' ,
'number' : 'id_security_password_number' ,
'special' : 'id_security_password_special_char'
} ;
var rules _id _map _label = {
'id_security_password_min_length' : gettext ( 'Password minimum length {N} bits' ) ,
'id_security_password_upper_case' : gettext ( 'Must contain capital letters' ) ,
'id_security_password_lower_case' : gettext ( 'Must contain lowercase letters' ) ,
'id_security_password_number' : gettext ( 'Must contain numeric characters' ) ,
'id_security_password_special_char' : gettext ( 'Must contain special characters' )
} ;
function getRuleLabel ( rule ) {
var label = '' ;
if ( rule . key === rules _short _map _id [ 'min' ] ) {
label = rules _id _map _label [ rule . key ] . replace ( '{N}' , rule . value )
}
else {
label = rules _id _map _label [ rule . key ]
}
return label
}
2018-06-05 09:26:31 +00:00
// 校验密码-改变规则颜色
function checkPasswordRules ( password , minLength ) {
if ( wordMinLength ( password , minLength ) ) {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'min' ] ) . css ( 'color' , 'green' )
2018-06-05 09:26:31 +00:00
}
else {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'min' ] ) . css ( 'color' , '#908a8a' )
2018-06-05 09:26:31 +00:00
}
if ( wordUpperCase ( password ) ) {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'upper' ] ) . css ( 'color' , 'green' )
2018-06-05 09:26:31 +00:00
}
else {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'upper' ] ) . css ( 'color' , '#908a8a' )
2018-06-05 09:26:31 +00:00
}
if ( wordLowerCase ( password ) ) {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'lower' ] ) . css ( 'color' , 'green' )
2018-06-05 09:26:31 +00:00
}
else {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'lower' ] ) . css ( 'color' , '#908a8a' )
2018-06-05 09:26:31 +00:00
}
if ( wordNumber ( password ) ) {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'number' ] ) . css ( 'color' , 'green' )
2018-06-05 09:26:31 +00:00
}
else {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'number' ] ) . css ( 'color' , '#908a8a' )
2018-06-05 09:26:31 +00:00
}
if ( wordSpecialChar ( password ) ) {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'special' ] ) . css ( 'color' , 'green' )
2018-06-05 09:26:31 +00:00
}
else {
2018-11-22 04:27:27 +00:00
$ ( '#' + rules _short _map _id [ 'special' ] ) . css ( 'color' , '#908a8a' )
2018-06-05 09:26:31 +00:00
}
}
// 最小长度
function wordMinLength ( word , minLength ) {
//var minLength = {{ min_length }};
var re = new RegExp ( "^(.{" + minLength + ",})$" ) ;
return word . match ( re )
}
// 大写字母
function wordUpperCase ( word ) {
return word . match ( /([A-Z]+)/ )
}
// 小写字母
function wordLowerCase ( word ) {
return word . match ( /([a-z]+)/ )
}
// 数字字符
function wordNumber ( word ) {
return word . match ( /([\d]+)/ )
}
// 特殊字符
function wordSpecialChar ( word ) {
return word . match ( /[`,~,!,@,#,\$,%,\^,&,\*,\(,\),\-,_,=,\+,\{,\},\[,\],\|,\\,;,',:,",\,,\.,<,>,\/,\?]+/ )
}
2018-11-22 04:27:27 +00:00
2018-06-05 09:26:31 +00:00
// 显示弹窗密码规则
function popoverPasswordRules ( password _check _rules , $el ) {
var message = "" ;
2018-11-22 04:27:27 +00:00
jQuery . each ( password _check _rules , function ( idx , rule ) {
message += "<li id=" + rule . key + " style='list-style-type:none;'> <i class='fa fa-check-circle-o' style='margin-right:10px;' ></i>" + getRuleLabel ( rule ) + "</li>" ;
2018-06-05 09:26:31 +00:00
} ) ;
//$('#id_password_rules').html(message);
$el . html ( message )
}
// 初始化弹窗popover
2018-08-01 02:44:43 +00:00
function initPopover ( $container , $progress , $idPassword , $el , password _check _rules , i18n _fallback ) {
2018-06-05 09:26:31 +00:00
options = { } ;
// User Interface
options . ui = {
container : $container ,
viewports : {
progress : $progress
//errors: $('.popover-content')
} ,
showProgressbar : true ,
showVerdictsInsideProgressBar : true
} ;
2018-08-01 02:44:43 +00:00
options . i18n = {
fallback : i18n _fallback ,
t : function ( key ) {
var result = '' ;
result = options . i18n . fallback [ key ] ;
return result === key ? '' : result ;
}
} ;
2018-06-05 09:26:31 +00:00
$idPassword . pwstrength ( options ) ;
popoverPasswordRules ( password _check _rules , $el ) ;
}
2018-12-18 10:50:02 +00:00
// 解决input框中的资产和弹出表格中资产的显示不一致
2019-06-19 03:31:38 +00:00
function initSelectedAssets2Table ( id ) {
if ( ! id ) {
id = "#id_assets"
}
var inputAssets = $ ( id ) . val ( ) ;
2018-12-18 10:50:02 +00:00
var selectedAssets = asset _table2 . selected . concat ( ) ;
// input assets无, table assets选中, 则取消勾选(再次click)
if ( selectedAssets . length !== 0 ) {
$ . each ( selectedAssets , function ( index , assetId ) {
if ( $ . inArray ( assetId , inputAssets ) === - 1 ) {
$ ( '#' + assetId ) . trigger ( 'click' ) ; // 取消勾选
}
} ) ;
}
// input assets有, table assets没选, 则选中(click)
if ( inputAssets !== null ) {
asset _table2 . selected = inputAssets ;
$ . each ( inputAssets , function ( index , assetId ) {
var dom = document . getElementById ( assetId ) ;
if ( dom !== null ) {
var selected = dom . parentElement . parentElement . className . indexOf ( 'selected' )
}
if ( selected === - 1 ) {
$ ( '#' + assetId ) . trigger ( 'click' ) ;
}
} ) ;
}
}
2019-03-05 11:47:14 +00:00
function rootNodeAddDom ( ztree , callback ) {
var refreshIcon = "<a id='tree-refresh'><i class='fa fa-refresh'></i></a>" ;
var rootNode = ztree . getNodes ( ) [ 0 ] ;
var $rootNodeRef = $ ( "#" + rootNode . tId + "_a" ) ;
$rootNodeRef . after ( refreshIcon ) ;
var refreshIconRef = $ ( '#tree-refresh' ) ;
refreshIconRef . bind ( 'click' , function ( ) {
ztree . destroy ( ) ;
callback ( )
} )
2019-04-25 06:31:34 +00:00
}
2019-05-21 08:24:01 +00:00
function APIExportData ( props ) {
props = props || { } ;
$ . ajax ( {
url : '/api/common/v1/resources/cache/' ,
type : props . method || "POST" ,
data : props . body ,
contentType : props . content _type || "application/json; charset=utf-8" ,
dataType : props . data _type || "json" ,
success : function ( data ) {
var export _url = props . success _url ;
var params = props . params || { } ;
params [ 'format' ] = props . format ;
params [ 'spm' ] = data . spm ;
for ( var k in params ) {
export _url = setUrlParam ( export _url , k , params [ k ] )
}
window . open ( export _url ) ;
} ,
error : function ( ) {
2019-05-27 08:12:19 +00:00
toastr . error ( gettext ( 'Export failed' ) ) ;
2019-05-21 08:24:01 +00:00
}
} )
}
function APIImportData ( props ) {
props = props || { } ;
$ . ajax ( {
url : props . url ,
type : props . method || "POST" ,
processData : false ,
data : props . body ,
contentType : props . content _type || 'text/csv' ,
success : function ( data ) {
if ( props . method === 'POST' ) {
$ ( '#created_failed' ) . html ( '' ) ;
$ ( '#created_failed_detail' ) . html ( '' ) ;
2019-05-27 08:12:19 +00:00
$ ( '#success_created' ) . html ( gettext ( "Import Success" ) ) ;
2019-05-21 08:24:01 +00:00
$ ( '#success_created_detail' ) . html ( "Count" + ": " + data . length ) ;
} else {
$ ( '#updated_failed' ) . html ( '' ) ;
$ ( '#updated_failed_detail' ) . html ( '' ) ;
2019-05-27 08:12:19 +00:00
$ ( '#success_updated' ) . html ( gettext ( "Update Success" ) ) ;
2019-06-20 10:10:44 +00:00
$ ( '#success_updated_detail' ) . html ( gettext ( "Count" ) + ": " + data . length ) ;
2019-05-21 08:24:01 +00:00
}
props . data _table . ajax . reload ( )
} ,
error : function ( error ) {
var data = error . responseJSON ;
if ( data instanceof Array ) {
var html = '' ;
var li = '' ;
var err = '' ;
$ . each ( data , function ( index , item ) {
err = '' ;
for ( var prop in item ) {
err += prop + ": " + item [ prop ] [ 0 ] + " "
}
if ( err ) {
li = "<li>" + "Line " + ( ++ index ) + ". " + err + "</li>" ;
html += li
}
} ) ;
html = "<ul>" + html + "</ul>"
}
else {
html = error . responseText
}
if ( props . method === 'POST' ) {
$ ( '#success_created' ) . html ( '' ) ;
$ ( '#success_created_detail' ) . html ( '' ) ;
2019-05-27 08:12:19 +00:00
$ ( '#created_failed' ) . html ( gettext ( "Import failed" ) ) ;
2019-05-21 08:24:01 +00:00
$ ( '#created_failed_detail' ) . html ( html ) ;
} else {
$ ( '#success_updated' ) . html ( '' ) ;
$ ( '#success_updated_detail' ) . html ( '' ) ;
2019-05-27 08:12:19 +00:00
$ ( '#updated_failed' ) . html ( gettext ( "Update failed" ) ) ;
2019-05-21 08:24:01 +00:00
$ ( '#updated_failed_detail' ) . html ( html ) ;
}
}
} )
}
2019-04-25 06:31:34 +00:00
function htmlEscape ( d ) {
return typeof d === 'string' ?
d . replace ( /</g , '<' ) . replace ( />/g , '>' ) . replace ( /"/g , '"' ) :
d ;
2019-05-21 08:24:01 +00:00
}
2019-06-28 14:07:22 +00:00
function objectAttrsIsList ( obj , attrs ) {
attrs . forEach ( function ( attr ) {
2019-07-05 08:34:37 +00:00
if ( ! obj [ attr ] ) {
obj [ attr ] = [ ]
}
else if ( obj [ attr ] && ! ( obj [ attr ] instanceof Array ) ) {
2019-06-28 14:07:22 +00:00
obj [ attr ] = [ obj [ attr ] ]
}
} )
}
function objectAttrsIsDatetime ( obj , attrs ) {
attrs . forEach ( function ( attr ) {
2019-07-22 09:15:24 +00:00
obj [ attr ] = toSafeDateISOStr ( obj [ attr ] ) ;
2019-06-28 14:07:22 +00:00
} )
}
function objectAttrsIsBool ( obj , attrs ) {
attrs . forEach ( function ( attr ) {
if ( ! obj [ attr ] ) {
obj [ attr ] = false
} else if ( [ 'on' , '1' ] . includes ( obj [ attr ] ) ) {
obj [ attr ] = true
}
} )
}
2019-07-02 14:08:50 +00:00
2019-07-22 09:15:24 +00:00
function cleanDateStr ( d ) {
for ( var i = 0 ; i < 3 ; i ++ ) {
if ( ! isNaN ( Date . parse ( d ) ) ) {
return d ;
}
if ( ! isNaN ( Number ( d ) ) ) {
return d ;
}
switch ( i ) {
case 0 :
d = d . replaceAll ( '-' , '/' ) ;
break ;
case 1 :
d = d . split ( '+' ) [ 0 ] . trimRight ( ) ;
break ;
2019-07-12 10:31:55 +00:00
}
}
2019-07-22 09:15:24 +00:00
return null ;
2019-07-12 10:31:55 +00:00
}
2019-07-19 04:01:17 +00:00
function safeDate ( s ) {
2019-07-22 09:15:24 +00:00
s = cleanDateStr ( s ) ;
2019-07-19 04:01:17 +00:00
return new Date ( s )
}
2019-07-22 09:15:24 +00:00
function toSafeDateISOStr ( s ) {
var d = safeDate ( s ) ;
return d . toISOString ( ) ;
}
function toSafeLocalDateStr ( d ) {
2019-07-19 04:01:17 +00:00
var date = safeDate ( d ) ;
2019-07-09 04:05:31 +00:00
var date _s = date . toLocaleString ( navigator . language , { hour12 : false } ) ;
return date _s . split ( "/" ) . join ( '-' )
2019-07-02 14:08:50 +00:00
}
2019-07-03 10:03:01 +00:00
function getUrlParams ( url ) {
url = url . split ( "?" ) ;
2019-07-03 14:28:20 +00:00
var params = "" ;
2019-07-03 10:03:01 +00:00
if ( url . length === 2 ) {
params = url [ 1 ] ;
}
return params
2019-07-03 14:28:20 +00:00
}
function getTimeUnits ( u ) {
var units = {
"d" : "天" ,
"h" : "时" ,
"m" : "分" ,
"s" : "秒" ,
} ;
2019-07-22 09:15:24 +00:00
if ( navigator . language === "zh-CN" ) {
2019-07-03 14:28:20 +00:00
return units [ u ]
}
return u
}
function timeOffset ( a , b ) {
2019-07-19 05:10:34 +00:00
var start = safeDate ( a ) ;
var end = safeDate ( b ) ;
2019-07-03 14:28:20 +00:00
var offset = ( end - start ) / 1000 ;
var days = offset / 3600 / 24 ;
var hours = offset / 3600 ;
var minutes = offset / 60 ;
var seconds = offset ;
if ( days > 1 ) {
return days . toFixed ( 1 ) + " " + getTimeUnits ( "d" ) ;
} else if ( hours > 1 ) {
return hours . toFixed ( 1 ) + " " + getTimeUnits ( "h" ) ;
} else if ( minutes > 1 ) {
return minutes . toFixed ( 1 ) + " " + getTimeUnits ( "m" )
} else if ( seconds > 1 ) {
return seconds . toFixed ( 1 ) + " " + getTimeUnits ( "s" )
}
return ""
2019-07-08 07:35:20 +00:00
}
function readFile ( ref ) {
var files = ref . prop ( 'files' ) ;
var hasFile = files && files . length > 0 ;
if ( hasFile ) {
var reader = new FileReader ( ) ; //新建一个FileReader
reader . readAsText ( files [ 0 ] , "UTF-8" ) ; //读取文件
reader . onload = function ( evt ) { //读取完文件之后会回来这里
ref . trigger ( "onload" , evt . target . result ) ;
} ;
} else {
ref . trigger ( "onload" , null ) ;
}
return ref
}