-
Notifications
You must be signed in to change notification settings - Fork 27
/
b.dialog.js
947 lines (924 loc) · 41.3 KB
/
b.dialog.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
/**
* 使用Bootstrap的Modal对话框进行二次封装
*
* @version 2.1
*
* @author Terry
* created : 2012.11.26
*
* 窗口拖拽功能依赖jQueryUI的draggable功能库
*
*
* 2016.05.12
* 解决在已经弹出的窗口中,再进行弹出窗口会进行覆盖的问题
* 2016.05.25
* 解决使用打开内容为HTML代码段的内容时,窗口关闭后,因为窗口里的所有内容会被移除,所以再打开时,原传递的原型内容则会不存在,即第二次打开后只有空白的窗口
* 2016.06.22
* 增加窗口打开后的重定位动画
* 增加当窗口大小改变后的重定位功能
* 解决在IE下多次打开弹出窗口后,窗口里的输入框无法获得焦点
* 2016.08.09
* 重构代码
* 使用bootstrap3-3.3.7版本的bootstrap-modal.js的模态窗口代码单独提取出来使用
* 解决多级弹出的窗口和遮罩的层次显示顺序问题
* 增加背景遮罩点击后显示窗口抖动的动画效果
* 2017.01.26
* 增加fullWidth参数,设置是否为全宽度窗口,默认为false(关闭)
* 2017.03.27
* 增加customClass参数,允许使用样式对弹出框整体样式进行定义
* 2017.06.14
* 重构bDialog代码
* 2017.06.20
* 修复内容区域高度设置误差问题
* 适配Bootstrap3版本
* 修复部分参数丢失的问题
* 2017.07.20
* 修复窗口最小高度限制问题
* 2017.07.24
* 修复Bootstrap3下样式应用无效果问题
* 统一处理Bootstrap2、3的窗口高度计算
* 修复Bootstrap3下全宽度窗口没有铺满全宽度的问题
* 2017.08.06
* 增加窗口最大化功能
* 增加dialogMaxButton配置项目,设置是否启用最大化窗口按钮,默认:true
* 修正部分样式问题
* 2017.08.19(2.0)
* 修复窗口最大化后,内部iframe高度没有最大化的问题
* 重构代码结构
* 增加窗口打开后的动画效果
* 增加国际化多语言支持
* 增加bDialog.alert()对话框模式,支持info、warning、error、success、confirm五种模式
* 增加bDialog.mask()遮罩模式
* 修改原bDialog.closeCurrent方法的函数名为bDialog.close
* 2017.09.16(2.1)
* 增加带文本输入框的Alert confirm消息对话窗口
* 增加Alert模式下回车键关闭窗口的功能
* 增加Toast边角显示的通知窗口,支持info, warning, error, success以及六个角落显示的功能
* 修复部分Bug
*/
/* ========================================================================
* Bootstrap: modal.js v3.3.7
* http://getbootstrap.com/javascript/#modals
* ========================================================================
* Copyright 2011-2016 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
*
* 整合bootstrap - v3.3.7的Modal插件
* ======================================================================== */
+function(d){var b=function(f,e){this.options=e;this.$body=d(document.body);this.$element=d(f);this.$dialog=this.$element.find(".modal-dialog");this.$backdrop=null;this.isShown=null;this.originalBodyPad=null;this.scrollbarWidth=0;this.ignoreBackdropClick=false;if(this.options.remote){this.$element.find(".modal-content").load(this.options.remote,d.proxy(function(){this.$element.trigger("loaded.bs.modal")},this))}};b.VERSION="3.3.7";b.TRANSITION_DURATION=300;b.BACKDROP_TRANSITION_DURATION=150;b.DEFAULTS={backdrop:true,keyboard:true,show:true};b.prototype.toggle=function(e){return this.isShown?this.hide():this.show(e)};b.prototype.show=function(h){var f=this;var g=d.Event("show.bs.modal",{relatedTarget:h});this.$element.trigger(g);if(this.isShown||g.isDefaultPrevented()){return}this.isShown=true;this.checkScrollbar();this.setScrollbar();this.$body.addClass("modal-open");this.escape();this.resize();this.$element.on("click.dismiss.bs.modal",'[data-dismiss="modal"]',d.proxy(this.hide,this));this.$dialog.on("mousedown.dismiss.bs.modal",function(){f.$element.one("mouseup.dismiss.bs.modal",function(i){if(d(i.target).is(f.$element)){f.ignoreBackdropClick=true}})});this.backdrop(function(){var j=d.support.transition&&f.$element.hasClass("fade");if(!f.$element.parent().length){f.$element.appendTo(f.$body)}f.$element.show().scrollTop(0);f.adjustDialog();if(j){f.$element[0].offsetWidth}f.$element.addClass("in");f.enforceFocus();var i=d.Event("shown.bs.modal",{relatedTarget:h});j?f.$dialog.one("bsTransitionEnd",function(){f.$element.trigger("focus").trigger(i)}).emulateTransitionEnd(b.TRANSITION_DURATION):f.$element.trigger("focus").trigger(i)})};b.prototype.hide=function(f){if(f){f.preventDefault()}f=d.Event("hide.bs.modal");this.$element.trigger(f);if(!this.isShown||f.isDefaultPrevented()){return}this.isShown=false;this.escape();this.resize();d(document).off("focusin.bs.modal");this.$element.removeClass("in").off("click.dismiss.bs.modal").off("mouseup.dismiss.bs.modal");this.$dialog.off("mousedown.dismiss.bs.modal");d.support.transition&&this.$element.hasClass("fade")?this.$element.one("bsTransitionEnd",d.proxy(this.hideModal,this)).emulateTransitionEnd(b.TRANSITION_DURATION):this.hideModal()};b.prototype.enforceFocus=function(){d(document).off("focusin.bs.modal").on("focusin.bs.modal",d.proxy(function(f){if(document!==f.target&&this.$element[0]!==f.target&&!this.$element.has(f.target).length){this.$element.trigger("focus")}},this))};b.prototype.escape=function(){if(this.isShown&&this.options.keyboard){this.$element.on("keydown.dismiss.bs.modal",d.proxy(function(f){f.which==27&&this.hide()},this))}else{if(!this.isShown){this.$element.off("keydown.dismiss.bs.modal")}}};b.prototype.resize=function(){if(this.isShown){d(window).on("resize.bs.modal",d.proxy(this.handleUpdate,this))}else{d(window).off("resize.bs.modal")}};b.prototype.hideModal=function(){var e=this;this.$element.hide();this.backdrop(function(){e.$body.removeClass("modal-open");e.resetAdjustments();e.resetScrollbar();e.$element.trigger("hidden.bs.modal")})};b.prototype.removeBackdrop=function(){this.$backdrop&&this.$backdrop.remove();this.$backdrop=null};b.prototype.backdrop=function(i){var h=this;var f=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var e=d.support.transition&&f;this.$backdrop=d(document.createElement("div")).addClass("modal-backdrop "+f).appendTo(this.$body);this.$element.on("click.dismiss.bs.modal",d.proxy(function(j){if(this.ignoreBackdropClick){this.ignoreBackdropClick=false;return}if(j.target!==j.currentTarget){return}this.options.backdrop=="static"?this.$element[0].focus():this.hide()},this));if(e){this.$backdrop[0].offsetWidth}this.$backdrop.addClass("in");if(!i){return}e?this.$backdrop.one("bsTransitionEnd",i).emulateTransitionEnd(b.BACKDROP_TRANSITION_DURATION):i()}else{if(!this.isShown&&this.$backdrop){this.$backdrop.removeClass("in");var g=function(){h.removeBackdrop();i&&i()};d.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one("bsTransitionEnd",g).emulateTransitionEnd(b.BACKDROP_TRANSITION_DURATION):g()}else{if(i){i()}}}};b.prototype.handleUpdate=function(){this.adjustDialog()};b.prototype.adjustDialog=function(){var e=this.$element[0].scrollHeight>document.documentElement.clientHeight;this.$element.css({paddingLeft:!this.bodyIsOverflowing&&e?this.scrollbarWidth:"",paddingRight:this.bodyIsOverflowing&&!e?this.scrollbarWidth:""})};b.prototype.resetAdjustments=function(){this.$element.css({paddingLeft:"",paddingRight:""})};b.prototype.checkScrollbar=function(){var f=window.innerWidth;if(!f){var e=document.documentElement.getBoundingClientRect();f=e.right-Math.abs(e.left)}this.bodyIsOverflowing=document.body.clientWidth<f;this.scrollbarWidth=this.measureScrollbar()};b.prototype.setScrollbar=function(){var e=parseInt((this.$body.css("padding-right")||0),10);this.originalBodyPad=document.body.style.paddingRight||"";if(this.bodyIsOverflowing){this.$body.css("padding-right",e+this.scrollbarWidth)}};b.prototype.resetScrollbar=function(){this.$body.css("padding-right",this.originalBodyPad)};b.prototype.measureScrollbar=function(){var f=document.createElement("div");f.className="modal-scrollbar-measure";this.$body.append(f);var e=f.offsetWidth-f.clientWidth;this.$body[0].removeChild(f);return e};function c(e,f){return this.each(function(){var i=d(this);var h=i.data("bs.modal");var g=d.extend({},b.DEFAULTS,i.data(),typeof e=="object"&&e);if(!h){i.data("bs.modal",(h=new b(this,g)))}if(typeof e=="string"){h[e](f)}else{if(g.show){h.show(f)}}})}var a=d.fn.modal;d.fn.modal=c;d.fn.modal.Constructor=b;d.fn.modal.noConflict=function(){d.fn.modal=a;return this};d(document).on("click.bs.modal.data-api",'[data-toggle="modal"]',function(j){var i=d(this);var g=i.attr("href");var f=d(i.attr("data-target")||(g&&g.replace(/.*(?=#[^\s]+$)/,"")));var h=f.data("bs.modal")?"toggle":d.extend({remote:!/#/.test(g)&&g},f.data(),i.data());if(i.is("a")){j.preventDefault()}f.one("show.bs.modal",function(e){if(e.isDefaultPrevented()){return}f.one("hidden.bs.modal",function(){i.is(":visible")&&i.trigger("focus")})});c.call(f,h,this)})}(window.top.jQuery.fn.modal&&typeof(window.top.jQuery.fn.modal.Constructor.VERSION)=='string'?jQuery:window.top.jQuery);
;(function($){
"use strict";
//模板
var template = {
dialog : '<div class="modal hide bDialog" dialog="bDialog" tabindex="-1" aria-labelledby="bDialogHeaderLabel" role="dialog" aria-hidden="true">' +
'<div class="modal-dialog" role="document">' +
'<div class="modal-content">' +
'<div class="modal-header bDialogHeader">' +
'<button type="button" class="close bDialogCloseButton" data-dismiss="modal" aria-hidden="true">×</button>' +
'<button type="button" class="close maximize bDialogMaxButton" data-dismiss="modal" aria-hidden="true">□</button>' +
'<h3 class="bDialogHeaderLabel"></h3>' +
'</div>' +
'<div class="modal-body bDialogBody"></div>' +
'<div class="modal-footer bDialogFooter hide"> </div>' +
'</div></div></div>',
message : '<div class="bDialogAlert"><div class="messageContent"></div>' +
'<div class="bDialogButtons"><button type="button" class="btn bDialogOk"></button>' +
'<button type="button" class="btn bDialogCancel"></button></div>' +
'</div>',
mask : '<div class="bDialogMaskContent"><div class="bDialogTimer"></div><div class="messageContent"></div></div>',
toast : '<div class="bDialogToastContent"><button type="button" class="bDialogToastClose">×</button>' +
'<div class="bDialogToastIcon"><i></i></div>' +
'<div class="messageContent"><h3></h3><p></p></div>' +
'</div>'
};
//默认参数
var defaults = {
/**
* 窗口背景遮罩设置
* 'static':静态模式窗口,鼠标点击背景不关闭窗口
* false:不显示背景遮罩
* true,显示背景遮罩,但鼠标点击遮罩会关闭窗口
* @type string | boolean
*/
'backdrop' : 'static',
/**
* 标题栏显示文本,设置为false则关闭标题栏
* @type string | boolean
*/
'title' : '对话框',
/**
* 使用的语言
* @type string 默认'cn'
*/
'language' : 'cn',
/**
* 窗口宽度
* @type number
*/
'width' : 700,
/**
* 窗口高度
* @type number
*/
'height' : 400,
/**
* 窗口打开时的动画效果
* @type boolean 默认 true
*/
'animation' : true,
/**
* 窗口标题栏的关闭按钮是否启用
* @type boolean
*/
'dialogCloseButton' : true,
/**
* 窗口标题栏的最大化按钮是否启用
* @type boolean
*/
'dialogMaxButton' : true,
/**
* 对话框底部的关闭窗口按钮
* @type boolean
*/
'closeButton' : false,
/**
* 是否显示滚动条,默认显示
* @type boolean
*/
'scroll' : true,
/**
* 是否允许窗口进行拖拽
* @type boolean
* 该功能需要引入jquery-ui的draggable功能库
*/
'drag' : true,
/**
* 需要在窗口中打开窗口的链接地址
* @type string
*/
'url' : false,
/**
* 需要在窗口里显示的HTML DOM内容
* 如果设置了dom参数,则优先设置,插件不会再加载url所指定的内容
* @type object
*/
'dom' : undefined,
/**
* 是否展示全宽度窗口
* @type boolean
*/
'fullWidth' : false,
/**
* 自定义样式,它会添加到弹出窗口的最外层DIV上
* @type string
*/
'customClass' : undefined,
/**
* 初始化时即显示模态对话框
* @type boolean
*/
'show' : false,
/**
* 显示对话框前执行的回调
* @type function
*/
'onShow' : undefined,
/**
* 显示完成对话框后执行的回调
* @type function
*/
'onShowed' : undefined,
/**
* 关闭/隐藏对话框前执行的回调
* @type function
*/
'onHide' : undefined,
/**
* 关闭/隐藏对话框后执行的回调
* @type function
*/
'onHidden' : undefined,
/**
* 窗口回调函数,参数1:回调后返回的数据(callback(data))
* @type function
*/
'callback' : undefined,
/**
* 对话框模式,该参数为内部参数,不接受用户传递
* @type string 窗口类型
* @access private
* @enum 'dialog' 模态窗口
* @enum 'alert' 消息提示框
* @enum 'mask' 遮罩
* @enum 'toast' 边角弹出菜单
*/
'type' : 'dialog',
/**
* 消息对话框模式的提示信息文本内容,仅内部使用,不接受用户传递
* @type string
* @access private
*/
'message' : undefined,
/**
* 消息对话框类型
* @type string
* @enum 'info' 消息提示(默认)
* @enum 'warning' 警告
* @enum 'error' 错误
* @enum 'success' 成功
* @enum 'confirm' 确认
*/
'messageType' : 'info',
/**
* 窗口显示位置,仅在type:toast模式下可用
* @type string
* @enum 'topLeft' 左上角
* @enum 'topCenter' 正上方
* @enum 'topRight' 右上角
* @enum 'bottomLeft' 左下角
* @enum 'bottomCenter' 底部正下方
* @enum 'bottomRight' 右下角(默认)
*/
'position' : 'bottomRight',
/**
* 自动关闭窗口的时间,单位:秒,仅在type:toast模式下可用
* 设置0关闭自动关闭窗口功能
* @type number
*/
'closeTime' : 3,
/**
* confirm模式下,取消按钮的执行回调
* @type function
* @example
* cancel : function(dialog){}
*/
'cancel' : undefined
};
/**
* bDialog对象
* @param p
* @returns {bDialog} 返回窗口对象
*/
var bDialog = function(p){
//合并参数
this.params = this.setParam(p);
this.message = null;
this.setLanguage();
this.buildDialog();
this.timeout = null;
this.callback = null;
//用于确认窗口的取消按钮回调处理
this.cancalCallback = false;
this.returnData = null;
this.bindEvent();
this.openDialog();
this.setCssStyle();
this.atLast();
$(this.dialog).data('bDialog',this);
return this;
};
//版本号
bDialog.version = "2.1"
/**
* 合并默认参数与用户传递参数
* @param {object} param - 用户传递参数集
* @return {object} 合并后参数集
*/
bDialog.prototype.setParam = function(param){
return $.extend({},defaults,param);
};
/**
* 设置国际化多语言
*/
bDialog.prototype.setLanguage = function(){
var p = this.params;
var message = {};
switch (p.language){
case 'cn':
message = {
titleInfo : '提示',
titleWarning : '警告',
titleError : '错误',
titleSuccess : '成功',
titleConfirm : '确认',
btnOk : '确认',
btnCancel : '取消',
maskText : '数据加载中……'
};
break;
case 'en':
message = {
titleInfo : 'information',
titleWarning : 'warning',
titleError : 'error',
titleSuccess : 'success',
titleConfirm : 'confirmation',
btnOk : 'OK',
btnCancel : 'Cancel',
maskText : 'Loading……'
};
break;
case 'jp':
message = {
titleInfo : 'ヒント',
titleWarning : '警告',
titleError : '間違った',
titleSuccess : '成功',
titleConfirm : '確認',
btnOk : '確認',
btnCancel : 'キャンセル',
maskText : 'データロード……'
};
break;
}
this.message = message;
};
/**
* 生成窗口对象
* @return {object} 生成完成的窗口对象
*/
bDialog.prototype.buildDialog = function(){
var p = this.params,self = this;
var html = template.dialog;
var dialog = $(html);
var topBody = window.top.document.body;
//在浏览器尺寸改变时使用的定时器
self.timeout = null;
//设置标题
if(p.title) $("h3.bDialogHeaderLabel",$(dialog)).html(p.title);
else $('div.bDialogHeader',$(dialog)).hide();
if(!p.dialogCloseButton)$('button.bDialogCloseButton',$(dialog)).hide();
if(!p.dialogMaxButton)$('button.bDialogMaxButton',$(dialog)).hide();
//if(p.animation) $(dialog).addClass('fade');//设置动画效果(bootstrap modal默认动画效果)
if(p.closeButton){
$("div.bDialogFooter",$(dialog)).empty().append('<button class="btn btn-inverse" data-dismiss="modal" aria-hidden="true">关闭</button>');
$("div.bDialogFooter",$(dialog)).show();
}
if(p.dom){//页面片断模式
var content = $(p.dom).clone(true);
$("div.bDialogBody",$(dialog)).html($(content).show());
if(p.scroll) $("div.bDialogBody",$(dialog)).css('overflow-y','auto');
}else if(p.url) {//iframe模式
var tmp = p.scroll ? 'yes' : 'no';
var iframe = '<iframe class="bDialogBodyFrame" frameborder="0" scrolling="'+tmp+'" style="width:100%;height:100%;border:0px;" src="'+p.url+'"></iframe>';
$("div.bDialogBody",$(dialog)).html(iframe);
}
//对话框模式特殊处理
if(p.type === 'alert'){
$('button.bDialogOk',dialog).html(this.message.btnOk);
$('button.bDialogCancel',dialog).html(this.message.btnCancel);
if(p.title !== false){
var atitle = '';
switch(p.messageType){
case 'info':
atitle = this.message.titleInfo;
break;
case 'warning':
atitle = this.message.titleWarning;
break;
case 'error':
atitle = this.message.titleError;
break;
case 'success':
atitle = this.message.titleSuccess;
break;
case 'confirm':
case 'inputConfirm':
atitle = this.message.titleConfirm;
break;
}
$("h3.bDialogHeaderLabel",dialog).html(atitle);
}
}
if(p.type === 'mask'){
var msg = p.message ? p.message : this.message.maskText;
$('div.messageContent',dialog).html(msg);
$(dialog).addClass('bDialogMask');
}
if(p.type === 'toast'){
$(dialog).addClass('bDialogToast');
$(dialog).addClass(p.position);
var cName = '';
switch(p.messageType){
case 'warning':
cName = 'toastWarning';
break;
case 'error':
cName = 'toastError';
break;
case 'success':
cName = 'toastSuccess';
break;
case 'info':
default:
cName = 'toastInfo';
break;
}
$("div.bDialogToastContent",dialog).addClass(cName);
}
//设置全宽度内容
if(p.fullWidth){
$("div.bDialogHeader,div.bDialogBody,div.bDialogFooter",$(dialog)).addClass('container');
$(dialog).addClass('fullWidth');
p.width = '100%';
}
//自定义样式
if(p.customClass) $(dialog).addClass(p.customClass);
$(topBody).append(dialog);
this.dialog = dialog;
};
/**
* 为窗口对象绑定事件
* @return void
*/
bDialog.prototype.bindEvent = function(){
var p = this.params,dialog = this.dialog;
var self = this;
var topBody = window.top.document.body;
var setReturnData = function(){
var d = {"results" : null};
if(self.returnData)
d.results = $.isArray(self.returnData) ? self.returnData : [self.returnData];
return d;
}
self.callback = function(){
if(p.cancel && $.isFunction(p.cancel) && self.cancalCallback) p.cancel(dialog);
else if(p.callback && $.isFunction(p.callback)) p.callback(setReturnData());
};
if(p.onShow && $.isFunction(p.onShow)) $(dialog).off('show.bs.modal').on('show.bs.modal',function(){
p.onShow(self);
});
$(dialog).off('shown.bs.modal').on('shown.bs.modal',function(e){
e.stopPropagation();
if(p.onShowed && $.isFunction(p.onShowed)) p.onShowed(self);
if(p.animation && !p.fullWidth) $('div.modal-content',dialog).addClass('bDialogOpen');
});
if(p.onHide && $.isFunction(p.onHide)) $(dialog).off('hide.bs.modal').on('hide.bs.modal',function(){
p.onHide(self);
});
$(dialog).off('hidden.bs.modal').on('hidden.bs.modal',function(e){
e.stopPropagation();
// stop the timeout
clearTimeout(self.timeout);
//在移除窗口之前,先把iframe移除,解决在IE下,窗口上的输入控件获得不了焦点的问题
if($('iframe',$(dialog)).size() > 0) $('iframe',$(dialog)).remove();
$(dialog).remove();
if($('[dialog="bDialog"]',$(topBody)).size() > 0) $('[dialog="bDialog"]:last',$(topBody)).addClass('dialogInActive');
if(p.onHidden && $.isFunction(p.onHidden)) p.onHidden(self);
if(self.callback && $.isFunction(self.callback)) self.callback();
});
if(p.dialogMaxButton){
$('button.bDialogMaxButton',dialog).off('click.bDialog').on('click.bDialog',function(e){
e.stopPropagation();
self.maxWindow();
});
}
if(p.type !== 'mask' && p.type !== 'toast' && !p.fullWidth){
$(dialog).off('click.bDialog').on('click.bDialog',function(e){
e.stopPropagation();
var srcEl = e.target || e.srcElement;
if($(srcEl).is('div.bDialog')){
$(dialog).removeClass('animated').removeClass('shake');
setTimeout(function(){
$(dialog).addClass('animated').addClass('shake');
}, 0);
}
});
}
//浏览器窗口尺寸变化时,自动对窗口位置进行调整
if(p.type !== 'toast'){
$(window.top).on('resize.bDialog', function(e) {
e.stopPropagation();
// clear a previously set timeout
// this will ensure that the next piece of code will not be executed on every step of the resize event
clearTimeout(self.timeout);
// set a small timeout before doing anything
self.timeout = setTimeout(function() {
// reposition the dialog box
self.rePosition();
}, 100);
});
}
};
/**
* 在页面上弹出窗口
* @return void
*/
bDialog.prototype.openDialog = function(){
var p = this.params,dialog = this.dialog;
$('div.modal-dialog',dialog).css({
'width' : p.width,
'height' : p.height
});
var param = {
backdrop : p.backdrop,
show : true
};
if($.type(p.keyboard) !== 'undefined') param.keyboard = p.keyboard;
$(dialog).modal(param).removeClass('hide');
};
/**
* 处理窗口的样式、宽度高度及位置等内容
* @return void
*/
bDialog.prototype.setCssStyle = function(){
var p = this.params,dialog = this.dialog;
/**
* 处理层级顺序及遮罩层级顺序
*/
var topBody = window.top.document.body;
var setSize = $('div.modal-backdrop',$(topBody)).size();
var baseNumber = 1000;
var stepNumber = (setSize -1) * 20;
$('div.modal-backdrop:last',$(topBody)).css('z-index', baseNumber + stepNumber + 10 );
$('div.bDialog:last div.modal-content',$(topBody)).css('z-index', baseNumber + stepNumber + 20 );
$('div.bDialog:last',$(topBody)).css('z-index', baseNumber + stepNumber + 19 );
if(setSize > 1) $('div.modal-backdrop:last',$(topBody)).css('opacity','0.1');
this.adjust();
//清除所有已弹出窗口的当前激活样式
$('[dialog="bDialog"]',$(topBody)).removeClass('dialogInActive');
$(dialog).addClass('dialogInActive');
};
/**
* 调整窗口的内部外部的高度,宽度等内容
*/
bDialog.prototype.adjust = function(){
var p = this.params,dialog = this.dialog;
/**
* 处理窗口内部高度样式-----------------------------
*/
var totalHeight = $('div.modal-dialog',$(dialog)).innerHeight();
var head = p.title ? $("div.bDialogHeader",$(dialog)).outerHeight(true) : 0;
var footer = p.closeButton ? $("div.bDialogFooter",$(dialog)).outerHeight(true) : 0;
var bodyPaddingTop = parseFloat($("div.bDialogBody",$(dialog)).css('padding-top'));
var bodyPaddingBottom = parseFloat($("div.bDialogBody",$(dialog)).css('padding-bottom'));
var newBodyHeight = totalHeight - head - footer;// - bodyPaddingTop - bodyPaddingBottom;
var minBodyHeight = 80 - head - footer;//窗口最小高度
if(newBodyHeight < minBodyHeight) newBodyHeight = minBodyHeight;
var bodyCss = {'height':newBodyHeight,'max-height':newBodyHeight};
$("div.bDialogBody",$(dialog)).css(bodyCss);
//若是iFrame模式则设置iFrame高度等样式
if(!p.dom){
var frameHeight = newBodyHeight - bodyPaddingTop - bodyPaddingBottom;
var minFrameHeight = 80 - bodyPaddingTop - bodyPaddingBottom;
if(frameHeight < minFrameHeight) frameHeight = minFrameHeight;
var bodyFrameCss = {'height':frameHeight,'max-height':frameHeight};
$("iframe.bDialogBodyFrame",$(dialog)).css(bodyFrameCss);
}
if(p.fullWidth) $(dialog).css('padding-right','0px');
if(p.type == 'toast'){
var dlgBox = $('div.modal-dialog',$(dialog));
var t,l,r,b;
if(p.position === 'topRight' || p.position === 'bottomRight')
l = (parseFloat(dlgBox.css('left')) - 20) + 'px';
if(p.position === 'topLeft' || p.position === 'bottomLeft')
r = (parseFloat(dlgBox.css('right')) - 20) + 'px';
if(p.position === 'topLeft' || p.position === 'topRight')
b = (parseFloat(dlgBox.css('bottom')) - 25) + 'px';
if(p.position === 'bottomLeft' || p.position === 'bottomRight')
t = (parseFloat(dlgBox.css('top')) - 20) + 'px';
var offset = {};
switch(p.position){
case 'topLeft':
offset = { right : r,bottom : b};
break;
case 'topCenter':
l = ($(window.top).width() - p.width - 40) / 2;
b = $(window.top).height() - p.height - 25 - 12;
offset = { left : l, right : l, bottom : b};
break;
case 'topRight':
offset = { left : l,bottom : b};
break;
case 'bottomLeft':
offset = { right : r,top : t};
break;
case 'bottomCenter':
l = ($(window.top).width() - p.width - 40) / 2;
t = $(window.top).height() - p.height - 20 - 12;
offset = { top : t, right : l, left : l};
break;
case 'bottomRight':
offset = { left : l,top : t};
break;
}
$(dialog).css(offset);
}
};
/**
* 最后的一些处理
*/
bDialog.prototype.atLast = function(){
var p = this.params,dialog = this.dialog, self = this;
var msie = navigator.userAgent.indexOf("MSIE") !== -1 || navigator.userAgent.indexOf("Trident") !== -1;
//执行一次窗口位置定位
if(p.type !== 'toast') this.rePosition(0);
//处理窗口拖拽
if(p.drag && $.fn.draggable && !msie && !p.fullWidth) $(dialog).draggable({handle:"div.bDialogHeader"});
if(p.type === 'alert'){
if(p.messageType === 'inputConfirm') $('.inputConfirm',dialog).focus();
else $('.bDialogOk',dialog).focus();
}else $(dialog).focus();
if(p.type === 'toast' && p.closeTime > 0){
setTimeout(function(){
self.close();
},p.closeTime * 1000);
}
};
/**
* 关闭窗口
* @param data 向调用者回传的数据
*/
bDialog.prototype.close = function(data){
var dialog = this.dialog,self = this;
self.returnData = data;
var modal = dialog.data('bs.modal');
if(modal) modal.hide();
};
/**
* 最大化窗口
*/
bDialog.prototype.maxWindow = function(){
var dialog = this.dialog;
if(!dialog.max){
$(dialog).addClass('maximize');
dialog.max = true;
}else{
$(dialog).removeClass('maximize');
dialog.max = false;
}
this.adjust();
this.rePosition(0);
};
/**
* 重新定位窗口位置(主要是处理垂直高度居中)
* @param {number} speed - 动画速度
* @return void
*/
bDialog.prototype.rePosition = function(speed) {
var
dialog = this.dialog,
//获得可视区域的宽度和高度
viewport_width = $(window.top).width(),
viewport_height = $(window.top).height(),
//获得对话框的宽度和高度
dialog_width = $('div.modal-dialog',$(dialog)).width(),
dialog_height = $('div.modal-dialog',$(dialog)).height(),
//计算位置内容
values = {
'left': 0,
'top': 0,
'right': viewport_width - dialog_width,
'bottom': viewport_height - dialog_height,
'center': (viewport_width - dialog_width) / 2,
'middle': (viewport_height - dialog_height) / 2
};
dialog.dialog_top = values['middle'];
// position the dialog box and make it visible
/*
$(main).css({
'top': main.dialog_top,
'visibility': 'visible',
'opacity': 0
}).animate({'opacity': 1}, 0);
*/
//停止正在执行的动画
$('div.modal-dialog',$(dialog)).stop(true);
$('div.modal-dialog',$(dialog)).css('visibility', 'visible').animate({
'top': dialog.dialog_top
}, (undefined !== $.type(speed) && $.type(speed) == 'number') ? speed : 100);
};
/**
* 窗口工具集
*/
var bDialogTools = {
/**
* 获得当前获得焦点的窗口对象
*/
getDialog : function(){
var dlg = $('[dialog="bDialog"].dialogInActive',window.top.document.body);
return dlg ? dlg.data('bDialog') : null;
},
/**
* 字符串截取,允许中英文混合(一个中文长度为2)
* @param str
* @param n
* @returns {*}
*/
sub : function(str,n){
var r=/[^\x00-\xff]/g;
if(str.replace(r,"mm").length<=n){return str;}
var m=Math.floor(n/2);
for(var i=m;i<str.length;i++){
if(str.substr(0,i).replace(r,"mm").length>=n){
return str.substr(0,i)+"...";
}
}
return str;
}
};
var Plugin = {
/**
* 打开模态窗口
* @param param 参数集
* @returns {bDialog} 返回窗口对象
*/
open : function(param){
return new bDialog(param);
},
/**
* 关闭当前弹出窗口
* @param data 向调用者回传的数据
* @param dialog 窗口对象(非必传参数)
*/
close : function(data,dialog){
var result,dlg;
if(data instanceof bDialog){
dlg = data;
result = null;
}else{
result = data;
dlg = dialog ? dialog : bDialogTools.getDialog();
}
if(dlg) dlg.close(result);
},
/**
* 获得弹出窗口对象
* @returns {object} 返回窗口对象
*/
getDialog : function(){
return bDialogTools.getDialog();
},
/**
* 获得选择器中的传递参数
* @returns {object} 返回窗口传递参数
*/
getDialogParams : function(){
var dlg = bDialogTools.getDialog();
return dlg ? dlg.params.params : null;
},
/**
* 打开消息对话框
* @param message 显示的文本内容
* @param callback 回调函数
* @param param 初始化参数
* @returns {bDialog} 窗口对象
*/
alert : function(message,callback,param){
if(!message) return;
var html = template.message;
var content = $(html);
var className = 'alertInfo';
if(!param) param = {};
var type = param && param.messageType ? param.messageType : '';
switch (type){
case 'error':
className = "alertError";
break;
case 'warning':
className = "alertWarning";
break;
case 'success':
className = "alertSuccess";
break;
case 'confirm':
case 'inputConfirm':
className = "alertConfirm";
$('.bDialogCancel',content).show().on('click.bDialog',function(){
var dlg = bDialogTools.getDialog();
dlg.cancalCallback = true;
dlg.close();
});
break;
case 'info':
default:
className = 'alertInfo'
param.messageType = 'info';
break;
}
$(content).addClass(className);
$('.messageContent',content).html(message);
if(type === 'inputConfirm'){
$('.messageContent',content).append('<input type="text" class="inputConfirm">');
$('.inputConfirm',content).on('input',function(){
if($(this).val()) $(this).removeClass('inputRequire');
}).keydown(function(e){
e.stopPropagation();
var key = e.keyCode;
if(key == 13){
var main = $(this).closest('div.bDialogAlert');
$('.bDialogOk',main).trigger('click');
e.preventDefault();
}
});
}
$('.bDialogOk',content).on('click.bDialog',function(e){
e.stopPropagation();
e.preventDefault();
var dlg = $(this).closest('div.bDialog').data('bDialog');
//alert(type);
if(type === 'inputConfirm'){
var main = $(this).closest('div.bDialogAlert');
var result = $('.inputConfirm',main).val();
if(result) Plugin.close(result,dlg);
else{
$('.inputConfirm',main).addClass('inputRequire');
}
}else Plugin.close(dlg);
});
param.dom = content;
if(callback && $.isFunction(callback)) param.callback = callback;
//param.title = false;
param.dialogCloseButton = false;
param.dialogMaxButton = false;
param.scroll = false;
param.type = 'alert';
param.width = message.length > 70 ? 700 : 450;
param.height = message.length > 70 ? 400 : $.type(param.title)=='undefined'||$.type(param.title)=='string' ? 210 : 180;
return new bDialog(param);;
},
/**
* 遮罩功能
* @param message 遮罩上显示的文字,不传递则使用默认文本
* @param param 插件参数
* @returns {bDialog} 返回插件对象
*/
mask : function(message,param){
var html = template.mask;
var content = $(html);
if(message) message = bDialogTools.sub(message,65);
if(!param) param = {};
param.title = false;
param.scroll = false;
param.type = 'mask';
param.width = 300;
param.height = 50;
param.message = message;
param.dom = content;
param.keyboard = false;
return new bDialog(param);
},
/**
* 边角弹出的提示窗口
* @param message 需要显示的信息
* @param param 设置参数
* @returns {bDialog} 返回插件对象
*/
toast : function(message,param){
if(!message) return;
var html = template.toast;
var content = $(html),className = '',titleStr = '',title = '';
message = bDialogTools.sub(message,56);
$('.messageContent p',content).html(message);
if(!param) param = {};
var type = param.messageType ? param.messageType : '';
switch (type){
case 'error':
className = "icon-roundclose";
titleStr = '错误';
break;
case 'warning':
className = "icon-warn";
titleStr = '警告';
break;
case 'success':
className = "icon-roundcheck";
titleStr = '成功';
break;
case 'info':
default:
className = 'icon-info'
titleStr = '提示';
param.messageType = 'info';
break;
}
if(param.title && $.type(param.title) === 'string') title = param.title;
else if($.type(param.title) === 'undefined') title = titleStr;
else title = false;
if(title) $('.messageContent h3',content).html(title);
else $('.messageContent h3',content).hide();
$('div.bDialogToastIcon i',content).addClass('iconfont ' + className);
if(param.dialogCloseButton === false) $('button.bDialogToastClose',content).hide();
else{
$('button.bDialogToastClose',content).on('click.bDialog',function(e){
e.stopPropagation();
e.preventDefault();
var dlg = $(this).closest('div.bDialog').data('bDialog');
Plugin.close(dlg);
});
}
param.backdrop = false;
param.dom = content;
param.dialogCloseButton = false;
param.dialogMaxButton = false;
param.title = false;
param.scroll = false;
param.type = 'toast';
param.width = 300;
param.height = 80;
return new bDialog(param);
}
};
if(!window.top.bDialog) window.top.bDialog = Plugin;
if(!window.bDialog) window.bDialog = Plugin;
})(window.top.jQuery);