929 lines
30 KiB
JavaScript
929 lines
30 KiB
JavaScript
pscript.onload_Messages = function() {
|
|
var p = new PageHeader($i('message_header'),'Messages');
|
|
pscript.msg_struct = new Message();
|
|
}
|
|
|
|
pscript.onshow_Messages = function() {
|
|
pscript.msg_struct.show_inbox();
|
|
}
|
|
|
|
function Message(){
|
|
if(!this.mytabs) this.make_body();
|
|
}
|
|
|
|
Message.prototype.make_body = function() {
|
|
var me = this;
|
|
this.mytabs = new TabbedPage($i('inbox_tabs'));
|
|
$y(this.mytabs.body_area, {padding:'16px'})
|
|
|
|
me.make_inbox();
|
|
me.make_compose();
|
|
me.make_sent();
|
|
|
|
this.mytabs.tabs['Inbox'].show();
|
|
}
|
|
|
|
Message.prototype.make_inbox = function() {
|
|
var me = this;
|
|
|
|
//inbox tab
|
|
me.mytabs.add_tab('Inbox', function() {
|
|
me.inbox_lst.generate_unread_lst();
|
|
me.inbox_lst.msg_li.run();
|
|
me.cur_inbox_list = me.inbox_lst.msg_li; // for refresh
|
|
});
|
|
|
|
if(!this.inbox_lst) this.inbox_lst = new MessageList(me.mytabs.tabs['Inbox'].tab_body, 'inbox msg');
|
|
this.inbox_lst.msg_li.get_query = function() {
|
|
//me.checked_msg_lst = [];
|
|
me.all_msg = {};
|
|
this.query = repl("select distinct t1.name, t1.last_updated_on, t1.last_updated_by, t1.subject, t3.first_name, t3.file_list, t1.message_date, t1.owner, t1.message, t1.previous_updated_by from `tabMail` t1, `tabMail Participant Details` t2, `tabProfile` t3 where t1.is_main_thread='Yes' and t2.participant_name='%(user)s' and (t2.delete_status is NULL or t2.delete_status = 'No') and t1.name = t2.parent and ((t1.last_updated_by = t3.name and t1.last_updated_by!='%(user)s') or (t1.previous_updated_by = t3.name and t1.previous_updated_by!='%(user)s')) order by t1.modified desc", {'user':user});
|
|
|
|
this.query_max = repl("select distinct count(t1.name) from `tabMail` t1, `tabMail Participant Details` t2, `tabProfile` t3 where t1.is_main_thread='Yes' and t2.participant_name='%(user)s' and (t2.delete_status is NULL or t2.delete_status = 'No') and t1.name = t2.parent and ((t1.last_updated_by = t3.name and t1.last_updated_by!='%(user)s') or (t1.previous_updated_by = t3.name and t1.previous_updated_by!='%(user)s')) order by t1.modified desc", {'user':user});
|
|
}
|
|
|
|
this.inbox_lst.generate_unread_lst();
|
|
this.inbox_lst.msg_li.run();
|
|
this.inbox_lst.msg_li.onrun = function(){ me.inbox_lst.show_if_no_msg(me.inbox_lst.msg_li); }
|
|
}
|
|
|
|
Message.prototype.make_compose = function() {
|
|
var me = this;
|
|
|
|
me.mytabs.add_tab('Compose', function() {
|
|
if(!pscript.compose_msg_obj){
|
|
pscript.compose_msg_obj = new MessageThread(me.mytabs.tabs['Compose'].tab_body, me.mytabs.tabs['Inbox'], me.inbox_lst.lst_wrapper, 'My Inbox');
|
|
//pscript.compose_msg_obj.show_msg(0, me.mytabs.tabs['Compose'].tab_body, me.mytabs.tabs['Inbox'], me.inbox_lst.lst_wrapper, 'My Inbox', me.mytabs.tabs['Sent'], me.sent_lst.lst_wrapper);
|
|
}
|
|
pscript.compose_msg_obj.show_msg(0, me.mytabs.tabs['Compose'].tab_body, me.mytabs.tabs['Inbox'], me.inbox_lst.lst_wrapper, 'My Inbox', me.mytabs.tabs['Sent'], me.sent_lst.lst_wrapper);
|
|
|
|
this.cur_inbox_list = null;
|
|
});
|
|
}
|
|
|
|
Message.prototype.make_sent = function() {
|
|
var me = this;
|
|
|
|
// sent msg tab
|
|
me.mytabs.add_tab('Sent', function() {
|
|
me.sent_lst.msg_li.run();
|
|
me.cur_inbox_list = me.sent_lst.msg_li; // for refresh
|
|
});
|
|
|
|
if(!this.sent_lst) this.sent_lst = new MessageList(me.mytabs.tabs['Sent'].tab_body, 'sent msg');
|
|
this.sent_lst.msg_li.get_query = function() {
|
|
//me.checked_msg_lst = [];
|
|
me.all_msg = {};
|
|
|
|
this.query = repl("select distinct t1.name, t1.last_updated_on, t1.last_updated_by, t1.subject, t3.first_name, t3.file_list, t1.message_date, t1.owner, t1.message from `tabMail` t1, `tabProfile` t3, `tabMail Participant Details` t2 where t1.is_main_thread='Yes' and t1.last_updated_by='%(user)s' and t1.last_updated_by = t3.name and t2.participant_name = '%(user)s' and (t2.delete_status is NULL or t2.delete_status = 'No') and t2.parent = t1.name order by t1.modified desc", {'user':user});
|
|
this.query_max = repl("select distinct count(t1.name) from `tabMail` t1, `tabProfile` t3, `tabMail Participant Details` t2 where t1.is_main_thread='Yes' and t1.last_updated_by='%(user)s' and t1.last_updated_by = t3.name and t2.participant_name = '%(user)s' and (t2.delete_status is NULL or t2.delete_status = 'No') and t2.parent = t1.name order by t1.modified desc", {'user':user});
|
|
}
|
|
this.sent_lst.msg_li.run();
|
|
this.sent_lst.msg_li.onrun = function(){ me.sent_lst.show_if_no_msg(me.sent_lst.msg_li); }
|
|
}
|
|
|
|
Message.prototype.show_inbox = function(){
|
|
var me = this;
|
|
if(me.inbox_lst){
|
|
me.inbox_lst.msg_li.run();
|
|
}
|
|
me.mytabs.tabs['Inbox'].show();
|
|
}
|
|
|
|
MessageList = function(parent_tab, req_frm) {
|
|
this.checked_msg_lst = [];
|
|
this.unread_msg_lst = [];
|
|
this.all_msg = {};
|
|
this.parent_tab = parent_tab;
|
|
this.req_frm = req_frm;
|
|
this.make();
|
|
}
|
|
|
|
MessageList.prototype.make = function(){
|
|
var me = this;
|
|
|
|
this.lst_wrapper = $a(me.parent_tab, 'div');
|
|
|
|
//toolbar
|
|
this.toolbar_area = $a(this.lst_wrapper, 'div', '', {paddingTop:'12px'});
|
|
this.create_toolbar();
|
|
|
|
//no inbox msg div
|
|
this.no_lst_wrapper = $a(me.parent_tab, 'div', '', {padding:'8px',backgroundColor:'#FFE4AA'});
|
|
$dh(this.no_lst_wrapper);
|
|
|
|
//view inbox msg div
|
|
this.view_msg_wrapper = $a(me.parent_tab, 'div');
|
|
|
|
this.msg_li = new Listing("Recent Messages",1);
|
|
this.msg_li.colwidths = ['90%'];
|
|
this.msg_li.opts.no_border = 1;
|
|
this.msg_li.opts.show_empty_tab = 0;
|
|
this.msg_li.opts.no_border = 1;
|
|
|
|
this.msg_li.show_cell = function(cell,ri,ci,d) {
|
|
if(ri % 2)$y(cell,{backgroundColor:'#E1E3DE'});
|
|
if(ci ==0){
|
|
this.msg_lst = new MessagePreview(cell, me.req_frm, d[ri][0], d[ri][1], d[ri][2], d[ri][3], d[ri][4], d[ri][5], d[ri][6], d[ri][7], d[ri][8], d[ri][9], me.lst_wrapper, me.view_msg_wrapper, me.unread_msg_lst, me.all_msg);
|
|
}
|
|
}
|
|
this.msg_li.make(this.lst_wrapper);
|
|
$dh(this.msg_li.btn_area);
|
|
}
|
|
|
|
MessageList.prototype.create_toolbar = function(){
|
|
var me = this;
|
|
|
|
this.toolbar_tbl = make_table(me.toolbar_area, 1, 2, '100%', ['85%', '15%']);
|
|
|
|
this.select_all_lnk = $a($td(this.toolbar_tbl, 0, 0), 'span', 'link_type');
|
|
this.select_all_lnk.innerHTML = 'Select All';
|
|
$dh(this.select_all_lnk);
|
|
|
|
this.unselect_all_lnk = $a($td(this.toolbar_tbl, 0, 0), 'span', 'link_type');
|
|
this.unselect_all_lnk.innerHTML = 'Unselect All';
|
|
$dh(this.unselect_all_lnk);
|
|
|
|
this.select_all_lnk.onclick = function(){
|
|
$ds(me.unselect_all_lnk);
|
|
$dh(me.select_all_lnk);
|
|
for(m in me.all_msg){
|
|
me.all_msg[m].checked = true;
|
|
}
|
|
}
|
|
|
|
this.unselect_all_lnk.onclick = function(){
|
|
$ds(me.select_all_lnk);
|
|
$dh(me.unselect_all_lnk);
|
|
for(m in me.all_msg){
|
|
me.all_msg[m].checked = false;
|
|
}
|
|
}
|
|
|
|
this.delete_selected_btn = $a($td(this.toolbar_tbl, 0, 1), 'button', 'button', {align:'right'});
|
|
this.delete_selected_btn.innerHTML = 'Delete Selected';
|
|
$dh(this.delete_selected_btn);
|
|
this.delete_selected_btn.onclick = function(){
|
|
me.checked_msg_lst = [];
|
|
for(m in me.all_msg){
|
|
if(me.all_msg[m].checked == true)
|
|
me.checked_msg_lst.push(m);
|
|
}
|
|
me.delete_selected();
|
|
}
|
|
}
|
|
|
|
MessageList.prototype.show_if_no_msg = function(lst_data){
|
|
var me = this;
|
|
$dh(me.view_msg_wrapper);
|
|
|
|
if(!lst_data.has_data()){
|
|
$ds(me.no_lst_wrapper);
|
|
$dh(me.lst_wrapper);
|
|
if(me.req_frm == 'inbox msg'){
|
|
me.no_lst_wrapper.innerHTML = "You have no messages in your Inbox.";
|
|
}
|
|
else if(me.req_frm == 'sent msg'){
|
|
me.no_lst_wrapper.innerHTML = "You have no messages in your Sent messages list.";
|
|
}
|
|
} else {
|
|
$dh(me.no_lst_wrapper);
|
|
$ds(me.lst_wrapper);
|
|
$dh(me.no_lst_wrapper);
|
|
$ds(me.lst_wrapper);
|
|
$dh(this.unselect_all_lnk);
|
|
$ds(this.select_all_lnk);
|
|
$ds(this.delete_selected_btn);
|
|
}
|
|
}
|
|
|
|
MessageList.prototype.generate_unread_lst = function(){
|
|
var me = this;
|
|
|
|
var msg_callback = function(r, rt){
|
|
if(r.message.ur_lst){
|
|
me.unread_msg_lst = r.message.ur_lst;
|
|
}
|
|
}
|
|
$c('runserverobj', {doctype:'Message Control',method:'get_unread_msg_lst',arg:user}, msg_callback);
|
|
}
|
|
|
|
MessageList.prototype.delete_selected = function(){
|
|
var me = this;
|
|
|
|
if(me.checked_msg_lst.length >= 1) me.msg_li.msg_lst.delete_msg(me.checked_msg_lst);
|
|
else msgprint("error:Please select the message to delete");
|
|
}
|
|
|
|
function MessagePreview(parent, req_frm, msg_id, last_updated_on, last_updated_by, subject, first_name, profile_pic, msg_date, msg_owner, message, previous_updated_by, lst_wrapper, view_msg_wrapper, unread_msg_lst, all_msg_dict) {
|
|
this.create_structure(parent);
|
|
|
|
if(req_frm) this.req_frm = req_frm;
|
|
this.msg_id = msg_id;
|
|
this.subject = subject;
|
|
this.message = message;
|
|
this.msg_date = msg_date;
|
|
this.msg_owner = msg_owner;
|
|
this.first_name = first_name;
|
|
this.lst_wrapper = lst_wrapper;
|
|
this.view_msg_wrapper = view_msg_wrapper;
|
|
if(profile_pic) this.profile_pic = profile_pic;
|
|
if(last_updated_on) this.last_updated_on = last_updated_on;
|
|
if(last_updated_by) this.last_updated_by = last_updated_by;
|
|
if(previous_updated_by) this.previous_updated_by = previous_updated_by;
|
|
this.unread_msg_lst = unread_msg_lst;
|
|
this.all_msg = all_msg_dict;
|
|
|
|
this.show_msg_sender();
|
|
this.show_msg_subject();
|
|
this.show_delete_lnk();
|
|
}
|
|
|
|
MessagePreview.prototype.create_structure = function(parent){
|
|
this.wrapper = $a(parent,'div');
|
|
this.t = make_table(this.wrapper, 1, 4, '100%', ['5%','10%','80%','5%']);
|
|
}
|
|
|
|
MessagePreview.prototype.show_msg_sender = function(){
|
|
var me = this;
|
|
|
|
// checkbox
|
|
var chk_box = $a($td(this.t, 0, 0),'div');
|
|
if(isIE) {
|
|
chk_box.innerHTML = '<input type="checkbox" style="border: 0px">'; // IE fix
|
|
this.inp = chk_box.childNodes[0];
|
|
} else {
|
|
this.inp = $a(chk_box, 'input');
|
|
this.inp.type = 'checkbox';
|
|
}
|
|
|
|
this.inp.onclick = function() {
|
|
for(m in me.all_msg){
|
|
if(m == me.msg_id)
|
|
me.all_msg[m].checked = me.inp.checked;
|
|
}
|
|
}
|
|
|
|
me.all_msg[me.msg_id] = this.inp;
|
|
|
|
//sender or receiver
|
|
// photo
|
|
if(this.profile_pic) {
|
|
var img = $a($td(this.t, 0, 1),'img');
|
|
var img_src = this.profile_pic.split(NEWLINE)[0].split(',')[0]
|
|
img.src = repl('cgi-bin/getfile.cgi?name=%(fn)s&thumbnail=32',{fn:img_src})
|
|
}
|
|
//name
|
|
var div = $a($td(this.t, 0, 1),'div');
|
|
div.innerHTML = this.first_name;
|
|
}
|
|
|
|
MessagePreview.prototype.show_msg_subject = function() {
|
|
var me = this;
|
|
// message
|
|
var div1 = $a($td(this.t, 0, 2),'div', '', {paddingBottom:'4px'});
|
|
var sp = $a(div1,'span','link_type', {fontSize:'12px'});
|
|
sp.innerHTML = 'Sub : ' +me.subject;
|
|
|
|
var div = $a($td(this.t, 0, 2),'div', 'comment',{paddingBottom:'8px'});
|
|
div.innerHTML = 'created by: ' + me.msg_owner +' | created on: ' + dateutil.str_to_user(me.msg_date)+ ' | last updated on: ' + dateutil.str_to_user(me.last_updated_on);
|
|
|
|
if (me.req_frm == 'inbox msg' && inList(me.unread_msg_lst, me.msg_id)) {
|
|
$y(sp,{fontWeight:'bold',color:'Black'});
|
|
$y(div,{fontWeight:'bold',color:'Black'});
|
|
}
|
|
|
|
sp.style.cursor = 'pointer';
|
|
sp.msg_id = me.msg_id; sp.req_frm = me.req_frm;
|
|
|
|
sp.onclick = function() {
|
|
$dh(me.lst_wrapper);
|
|
if(this.req_frm == 'inbox msg'){
|
|
if(!pscript.inbox_msg_obj){
|
|
pscript.inbox_msg_obj = new MessageThread(me.view_msg_wrapper, pscript.msg_struct.mytabs.tabs['Inbox'], me.lst_wrapper, 'My Inbox');
|
|
}
|
|
pscript.inbox_msg_obj.show_msg(this.msg_id, me.view_msg_wrapper, pscript.msg_struct.mytabs.tabs['Inbox'], me.lst_wrapper, 'My Inbox', pscript.msg_struct.mytabs.tabs['Sent'], me.lst_wrapper);
|
|
|
|
//mark for already read
|
|
if (this.req_frm == 'inbox msg' && inList(me.unread_msg_lst,this.msg_id)) {
|
|
me.mark_as_read(this.msg_id);
|
|
}
|
|
}
|
|
else if(this.req_frm == 'sent msg'){
|
|
if(!pscript.sent_msg_obj){
|
|
pscript.sent_msg_obj = new MessageThread(me.view_msg_wrapper, pscript.msg_struct.mytabs.tabs['Sent'], me.lst_wrapper, 'My Inbox');
|
|
}
|
|
pscript.sent_msg_obj.show_msg(this.msg_id, me.view_msg_wrapper, pscript.msg_struct.mytabs.tabs['Sent'], me.lst_wrapper, 'My Inbox', pscript.msg_struct.mytabs.tabs['Sent'], me.lst_wrapper);
|
|
}
|
|
}
|
|
}
|
|
|
|
MessagePreview.prototype.mark_as_read = function(msg_id){
|
|
this.msg_id = msg_id;
|
|
var me = this;
|
|
|
|
args = {'user' : user, 'msg':this.msg_id,'read':'Yes'}
|
|
$c_obj('Message Control','read_unread_message',docstring(args),function(r,rt){
|
|
me.remove_element(me.unread_msg_lst, me.msg_id);
|
|
});
|
|
}
|
|
|
|
MessagePreview.prototype.delete_msg = function(msg_nm_lst){
|
|
this.msg_nm_lst = msg_nm_lst;
|
|
var me = this;
|
|
var delete_msg_dialog;
|
|
|
|
set_delete_msg_dialog = function() {
|
|
delete_msg_dialog = new Dialog(400, 200, 'Delete Message');
|
|
delete_msg_dialog.make_body([
|
|
['HTML', 'Message', '<div class = "comment">Are you sure, you want to delete message(s) ?</div>'],
|
|
['HTML', 'Response', '<div class = "comment" id="delete_msg_dialog_response"></div>'],
|
|
['HTML', 'Delete Msg', '<div></div>']
|
|
]);
|
|
|
|
var delete_msg_btn1 = $a($i(delete_msg_dialog.widgets['Delete Msg']), 'button', 'button');
|
|
delete_msg_btn1.innerHTML = 'Yes';
|
|
delete_msg_btn1.onclick = function(){ delete_msg_dialog.add(); }
|
|
|
|
var delete_msg_btn2 = $a($i(delete_msg_dialog.widgets['Delete Msg']), 'button', 'button');
|
|
delete_msg_btn2.innerHTML = 'No';
|
|
$y(delete_msg_btn2,{marginLeft:'4px'});
|
|
delete_msg_btn2.onclick = function(){ delete_msg_dialog.hide();}
|
|
|
|
delete_msg_dialog.onshow = function() {
|
|
$i('delete_msg_dialog_response').innerHTML = '';
|
|
}
|
|
|
|
delete_msg_dialog.add = function() {
|
|
// sending...
|
|
$i('delete_msg_dialog_response').innerHTML = 'Processing...';
|
|
var m_arg = user+ '~~' + this.msg_nm_lst;
|
|
|
|
var call_back = function(r,rt) {
|
|
if(r.message == 'true'){
|
|
$i('delete_msg_dialog_response').innerHTML = 'Message Deleted';
|
|
delete_msg_dialog.hide();
|
|
|
|
for(m=0; m<me.msg_nm_lst.length; m++){
|
|
if(inList(me.unread_msg_lst, me.msg_nm_lst[m]))
|
|
me.remove_element(me.unread_msg_lst, me.msg_nm_lst[m]);
|
|
}
|
|
pscript.msg_struct.inbox_lst.msg_li.run();
|
|
pscript.msg_struct.sent_lst.msg_li.run();
|
|
}
|
|
}
|
|
$c('runserverobj', {doctype:'Message Control',method:'delete_message',arg:m_arg}, call_back);
|
|
}
|
|
}
|
|
|
|
if(!delete_msg_dialog){
|
|
set_delete_msg_dialog();
|
|
}
|
|
delete_msg_dialog.msg_nm_lst = this.msg_nm_lst;
|
|
delete_msg_dialog.show();
|
|
}
|
|
|
|
MessagePreview.prototype.remove_element = function(arrayName, arrayElement){
|
|
for(var i=0; i<arrayName.length;i++ )
|
|
{
|
|
if(arrayName[i]==arrayElement)
|
|
arrayName.splice(i,1);
|
|
}
|
|
}
|
|
|
|
MessagePreview.prototype.show_delete_lnk = function() {
|
|
var me = this;
|
|
var div = $a($td(this.t, 0, 3), 'span', 'link_type');
|
|
div.innerHTML = 'Delete';
|
|
div.msg_id = me.msg_id;
|
|
|
|
div.onclick = function() {
|
|
me.delete_msg(me.msg_id);
|
|
}
|
|
}
|
|
|
|
MessagePart = function(parent){
|
|
var me = this;
|
|
|
|
this.parent = parent;
|
|
this.inputs = {};
|
|
|
|
me.make_header();
|
|
me.make_reply();
|
|
me.make_post();
|
|
}
|
|
|
|
MessagePart.prototype.make = function(label, ele, comment){
|
|
var me = this;
|
|
|
|
var div = $a(this.parent,'div','',{marginBottom:'12px'});
|
|
var t = make_table(div,2,1,'70%',['100%']);
|
|
|
|
if( ele == 'button'){
|
|
var element = $a($td(t,0,0), 'button');
|
|
element.innerHTML = label;
|
|
}
|
|
else {
|
|
var element = $a($td(t,1,0),ele);
|
|
|
|
// large fonts for inputs
|
|
if(in_list(['input','textarea'],ele.toLowerCase())) {
|
|
$y(element,{fontSize:'14px', width:'100%'})
|
|
}
|
|
$td(t,0,0).innerHTML = label;
|
|
}
|
|
|
|
if(comment) {
|
|
var div2 = $a(div,'div','',{fontSize:'11px', color:'#888', marginTop:'2px'});
|
|
div2.innerHTML = comment;
|
|
}
|
|
|
|
element.wrapper = div;
|
|
if(label) me.inputs[label] = element;
|
|
return element;
|
|
}
|
|
|
|
MessagePart.prototype.make_header = function(){
|
|
var me = this;
|
|
|
|
this.back_link_div = $a(me.make('','div'),'span', 'link_type', {paddingTop:'12px'});
|
|
this.back_link_div.innerHTML = 'Back to List';
|
|
|
|
me.make('To','textarea','Enter Email Ids separated by commas (,)');
|
|
$y(me.inputs['To'],{overflow :'auto', height : '50px'});
|
|
me.make('Subject','input');
|
|
}
|
|
|
|
MessagePart.prototype.make_reply = function(){
|
|
var me = this;
|
|
this.inputs.Thread = $a(this.parent, 'div', '', {margin:'16px 0px'})
|
|
}
|
|
|
|
MessagePart.prototype.make_post = function(){
|
|
var me = this;
|
|
|
|
me.make('Message','textarea');
|
|
$y(me.inputs['Message'],{height:'240px'});
|
|
|
|
// send + cancel
|
|
var d = $a(this.parent, 'div');
|
|
me.inputs.Send = $btn(d, 'Send');
|
|
me.inputs.Reply = $a(d, 'Reply')
|
|
}
|
|
|
|
MessagePart.prototype.add_header_values = function(to_list, subject){
|
|
var me = this;
|
|
|
|
//thread_participants
|
|
me.inputs['To'].value = to_list.join(',');
|
|
me.inputs['To'].disabled = true;
|
|
|
|
// subject
|
|
me.inputs['Subject'].value = subject;
|
|
me.inputs['Subject'].disabled = true;
|
|
}
|
|
|
|
MessagePart.prototype.add_reply_thread = function(thread){
|
|
var me = this;
|
|
// prev messages
|
|
var t = me.inputs['Thread'];
|
|
t.innerHTML = ''; // clear previous threads
|
|
|
|
var w = $a(t,'div','',{width:'70%'});
|
|
var tab = make_table(w,thread.length,2,'100%',['20%','80%'], {padding:'8px 0px', borderBottom:'1px solid #AAA'});
|
|
|
|
for(i=0;i<thread.length;i++) {
|
|
// ---- photo ----
|
|
if(thread[i][6]) {
|
|
var img = $a($td(tab,i,0),'img');
|
|
var img_src = thread[i][6].split(NEWLINE)[0].split(',')[0];
|
|
img.src = repl('cgi-bin/getfile.cgi?name=%(fn)s&thumbnail=32',{fn:img_src});
|
|
}
|
|
|
|
// ---- sender name ----
|
|
var d = $a($td(tab,i,0),'div','',{fontSize:'11px'});
|
|
d.innerHTML = thread[i][5];
|
|
|
|
//----- date ----
|
|
var d = $a($td(tab,i,1),'div', 'comment', {marginLeft:'8px', color:'#888', fontSize:'11px'});
|
|
d.innerHTML = dateutil.str_to_user(thread[i][3]);
|
|
|
|
//------ message ------
|
|
var d = $a($td(tab,i,1),'div', 'comment', {fontSize:'14px', marginLeft:'8px'});
|
|
d.innerHTML = replace_newlines(thread[i][1]);
|
|
$y($td(tab,i,1), {paddingBottom: '8px'});
|
|
}
|
|
}
|
|
|
|
//++++++++++++++++++++++++ Message ++++++++++++++++++++++++
|
|
|
|
MessageThread = function(parent, view_list_tab, view_list_div, req_frm) {
|
|
var me = this;
|
|
this.wrapper = $a(parent,'div');
|
|
if(!this.msg_parts) this.make(view_list_tab, view_list_div, req_frm);
|
|
}
|
|
|
|
|
|
MessageThread.prototype.add_autosuggest = function() {
|
|
var me = this;
|
|
|
|
// ---- add auto suggest ----
|
|
var opts = { script: '', json: true, maxresults: 10, timeout: 10000, delay:250, maxentries:500, cache:false};
|
|
|
|
var as = new AutoSuggest(me.msg_parts.inputs['To'], opts);
|
|
as.custom_select = function(txt, sel) {
|
|
// ---- add to the last comma ----
|
|
|
|
var r = '';
|
|
var tl = txt.split(',');
|
|
for(var i=0;i<tl.length-1;i++) r=r+tl[i]+',';
|
|
r = r+(r?' ':'')+sel+',';
|
|
if(r[r.length-1]==NEWLINE) { r=substr(0,r.length-1);}
|
|
return r;
|
|
}
|
|
|
|
// ---- override server call ----
|
|
as.doAjaxRequest = function(txt) {
|
|
var pointer = as; var q = '';
|
|
|
|
// ---- get last few letters typed ----
|
|
var last_txt = txt.split(',');
|
|
last_txt = last_txt[last_txt.length-1];
|
|
|
|
// ---- show options ----
|
|
var call_back = function(r,rt) {
|
|
as.aSug = [];
|
|
var jsondata = r.message;
|
|
for (var i=0;i<jsondata.results.length;i++) {
|
|
as.aSug.push({'id':jsondata.results[i].id, 'value':jsondata.results[i].value, 'info':jsondata.results[i].info});
|
|
}
|
|
as.idAs = "as_for_to_message";
|
|
|
|
//old create list
|
|
as.createList(as.aSug);
|
|
}
|
|
|
|
$c_obj('Message Control', 'get_to_list', (last_txt ? last_txt : '%'), call_back);
|
|
return;
|
|
}
|
|
}
|
|
|
|
MessageThread.prototype.make = function(view_list_tab, view_list_div, req_frm) {
|
|
var me = this;
|
|
|
|
me.view_list_tab = view_list_tab;
|
|
me.view_list_div = view_list_div;
|
|
me.req_frm = req_frm;
|
|
|
|
this.msg_parts = new MessagePart(me.wrapper);
|
|
|
|
this.msg_parts.back_link_div.onclick = function() {
|
|
me.hide();
|
|
|
|
if(me.in_compose) {
|
|
if(me.req_frm == 'My Inbox') { me.view_list_tab.show(); $ds(me.view_list_div); }
|
|
}
|
|
}
|
|
|
|
// autosuggest
|
|
me.add_autosuggest();
|
|
}
|
|
|
|
MessageThread.prototype.set_inbox_editor = function(editor) {
|
|
pscript.inbox_text_editor_set = 1;
|
|
}
|
|
|
|
MessageThread.prototype.view_existing_msg = function(args){
|
|
var me = this;
|
|
|
|
$c_obj('Message Control', 'get_thread_details', docstring(args),
|
|
function(r, rt){
|
|
var tl = r.message.tl;
|
|
var to_list = r.message.to_list;
|
|
|
|
//to and subject
|
|
me.msg_parts.add_header_values(to_list, tl[0][0]);
|
|
|
|
//reply thread
|
|
me.msg_parts.add_reply_thread(tl);
|
|
|
|
//post area
|
|
if(me.inbox_editor && pscript.inbox_text_editor_set == 1){
|
|
me.inbox_editor.editor.setContent('');
|
|
}
|
|
else{
|
|
me.msg_parts.inputs['Message'].value = '';
|
|
}
|
|
me.show_as(true);
|
|
}
|
|
);
|
|
}
|
|
|
|
MessageThread.prototype.view_blank_form = function(){
|
|
var me = this;
|
|
|
|
$ds(me.msg_parts.inputs['To'].wrapper);
|
|
|
|
me.msg_parts.inputs['To'].disabled = false;
|
|
me.msg_parts.inputs['To'].value = '';
|
|
|
|
me.msg_parts.inputs['Subject'].disabled = false;
|
|
me.msg_parts.inputs['Subject'].value = '';
|
|
|
|
me.msg_parts.inputs['Thread'].innerHTML = '';
|
|
|
|
if(me.inbox_editor && pscript.inbox_text_editor_set == 1){
|
|
me.inbox_editor.editor.setContent('');
|
|
}
|
|
else{
|
|
me.msg_parts.inputs['Message'].value = '';
|
|
}
|
|
me.show_as(false);
|
|
}
|
|
|
|
// msg_id = mesage id,
|
|
// parent = div/tab from where msg will be shown,
|
|
// view_list_tab = name of tab in which list will be viewed,
|
|
// view_list_div = name of div in which list will be viewed,
|
|
// req_frm = my inbox / group / event,
|
|
// show_on_send_tab = tab to be viewed on sending/replying to msg,
|
|
// show_on_send_div = div to be viewed on sending/replying to msg,
|
|
// receiver_lst = list of msg receiver
|
|
|
|
MessageThread.prototype.show_msg = function(msg_id, parent, view_list_tab, view_list_div, req_frm, show_on_send_tab, show_on_send_div, receiver_lst) {
|
|
var me = this;
|
|
|
|
// set tinymce editor
|
|
if(!me.inbox_editor) {
|
|
pscript.inbox_text_editor_set = 0;
|
|
var theme_adv_btn1 ="fontselect,fontsizeselect,formatselect,indicime,indicimehelp,emotions";
|
|
var theme_adv_btn2 ="bold,italic,underline,|,undo,redo,|,code,forecolor,backcolor,link,unlink,hr,|,sub,sup,|,charmap";
|
|
var theme_adv_btn3 = "";
|
|
|
|
me.inbox_editor = new TextAreaEditor(me.msg_parts.inputs["Message"], null, me.set_inbox_editor, theme_adv_btn1, theme_adv_btn2, theme_adv_btn3, '300px');
|
|
}
|
|
|
|
me.req_frm = req_frm;
|
|
me.receiver_lst = receiver_lst;
|
|
me.parent = parent;
|
|
me.view_list_tab = view_list_tab;
|
|
me.view_list_div = view_list_div;
|
|
me.show_on_send_tab = show_on_send_tab;
|
|
me.show_on_send_div = show_on_send_div;
|
|
me.msg_parts.inputs['Send'].btn_click = 0;
|
|
me.msg_parts.inputs['Reply'].btn_click = 0;
|
|
|
|
if(msg_id) {
|
|
this.cur_message_id = msg_id;
|
|
var args = {'user_name':user, 'cur_msg_id': this.cur_message_id};
|
|
me.view_existing_msg(args);
|
|
}
|
|
else {
|
|
this.cur_message_id = null;
|
|
me.view_blank_form();
|
|
}
|
|
$ds(me.parent);
|
|
|
|
// reply or send btn
|
|
me.msg_parts.inputs['Send'].onclick = function(){
|
|
if(!this.btn_click){
|
|
this.btn_click = 1;
|
|
me.send(me.req_frm, me.receiver_lst, me.show_on_send_tab, me.show_on_send_div);
|
|
}
|
|
}
|
|
me.msg_parts.inputs['Reply'].onclick = me.msg_parts.inputs['Send'].onclick;
|
|
}
|
|
|
|
MessageThread.prototype.hide = function() {
|
|
var me = this;
|
|
|
|
$dh(me.wrapper);
|
|
$ds(me.view_list_div);
|
|
me.display = 0;
|
|
}
|
|
|
|
MessageThread.prototype.show_as = function(reply) {
|
|
var me = this;
|
|
|
|
if(!reply) {
|
|
$dh(me.msg_parts.inputs['Thread'].wrapper);
|
|
$dh(me.msg_parts.inputs['Reply']);
|
|
$ds(me.msg_parts.inputs['Send']);
|
|
me.in_compose = 1;
|
|
}
|
|
else {
|
|
$ds(me.msg_parts.inputs['Thread'].wrapper);
|
|
$ds(me.msg_parts.inputs['Reply']);
|
|
$dh(me.msg_parts.inputs['Send']);
|
|
$dh(me.view_list_div);
|
|
me.in_compose = 1;
|
|
}
|
|
$ds(me.wrapper);
|
|
me.display = 1;
|
|
}
|
|
|
|
MessageThread.prototype.send_msg = function(arg){
|
|
var me = this;
|
|
var args = arg;
|
|
|
|
var send_call_back = function(r, rt){
|
|
//var me = this;
|
|
if(r.message == 'true'){
|
|
me.msg_parts.inputs['To'].value = '';
|
|
me.msg_parts.inputs['Subject'].value = '';
|
|
me.msg_parts.inputs['Thread'].innerHTML = '';
|
|
|
|
if(me.inbox_editor && pscript.inbox_text_editor_set == 1){
|
|
me.inbox_editor.editor.setContent('');
|
|
}
|
|
else{
|
|
me.msg_parts.inputs['Message'].value = '';
|
|
}
|
|
|
|
if(me.req_frm == 'My Inbox'){
|
|
pscript.msg_struct.sent_lst.msg_li.run();
|
|
me.show_on_send_tab.show();
|
|
$ds(me.show_on_send_div);
|
|
$dh(me.parent);
|
|
}
|
|
}
|
|
}
|
|
|
|
if(me.cur_message_id==null){
|
|
$c_obj('Message Control','send_message',docstring(args), send_call_back);
|
|
}
|
|
else{
|
|
$c_obj('Message Control','send_reply',docstring(args), send_call_back);
|
|
}
|
|
}
|
|
|
|
MessageThread.prototype.send = function(req_frm, receiver_lst, show_on_send_tab, show_on_send_div) {
|
|
var me = this;
|
|
me.req_frm = req_frm;
|
|
me.show_on_send_tab = show_on_send_tab;
|
|
me.show_on_send_div = show_on_send_div;
|
|
var args = {'user_name':user};
|
|
|
|
if(me.inbox_editor && pscript.inbox_text_editor_set == 1){
|
|
args.message = me.inbox_editor.editor.getContent();
|
|
}
|
|
else{
|
|
args.message = me.msg_parts.inputs['Message'].value;
|
|
}
|
|
|
|
if(me.cur_message_id==null){
|
|
args.subject = me.msg_parts.inputs['Subject'].value;
|
|
args.to_list = me.msg_parts.inputs['To'].value;
|
|
if(!args.to_list) {msgprint('error:Must enter "To:"'); }
|
|
else if(!args.subject) {msgprint('error:Must enter "Subject"'); }
|
|
else me.send_msg(args);
|
|
}
|
|
else{
|
|
var subj = me.msg_parts.inputs['Subject'].value;
|
|
if(!subj.substr(0,3).toLowerCase()=='re:')
|
|
subj = 'Re: ' + subj;
|
|
args.subject = subj;
|
|
args.message_id = me.cur_message_id;
|
|
|
|
me.send_msg(args);
|
|
}
|
|
}
|
|
|
|
MessageThread.prototype.delete_msg = function(req_frm, parent, view_list_tab, view_list_div) {
|
|
var me = this;
|
|
|
|
var msg_lst = [];
|
|
var delete_message_dialog;
|
|
me.parent = parent;
|
|
|
|
if(me.cur_message_id)
|
|
msg_lst.push(me.cur_message_id);
|
|
|
|
if(msg_lst.length >= 1){
|
|
function set_delete_message_dialog() {
|
|
delete_message_dialog = new Dialog(400, 400, 'Delete Message');
|
|
delete_message_dialog.make_body([
|
|
['HTML', 'Message', '<div class = "comment">Are you sure, you want to delete this message ?</div>'],
|
|
['HTML', 'Response', '<div class = "comment" id="delete_message_dialog_response"></div>'],
|
|
['HTML', 'Delete Message', '<div id="delete_message_btn" style ="height:25px;"></div>']
|
|
]);
|
|
|
|
var delete_message_btn1 = $a($i('delete_message_btn'), 'button', 'button');
|
|
delete_message_btn1.innerHTML = 'Yes';
|
|
delete_message_btn1.onclick = function(){ delete_message_dialog.add();}
|
|
|
|
var delete_message_btn2 = $a($i('delete_message_btn'), 'button', 'button');
|
|
delete_message_btn2.innerHTML = 'No';
|
|
$y(delete_message_btn2,{marginLeft:'4px'});
|
|
|
|
delete_message_btn2.onclick = function(){ delete_message_dialog.hide();}
|
|
|
|
delete_message_dialog.onshow = function() {
|
|
$i('delete_message_dialog_response').innerHTML = '';
|
|
}
|
|
|
|
delete_message_dialog.add = function() {
|
|
if(this.req_frm == 'My Inbox'){
|
|
var args = user + '~~' + this.msg_lst;
|
|
$c_obj('Message Control', 'delete_message', args, function(r, rt){
|
|
if(r.message == 'true'){
|
|
me.hide();
|
|
me.view_list_tab.show();
|
|
$ds(me.view_list_div);
|
|
delete_message_dialog.hide();
|
|
}
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
if(!delete_message_dialog)
|
|
set_delete_message_dialog();
|
|
delete_message_dialog.req_frm = req_frm;
|
|
delete_message_dialog.msg_lst = msg_lst;
|
|
delete_message_dialog.view_list_tab = view_list_tab;
|
|
delete_message_dialog.view_list_div = view_list_div;
|
|
delete_message_dialog.show();
|
|
}
|
|
}
|
|
|
|
// ---------------- editor---------------------
|
|
|
|
var editor_count = 0;
|
|
|
|
function TextAreaEditor(txt, parent, callback, theme_advanced_btn1, theme_advanced_btn2, theme_advanced_btn3, editor_ht) {
|
|
|
|
this.txt = txt;
|
|
this.parent = parent;
|
|
this.callback = callback;
|
|
if(theme_advanced_btn1) this.theme_advanced_btn1 = theme_advanced_btn1;
|
|
if(theme_advanced_btn2) this.theme_advanced_btn2 = theme_advanced_btn2;
|
|
if(theme_advanced_btn3) this.theme_advanced_btn3 = theme_advanced_btn3;
|
|
if(editor_ht) this.editor_ht = editor_ht;
|
|
|
|
// load tinyMCE library
|
|
this.load_tiny_mce_library();
|
|
}
|
|
|
|
TextAreaEditor.prototype.load_tiny_mce_library = function() {
|
|
|
|
var me = this;
|
|
|
|
if(!tinymce_loaded) {
|
|
tinymce_loaded = 1;
|
|
tinyMCE_GZ.init(
|
|
{
|
|
themes : "advanced",
|
|
plugins : "style,table,inlinepopups,indicime,emotions",
|
|
languages : "en",
|
|
disk_cache : true
|
|
}, function(){ me.setup_text_area() });
|
|
}
|
|
else {
|
|
me.setup_text_area();
|
|
}
|
|
}
|
|
|
|
TextAreaEditor.prototype.setup_text_area = function() {
|
|
|
|
var me = this;
|
|
if(!me.txt) {
|
|
me.txt = $a(me.parent, 'textarea');
|
|
}
|
|
|
|
editor_count++;
|
|
me.id = 'editor_text_' + editor_count;
|
|
me.txt.setAttribute('id', me.id);
|
|
|
|
tinyMCE.init({
|
|
theme : "advanced",
|
|
mode : "exact",
|
|
elements: me.id,
|
|
plugins:"table,style,inlinepopups,indicime,emotions",
|
|
theme_advanced_toolbar_location : "top",
|
|
theme_advanced_statusbar_location : "bottom",
|
|
extended_valid_elements: "div[id|dir|class|align|style]",
|
|
|
|
// w/h
|
|
width: '100%',
|
|
height: me.editor_ht?me.editor_ht:'50px',
|
|
|
|
// buttons
|
|
//theme_advanced_buttons1 :"bold,italic,underline,strikethrough,blockquote,forecolor,backcolor,bullist,numlist,|,undo,redo,|,image,code,indicime,indicimehelp,emotions",
|
|
theme_advanced_buttons1 : me.theme_advanced_btn1?me.theme_advanced_btn1:"bold,italic,underline,forecolor,backcolor,|,undo,redo,|,link,unlink,indicime,indicimehelp,emotions",
|
|
theme_advanced_buttons2 : me.theme_advanced_btn2?me.theme_advanced_btn2:"",
|
|
theme_advanced_buttons3 : me.theme_advanced_btn3?me.theme_advanced_btn3:"",
|
|
|
|
// callback function with editor instance.
|
|
init_instance_callback : "editor_init_callback"
|
|
});
|
|
|
|
editor_init_callback = function(inst) {
|
|
me.editor = tinyMCE.get(me.id);
|
|
me.editor.focus();
|
|
|
|
if(me.callback){
|
|
me.callback(me.editor);
|
|
}
|
|
}
|
|
} |