main.js
6 KB
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
/* main js */
var gb_main_ep = new EventProxy(),
res_load_ep = EventProxy.create('load_data_basic', 'load_tab', 'load_home_layout', 'load_home_line_panel', function () {
var eq = gb_main_ep;
// basic data end
eq.once('data-basic', g_emit('tab'));
// tabs
eq.once('tab', function () {
gb_tabs.init(
g_emit('home-layout')
);
});
//home layout
eq.once('home-layout', function () {
gb_home_layout.layout(
g_emit('home-line-panel')
);
});
//home line panel
eq.once('home-line-panel', function () {
gb_home_line_panel.init(g_emit('gps-time-refresh'));
});
//start fixed time refresh gps
eq.once('gps-time-refresh', function () {
gb_data_gps.fixedTimeRefresh();
g_emit('line-schedule-layout')();
});
//line schedule layout
eq.once('line-schedule-layout', function () {
gb_line_layout.layout(g_emit('render-sch-table'));
});
//render schedule table
eq.once('render-sch-table', function () {
gb_schedule_table.show(function () {
//加载信号状态
gb_signal_state.init();
});
//初始化gps异常判定
gb_gps_abnormal.initData();
setTimeout(function () {
//嵌入地图页面
$('li.map-panel', '#main-tab-content').load('/real_control_v2/mapmonitor/real.html');
}, 1000);
//弹出更新说明
showUpdateDescription();
});
function g_emit(id) {
console.log('g_emit [' + id + ']');
return function () {
console.log('eq.emitLater(' + id + ')');
return eq.emitLater(id);
};
}
});
$(document).on('click', '.ct-bottom-drawer-close', function () {
$(this).parents('.ct-bottom-drawer').removeClass('open');
});
function connectArr(arr, separator, transFun) {
var rs = '';
$.each(arr, function (i, item) {
if (transFun)
item = transFun(item);
rs += (separator + item);
});
return rs.substr(separator.length);
}
var gb_form_validation_opts = {
framework: 'uikit',
locale: 'zh_CN',
icon: {
valid: 'uk-icon-check',
invalid: 'uk-icon-times',
validating: 'uk-icon-refresh'
}
};
var notify_wait = function (t) {
UIkit.notify("<i class='uk-icon-spinner uk-icon-spin'></i> " + t, {
status: 'info'
});
};
var notify_succ = function (t) {
UIkit.notify("<i class='uk-icon-check'></i> " + t, {
status: 'success'
});
};
var notify_err = function (t) {
UIkit.notify("<i class='uk-icon-times'></i> " + t, {
status: 'danger'
});
};
var alt_confirm = function (content, succ, okBtn, noCenter) {
var modalEl = UIkit.modal.confirm(content, function () {
succ && succ();
modalEl.hide();
}, {
labels: {
Ok: okBtn,
Cancel: '取消'
}
, center: !noCenter
});
};
var show_wait_modal = function (text) {
var modalHtml =
'<div class="uk-modal" id="gb_wait_modal">' +
' <div class="uk-modal-dialog">' +
' <div class="uk-modal-spinner"></div>' +
' <div class="wait-modal-text">' + text + '</div>' +
' </div>' +
'</div>';
$(document.body).append(modalHtml);
return UIkit.modal('#gb_wait_modal', {
bgclose: false,
modal: false
}).show();
};
var hide_wait_modal = function () {
UIkit.modal('#gb_wait_modal').hide();
};
var isArray = function (obj) {
return Object.prototype.toString.call(obj) === '[object Array]';
};
var notify_err_form = function (t, form) {
$('.uk-alert-danger', form).remove();
$('.uk-modal-footer', form).before('<div class="uk-alert uk-alert-danger" data-uk-alert="">' +
'<a href="" class="uk-alert-close uk-close"></a>' +
'<p>' + t + '</p>' +
'</div>');
enable_submit_btn(form);
};
var enable_submit_btn = function (form) {
var subBtn = $('button[type=submit]', form);
if (subBtn) {
subBtn.removeClass('disabled').removeAttr('disabled');
}
};
var disabled_submit_btn = function (form) {
var subBtn = $('button[type=submit]', form);
if (subBtn) {
subBtn.addClass('disabled').attr('disabled', 'disabled');
}
};
function showUpdateDescription() {
//更新说明
var updateDescription = {
date: '2017-05-18',
text: '<h5>现在自定义子任务,勾选是否烂班后,烂班原因必填。</h5><h5>修复了在驾驶员请求出场时,误下发分班出场指令的问题</h5>' +
'<h5>调整了报表的弹出窗口<br>1、取消了窗口遮罩,可同时打开多个报表窗口,窗口堆叠时,点击窗口title切换堆叠顺序<br>2、鼠标按住窗口右下角,可随意改变窗口大小。<br>3、拖动窗口时,允许拖出页面之外<br><br>注意:将窗口和窗口title拖出页面外时,会面临窗口丢失的风险,过多丢失的窗口会影响到页面性能,你可以刷新页面以重置!</h5>'
};
var storage = window.localStorage
, key = 'update_' + updateDescription.date;
var text = storage.getItem(key);
if (!text) {
var modal = '<div class="uk-modal" id="update-description-modal">' +
' <div class="uk-modal-dialog">' +
' <a class="uk-modal-close uk-close"></a>' +
' <div class="uk-modal-header">' +
' <h2>' + updateDescription.date + ' 更新说明</h2></div>' + updateDescription.text +
' </div>';
show_modal('#update-description-modal', modal);
storage.setItem(key, updateDescription.text);
}
}