-rw-r--r-- | noncore/net/mail/imapwrapper.cpp | 5 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/imapwrapper.cpp | 5 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/mailtypes.cpp | 12 | ||||
-rw-r--r-- | noncore/net/mail/libmailwrapper/mailtypes.h | 4 | ||||
-rw-r--r-- | noncore/net/mail/mailtypes.cpp | 12 | ||||
-rw-r--r-- | noncore/net/mail/mailtypes.h | 4 | ||||
-rw-r--r-- | noncore/net/mail/mainwindow.cpp | 4 | ||||
-rw-r--r-- | noncore/net/mail/viewmail.cpp | 32 | ||||
-rw-r--r-- | noncore/net/mail/viewmail.h | 3 | ||||
-rw-r--r-- | noncore/net/mail/viewmailbase.cpp | 5 |
10 files changed, 64 insertions, 22 deletions
diff --git a/noncore/net/mail/imapwrapper.cpp b/noncore/net/mail/imapwrapper.cpp index 0ce2c6c..ad95384 100644 --- a/noncore/net/mail/imapwrapper.cpp +++ b/noncore/net/mail/imapwrapper.cpp | |||
@@ -507,267 +507,270 @@ QString IMAPwrapper::fetchPart(const RecMail&mail,const QValueList<int>&path,boo | |||
507 | char*text = msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part; | 507 | char*text = msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part; |
508 | msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part = 0L; | 508 | msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part = 0L; |
509 | if (text) { | 509 | if (text) { |
510 | body = QString(text); | 510 | body = QString(text); |
511 | free(text); | 511 | free(text); |
512 | } else { | 512 | } else { |
513 | body = ""; | 513 | body = ""; |
514 | } | 514 | } |
515 | } | 515 | } |
516 | } | 516 | } |
517 | } | 517 | } |
518 | 518 | ||
519 | } else { | 519 | } else { |
520 | qDebug("error fetching text: %s",m_imap->imap_response); | 520 | qDebug("error fetching text: %s",m_imap->imap_response); |
521 | } | 521 | } |
522 | mailimap_fetch_list_free(result); | 522 | mailimap_fetch_list_free(result); |
523 | return body; | 523 | return body; |
524 | } | 524 | } |
525 | 525 | ||
526 | void IMAPwrapper::searchBodyText(const RecMail&mail,mailimap_body_type_mpart*mailDescription,RecBody&target_body,int current_recursion,QValueList<int>recList) | 526 | void IMAPwrapper::searchBodyText(const RecMail&mail,mailimap_body_type_mpart*mailDescription,RecBody&target_body,int current_recursion,QValueList<int>recList) |
527 | { | 527 | { |
528 | /* current_recursion is for avoiding ugly mails which has a to deep body-structure */ | 528 | /* current_recursion is for avoiding ugly mails which has a to deep body-structure */ |
529 | if (!mailDescription||current_recursion==10) { | 529 | if (!mailDescription||current_recursion==10) { |
530 | return; | 530 | return; |
531 | } | 531 | } |
532 | clistcell*current; | 532 | clistcell*current; |
533 | mailimap_body*current_body; | 533 | mailimap_body*current_body; |
534 | unsigned int count = 0; | 534 | unsigned int count = 0; |
535 | for (current=clist_begin(mailDescription->bd_list);current!=0;current=clist_next(current)) { | 535 | for (current=clist_begin(mailDescription->bd_list);current!=0;current=clist_next(current)) { |
536 | /* the point in the message */ | 536 | /* the point in the message */ |
537 | ++count; | 537 | ++count; |
538 | current_body = (mailimap_body*)current->data; | 538 | current_body = (mailimap_body*)current->data; |
539 | if (current_body->bd_type==MAILIMAP_BODY_MPART) { | 539 | if (current_body->bd_type==MAILIMAP_BODY_MPART) { |
540 | QValueList<int>clist = recList; | 540 | QValueList<int>clist = recList; |
541 | clist.append(count); | 541 | clist.append(count); |
542 | searchBodyText(mail,current_body->bd_data.bd_body_mpart,target_body,current_recursion+1,clist); | 542 | searchBodyText(mail,current_body->bd_data.bd_body_mpart,target_body,current_recursion+1,clist); |
543 | } else if (current_body->bd_type==MAILIMAP_BODY_1PART){ | 543 | } else if (current_body->bd_type==MAILIMAP_BODY_1PART){ |
544 | RecPart currentPart; | 544 | RecPart currentPart; |
545 | fillSinglePart(currentPart,current_body->bd_data.bd_body_1part); | 545 | fillSinglePart(currentPart,current_body->bd_data.bd_body_1part); |
546 | QValueList<int>clist = recList; | 546 | QValueList<int>clist = recList; |
547 | clist.append(count); | 547 | clist.append(count); |
548 | /* important: Check for is NULL 'cause a body can be empty! */ | 548 | /* important: Check for is NULL 'cause a body can be empty! */ |
549 | if (currentPart.Type()=="text" && target_body.Bodytext().isNull() ) { | 549 | if (currentPart.Type()=="text" && target_body.Bodytext().isNull() ) { |
550 | QString body_text = fetchPart(mail,clist,true); | 550 | QString body_text = fetchPart(mail,clist,true); |
551 | target_body.setDescription(currentPart); | 551 | target_body.setDescription(currentPart); |
552 | target_body.setBodytext(body_text); | 552 | target_body.setBodytext(body_text); |
553 | } else { | 553 | } else { |
554 | QString id(""); | 554 | QString id(""); |
555 | for (unsigned int j = 0; j < clist.count();++j) { | 555 | for (unsigned int j = 0; j < clist.count();++j) { |
556 | id+=(j>0?" ":""); | 556 | id+=(j>0?" ":""); |
557 | id+=QString("%1").arg(clist[j]); | 557 | id+=QString("%1").arg(clist[j]); |
558 | } | 558 | } |
559 | qDebug("ID= %s",id.latin1()); | 559 | qDebug("ID= %s",id.latin1()); |
560 | currentPart.setIdentifier(id); | 560 | currentPart.setIdentifier(id); |
561 | currentPart.setPositionlist(clist); | 561 | currentPart.setPositionlist(clist); |
562 | target_body.addPart(currentPart); | 562 | target_body.addPart(currentPart); |
563 | } | 563 | } |
564 | } | 564 | } |
565 | } | 565 | } |
566 | } | 566 | } |
567 | 567 | ||
568 | void IMAPwrapper::fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description) | 568 | void IMAPwrapper::fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description) |
569 | { | 569 | { |
570 | if (!Description) { | 570 | if (!Description) { |
571 | return; | 571 | return; |
572 | } | 572 | } |
573 | switch (Description->bd_type) { | 573 | switch (Description->bd_type) { |
574 | case MAILIMAP_BODY_TYPE_1PART_TEXT: | 574 | case MAILIMAP_BODY_TYPE_1PART_TEXT: |
575 | target_part.setType("text"); | 575 | target_part.setType("text"); |
576 | fillSingleTextPart(target_part,Description->bd_data.bd_type_text); | 576 | fillSingleTextPart(target_part,Description->bd_data.bd_type_text); |
577 | break; | 577 | break; |
578 | case MAILIMAP_BODY_TYPE_1PART_BASIC: | 578 | case MAILIMAP_BODY_TYPE_1PART_BASIC: |
579 | fillSingleBasicPart(target_part,Description->bd_data.bd_type_basic); | 579 | fillSingleBasicPart(target_part,Description->bd_data.bd_type_basic); |
580 | break; | 580 | break; |
581 | case MAILIMAP_BODY_TYPE_1PART_MSG: | 581 | case MAILIMAP_BODY_TYPE_1PART_MSG: |
582 | fillSingleMsgPart(target_part,Description->bd_data.bd_type_msg); | 582 | fillSingleMsgPart(target_part,Description->bd_data.bd_type_msg); |
583 | break; | 583 | break; |
584 | default: | 584 | default: |
585 | break; | 585 | break; |
586 | } | 586 | } |
587 | } | 587 | } |
588 | 588 | ||
589 | void IMAPwrapper::fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which) | 589 | void IMAPwrapper::fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which) |
590 | { | 590 | { |
591 | if (!which) { | 591 | if (!which) { |
592 | return; | 592 | return; |
593 | } | 593 | } |
594 | QString sub; | 594 | QString sub; |
595 | sub = which->bd_media_text; | 595 | sub = which->bd_media_text; |
596 | target_part.setSubtype(sub.lower()); | 596 | target_part.setSubtype(sub.lower()); |
597 | target_part.setLines(which->bd_lines); | 597 | target_part.setLines(which->bd_lines); |
598 | fillBodyFields(target_part,which->bd_fields); | 598 | fillBodyFields(target_part,which->bd_fields); |
599 | } | 599 | } |
600 | 600 | ||
601 | void IMAPwrapper::fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which) | 601 | void IMAPwrapper::fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which) |
602 | { | 602 | { |
603 | if (!which) { | 603 | if (!which) { |
604 | return; | 604 | return; |
605 | } | 605 | } |
606 | // QString sub; | 606 | // QString sub; |
607 | // sub = which->bd_media_text; | 607 | // sub = which->bd_media_text; |
608 | // target_part.setSubtype(sub.lower()); | 608 | // target_part.setSubtype(sub.lower()); |
609 | qDebug("Message part"); | 609 | qDebug("Message part"); |
610 | /* we set this type to text/plain */ | 610 | /* we set this type to text/plain */ |
611 | target_part.setType("text"); | 611 | target_part.setType("text"); |
612 | target_part.setSubtype("plain"); | 612 | target_part.setSubtype("plain"); |
613 | target_part.setLines(which->bd_lines); | 613 | target_part.setLines(which->bd_lines); |
614 | fillBodyFields(target_part,which->bd_fields); | 614 | fillBodyFields(target_part,which->bd_fields); |
615 | } | 615 | } |
616 | 616 | ||
617 | void IMAPwrapper::fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which) | 617 | void IMAPwrapper::fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which) |
618 | { | 618 | { |
619 | if (!which) { | 619 | if (!which) { |
620 | return; | 620 | return; |
621 | } | 621 | } |
622 | QString type,sub; | 622 | QString type,sub; |
623 | switch (which->bd_media_basic->med_type) { | 623 | switch (which->bd_media_basic->med_type) { |
624 | case MAILIMAP_MEDIA_BASIC_APPLICATION: | 624 | case MAILIMAP_MEDIA_BASIC_APPLICATION: |
625 | type = "application"; | 625 | type = "application"; |
626 | break; | 626 | break; |
627 | case MAILIMAP_MEDIA_BASIC_AUDIO: | 627 | case MAILIMAP_MEDIA_BASIC_AUDIO: |
628 | type = "audio"; | 628 | type = "audio"; |
629 | break; | 629 | break; |
630 | case MAILIMAP_MEDIA_BASIC_IMAGE: | 630 | case MAILIMAP_MEDIA_BASIC_IMAGE: |
631 | type = "image"; | 631 | type = "image"; |
632 | break; | 632 | break; |
633 | case MAILIMAP_MEDIA_BASIC_MESSAGE: | 633 | case MAILIMAP_MEDIA_BASIC_MESSAGE: |
634 | type = "message"; | 634 | type = "message"; |
635 | break; | 635 | break; |
636 | case MAILIMAP_MEDIA_BASIC_VIDEO: | 636 | case MAILIMAP_MEDIA_BASIC_VIDEO: |
637 | type = "video"; | 637 | type = "video"; |
638 | break; | 638 | break; |
639 | case MAILIMAP_MEDIA_BASIC_OTHER: | 639 | case MAILIMAP_MEDIA_BASIC_OTHER: |
640 | default: | 640 | default: |
641 | if (which->bd_media_basic->med_basic_type) { | 641 | if (which->bd_media_basic->med_basic_type) { |
642 | type = which->bd_media_basic->med_basic_type; | 642 | type = which->bd_media_basic->med_basic_type; |
643 | } else { | 643 | } else { |
644 | type = ""; | 644 | type = ""; |
645 | } | 645 | } |
646 | break; | 646 | break; |
647 | } | 647 | } |
648 | if (which->bd_media_basic->med_subtype) { | 648 | if (which->bd_media_basic->med_subtype) { |
649 | sub = which->bd_media_basic->med_subtype; | 649 | sub = which->bd_media_basic->med_subtype; |
650 | } else { | 650 | } else { |
651 | sub = ""; | 651 | sub = ""; |
652 | } | 652 | } |
653 | qDebug("Type = %s/%s",type.latin1(),sub.latin1()); | 653 | qDebug("Type = %s/%s",type.latin1(),sub.latin1()); |
654 | target_part.setType(type.lower()); | 654 | target_part.setType(type.lower()); |
655 | target_part.setSubtype(sub.lower()); | 655 | target_part.setSubtype(sub.lower()); |
656 | fillBodyFields(target_part,which->bd_fields); | 656 | fillBodyFields(target_part,which->bd_fields); |
657 | } | 657 | } |
658 | 658 | ||
659 | void IMAPwrapper::fillBodyFields(RecPart&target_part,mailimap_body_fields*which) | 659 | void IMAPwrapper::fillBodyFields(RecPart&target_part,mailimap_body_fields*which) |
660 | { | 660 | { |
661 | if (!which) return; | 661 | if (!which) return; |
662 | if (which->bd_parameter && which->bd_parameter->pa_list && which->bd_parameter->pa_list->count>0) { | 662 | if (which->bd_parameter && which->bd_parameter->pa_list && which->bd_parameter->pa_list->count>0) { |
663 | clistcell*cur; | 663 | clistcell*cur; |
664 | mailimap_single_body_fld_param*param=0; | 664 | mailimap_single_body_fld_param*param=0; |
665 | for (cur = clist_begin(which->bd_parameter->pa_list);cur!=NULL;cur=clist_next(cur)) { | 665 | for (cur = clist_begin(which->bd_parameter->pa_list);cur!=NULL;cur=clist_next(cur)) { |
666 | param = (mailimap_single_body_fld_param*)cur->data; | 666 | param = (mailimap_single_body_fld_param*)cur->data; |
667 | if (param) { | 667 | if (param) { |
668 | target_part.addParameter(QString(param->pa_name).lower(),QString(param->pa_value)); | 668 | target_part.addParameter(QString(param->pa_name).lower(),QString(param->pa_value)); |
669 | } | 669 | } |
670 | } | 670 | } |
671 | } | 671 | } |
672 | mailimap_body_fld_enc*enc = which->bd_encoding; | 672 | mailimap_body_fld_enc*enc = which->bd_encoding; |
673 | QString encoding(""); | 673 | QString encoding(""); |
674 | switch (enc->enc_type) { | 674 | switch (enc->enc_type) { |
675 | case MAILIMAP_BODY_FLD_ENC_7BIT: | 675 | case MAILIMAP_BODY_FLD_ENC_7BIT: |
676 | encoding = "7bit"; | 676 | encoding = "7bit"; |
677 | break; | 677 | break; |
678 | case MAILIMAP_BODY_FLD_ENC_8BIT: | 678 | case MAILIMAP_BODY_FLD_ENC_8BIT: |
679 | encoding = "8bit"; | 679 | encoding = "8bit"; |
680 | break; | 680 | break; |
681 | case MAILIMAP_BODY_FLD_ENC_BINARY: | 681 | case MAILIMAP_BODY_FLD_ENC_BINARY: |
682 | encoding="binary"; | 682 | encoding="binary"; |
683 | break; | 683 | break; |
684 | case MAILIMAP_BODY_FLD_ENC_BASE64: | 684 | case MAILIMAP_BODY_FLD_ENC_BASE64: |
685 | encoding="base64"; | 685 | encoding="base64"; |
686 | break; | 686 | break; |
687 | case MAILIMAP_BODY_FLD_ENC_QUOTED_PRINTABLE: | 687 | case MAILIMAP_BODY_FLD_ENC_QUOTED_PRINTABLE: |
688 | encoding="quoted-printable"; | 688 | encoding="quoted-printable"; |
689 | break; | 689 | break; |
690 | case MAILIMAP_BODY_FLD_ENC_OTHER: | 690 | case MAILIMAP_BODY_FLD_ENC_OTHER: |
691 | default: | 691 | default: |
692 | if (enc->enc_value) { | 692 | if (enc->enc_value) { |
693 | char*t=enc->enc_value; | 693 | char*t=enc->enc_value; |
694 | encoding=QString(enc->enc_value); | 694 | encoding=QString(enc->enc_value); |
695 | enc->enc_value=0L; | 695 | enc->enc_value=0L; |
696 | free(t); | 696 | free(t); |
697 | } | 697 | } |
698 | } | 698 | } |
699 | if (which->bd_description) { | ||
700 | target_part.setDescription(QString(which->bd_description)); | ||
701 | } | ||
699 | target_part.setEncoding(encoding); | 702 | target_part.setEncoding(encoding); |
700 | target_part.setSize(which->bd_size); | 703 | target_part.setSize(which->bd_size); |
701 | } | 704 | } |
702 | 705 | ||
703 | QString IMAPwrapper::fetchPart(const RecMail&mail,const RecPart&part) | 706 | QString IMAPwrapper::fetchPart(const RecMail&mail,const RecPart&part) |
704 | { | 707 | { |
705 | return fetchPart(mail,part.Positionlist(),false); | 708 | return fetchPart(mail,part.Positionlist(),false); |
706 | } | 709 | } |
707 | 710 | ||
708 | void IMAPwrapper::deleteMail(const RecMail&mail) | 711 | void IMAPwrapper::deleteMail(const RecMail&mail) |
709 | { | 712 | { |
710 | mailimap_flag_list*flist; | 713 | mailimap_flag_list*flist; |
711 | mailimap_set *set; | 714 | mailimap_set *set; |
712 | mailimap_store_att_flags * store_flags; | 715 | mailimap_store_att_flags * store_flags; |
713 | int err; | 716 | int err; |
714 | login(); | 717 | login(); |
715 | if (!m_imap) { | 718 | if (!m_imap) { |
716 | return; | 719 | return; |
717 | } | 720 | } |
718 | const char *mb = mail.getMbox().latin1(); | 721 | const char *mb = mail.getMbox().latin1(); |
719 | err = mailimap_select( m_imap, (char*)mb); | 722 | err = mailimap_select( m_imap, (char*)mb); |
720 | if ( err != MAILIMAP_NO_ERROR ) { | 723 | if ( err != MAILIMAP_NO_ERROR ) { |
721 | qDebug("error selecting mailbox for delete: %s",m_imap->imap_response); | 724 | qDebug("error selecting mailbox for delete: %s",m_imap->imap_response); |
722 | return; | 725 | return; |
723 | } | 726 | } |
724 | flist = mailimap_flag_list_new_empty(); | 727 | flist = mailimap_flag_list_new_empty(); |
725 | mailimap_flag_list_add(flist,mailimap_flag_new_deleted()); | 728 | mailimap_flag_list_add(flist,mailimap_flag_new_deleted()); |
726 | store_flags = mailimap_store_att_flags_new_set_flags(flist); | 729 | store_flags = mailimap_store_att_flags_new_set_flags(flist); |
727 | set = mailimap_set_new_single(mail.getNumber()); | 730 | set = mailimap_set_new_single(mail.getNumber()); |
728 | err = mailimap_store(m_imap,set,store_flags); | 731 | err = mailimap_store(m_imap,set,store_flags); |
729 | mailimap_set_free( set ); | 732 | mailimap_set_free( set ); |
730 | mailimap_store_att_flags_free(store_flags); | 733 | mailimap_store_att_flags_free(store_flags); |
731 | 734 | ||
732 | if (err != MAILIMAP_NO_ERROR) { | 735 | if (err != MAILIMAP_NO_ERROR) { |
733 | qDebug("error deleting mail: %s",m_imap->imap_response); | 736 | qDebug("error deleting mail: %s",m_imap->imap_response); |
734 | return; | 737 | return; |
735 | } | 738 | } |
736 | qDebug("deleting mail: %s",m_imap->imap_response); | 739 | qDebug("deleting mail: %s",m_imap->imap_response); |
737 | /* should we realy do that at this moment? */ | 740 | /* should we realy do that at this moment? */ |
738 | err = mailimap_expunge(m_imap); | 741 | err = mailimap_expunge(m_imap); |
739 | if (err != MAILIMAP_NO_ERROR) { | 742 | if (err != MAILIMAP_NO_ERROR) { |
740 | qDebug("error deleting mail: %s",m_imap->imap_response); | 743 | qDebug("error deleting mail: %s",m_imap->imap_response); |
741 | } | 744 | } |
742 | qDebug("Delete successfull %s",m_imap->imap_response); | 745 | qDebug("Delete successfull %s",m_imap->imap_response); |
743 | } | 746 | } |
744 | 747 | ||
745 | void IMAPwrapper::answeredMail(const RecMail&mail) | 748 | void IMAPwrapper::answeredMail(const RecMail&mail) |
746 | { | 749 | { |
747 | mailimap_flag_list*flist; | 750 | mailimap_flag_list*flist; |
748 | mailimap_set *set; | 751 | mailimap_set *set; |
749 | mailimap_store_att_flags * store_flags; | 752 | mailimap_store_att_flags * store_flags; |
750 | int err; | 753 | int err; |
751 | login(); | 754 | login(); |
752 | if (!m_imap) { | 755 | if (!m_imap) { |
753 | return; | 756 | return; |
754 | } | 757 | } |
755 | const char *mb = mail.getMbox().latin1(); | 758 | const char *mb = mail.getMbox().latin1(); |
756 | err = mailimap_select( m_imap, (char*)mb); | 759 | err = mailimap_select( m_imap, (char*)mb); |
757 | if ( err != MAILIMAP_NO_ERROR ) { | 760 | if ( err != MAILIMAP_NO_ERROR ) { |
758 | qDebug("error selecting mailbox for mark: %s",m_imap->imap_response); | 761 | qDebug("error selecting mailbox for mark: %s",m_imap->imap_response); |
759 | return; | 762 | return; |
760 | } | 763 | } |
761 | flist = mailimap_flag_list_new_empty(); | 764 | flist = mailimap_flag_list_new_empty(); |
762 | mailimap_flag_list_add(flist,mailimap_flag_new_answered()); | 765 | mailimap_flag_list_add(flist,mailimap_flag_new_answered()); |
763 | store_flags = mailimap_store_att_flags_new_set_flags(flist); | 766 | store_flags = mailimap_store_att_flags_new_add_flags(flist); |
764 | set = mailimap_set_new_single(mail.getNumber()); | 767 | set = mailimap_set_new_single(mail.getNumber()); |
765 | err = mailimap_store(m_imap,set,store_flags); | 768 | err = mailimap_store(m_imap,set,store_flags); |
766 | mailimap_set_free( set ); | 769 | mailimap_set_free( set ); |
767 | mailimap_store_att_flags_free(store_flags); | 770 | mailimap_store_att_flags_free(store_flags); |
768 | 771 | ||
769 | if (err != MAILIMAP_NO_ERROR) { | 772 | if (err != MAILIMAP_NO_ERROR) { |
770 | qDebug("error marking mail: %s",m_imap->imap_response); | 773 | qDebug("error marking mail: %s",m_imap->imap_response); |
771 | return; | 774 | return; |
772 | } | 775 | } |
773 | } | 776 | } |
diff --git a/noncore/net/mail/libmailwrapper/imapwrapper.cpp b/noncore/net/mail/libmailwrapper/imapwrapper.cpp index 0ce2c6c..ad95384 100644 --- a/noncore/net/mail/libmailwrapper/imapwrapper.cpp +++ b/noncore/net/mail/libmailwrapper/imapwrapper.cpp | |||
@@ -507,267 +507,270 @@ QString IMAPwrapper::fetchPart(const RecMail&mail,const QValueList<int>&path,boo | |||
507 | char*text = msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part; | 507 | char*text = msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part; |
508 | msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part = 0L; | 508 | msg_att_item->att_data.att_static->att_data.att_body_section->sec_body_part = 0L; |
509 | if (text) { | 509 | if (text) { |
510 | body = QString(text); | 510 | body = QString(text); |
511 | free(text); | 511 | free(text); |
512 | } else { | 512 | } else { |
513 | body = ""; | 513 | body = ""; |
514 | } | 514 | } |
515 | } | 515 | } |
516 | } | 516 | } |
517 | } | 517 | } |
518 | 518 | ||
519 | } else { | 519 | } else { |
520 | qDebug("error fetching text: %s",m_imap->imap_response); | 520 | qDebug("error fetching text: %s",m_imap->imap_response); |
521 | } | 521 | } |
522 | mailimap_fetch_list_free(result); | 522 | mailimap_fetch_list_free(result); |
523 | return body; | 523 | return body; |
524 | } | 524 | } |
525 | 525 | ||
526 | void IMAPwrapper::searchBodyText(const RecMail&mail,mailimap_body_type_mpart*mailDescription,RecBody&target_body,int current_recursion,QValueList<int>recList) | 526 | void IMAPwrapper::searchBodyText(const RecMail&mail,mailimap_body_type_mpart*mailDescription,RecBody&target_body,int current_recursion,QValueList<int>recList) |
527 | { | 527 | { |
528 | /* current_recursion is for avoiding ugly mails which has a to deep body-structure */ | 528 | /* current_recursion is for avoiding ugly mails which has a to deep body-structure */ |
529 | if (!mailDescription||current_recursion==10) { | 529 | if (!mailDescription||current_recursion==10) { |
530 | return; | 530 | return; |
531 | } | 531 | } |
532 | clistcell*current; | 532 | clistcell*current; |
533 | mailimap_body*current_body; | 533 | mailimap_body*current_body; |
534 | unsigned int count = 0; | 534 | unsigned int count = 0; |
535 | for (current=clist_begin(mailDescription->bd_list);current!=0;current=clist_next(current)) { | 535 | for (current=clist_begin(mailDescription->bd_list);current!=0;current=clist_next(current)) { |
536 | /* the point in the message */ | 536 | /* the point in the message */ |
537 | ++count; | 537 | ++count; |
538 | current_body = (mailimap_body*)current->data; | 538 | current_body = (mailimap_body*)current->data; |
539 | if (current_body->bd_type==MAILIMAP_BODY_MPART) { | 539 | if (current_body->bd_type==MAILIMAP_BODY_MPART) { |
540 | QValueList<int>clist = recList; | 540 | QValueList<int>clist = recList; |
541 | clist.append(count); | 541 | clist.append(count); |
542 | searchBodyText(mail,current_body->bd_data.bd_body_mpart,target_body,current_recursion+1,clist); | 542 | searchBodyText(mail,current_body->bd_data.bd_body_mpart,target_body,current_recursion+1,clist); |
543 | } else if (current_body->bd_type==MAILIMAP_BODY_1PART){ | 543 | } else if (current_body->bd_type==MAILIMAP_BODY_1PART){ |
544 | RecPart currentPart; | 544 | RecPart currentPart; |
545 | fillSinglePart(currentPart,current_body->bd_data.bd_body_1part); | 545 | fillSinglePart(currentPart,current_body->bd_data.bd_body_1part); |
546 | QValueList<int>clist = recList; | 546 | QValueList<int>clist = recList; |
547 | clist.append(count); | 547 | clist.append(count); |
548 | /* important: Check for is NULL 'cause a body can be empty! */ | 548 | /* important: Check for is NULL 'cause a body can be empty! */ |
549 | if (currentPart.Type()=="text" && target_body.Bodytext().isNull() ) { | 549 | if (currentPart.Type()=="text" && target_body.Bodytext().isNull() ) { |
550 | QString body_text = fetchPart(mail,clist,true); | 550 | QString body_text = fetchPart(mail,clist,true); |
551 | target_body.setDescription(currentPart); | 551 | target_body.setDescription(currentPart); |
552 | target_body.setBodytext(body_text); | 552 | target_body.setBodytext(body_text); |
553 | } else { | 553 | } else { |
554 | QString id(""); | 554 | QString id(""); |
555 | for (unsigned int j = 0; j < clist.count();++j) { | 555 | for (unsigned int j = 0; j < clist.count();++j) { |
556 | id+=(j>0?" ":""); | 556 | id+=(j>0?" ":""); |
557 | id+=QString("%1").arg(clist[j]); | 557 | id+=QString("%1").arg(clist[j]); |
558 | } | 558 | } |
559 | qDebug("ID= %s",id.latin1()); | 559 | qDebug("ID= %s",id.latin1()); |
560 | currentPart.setIdentifier(id); | 560 | currentPart.setIdentifier(id); |
561 | currentPart.setPositionlist(clist); | 561 | currentPart.setPositionlist(clist); |
562 | target_body.addPart(currentPart); | 562 | target_body.addPart(currentPart); |
563 | } | 563 | } |
564 | } | 564 | } |
565 | } | 565 | } |
566 | } | 566 | } |
567 | 567 | ||
568 | void IMAPwrapper::fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description) | 568 | void IMAPwrapper::fillSinglePart(RecPart&target_part,mailimap_body_type_1part*Description) |
569 | { | 569 | { |
570 | if (!Description) { | 570 | if (!Description) { |
571 | return; | 571 | return; |
572 | } | 572 | } |
573 | switch (Description->bd_type) { | 573 | switch (Description->bd_type) { |
574 | case MAILIMAP_BODY_TYPE_1PART_TEXT: | 574 | case MAILIMAP_BODY_TYPE_1PART_TEXT: |
575 | target_part.setType("text"); | 575 | target_part.setType("text"); |
576 | fillSingleTextPart(target_part,Description->bd_data.bd_type_text); | 576 | fillSingleTextPart(target_part,Description->bd_data.bd_type_text); |
577 | break; | 577 | break; |
578 | case MAILIMAP_BODY_TYPE_1PART_BASIC: | 578 | case MAILIMAP_BODY_TYPE_1PART_BASIC: |
579 | fillSingleBasicPart(target_part,Description->bd_data.bd_type_basic); | 579 | fillSingleBasicPart(target_part,Description->bd_data.bd_type_basic); |
580 | break; | 580 | break; |
581 | case MAILIMAP_BODY_TYPE_1PART_MSG: | 581 | case MAILIMAP_BODY_TYPE_1PART_MSG: |
582 | fillSingleMsgPart(target_part,Description->bd_data.bd_type_msg); | 582 | fillSingleMsgPart(target_part,Description->bd_data.bd_type_msg); |
583 | break; | 583 | break; |
584 | default: | 584 | default: |
585 | break; | 585 | break; |
586 | } | 586 | } |
587 | } | 587 | } |
588 | 588 | ||
589 | void IMAPwrapper::fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which) | 589 | void IMAPwrapper::fillSingleTextPart(RecPart&target_part,mailimap_body_type_text*which) |
590 | { | 590 | { |
591 | if (!which) { | 591 | if (!which) { |
592 | return; | 592 | return; |
593 | } | 593 | } |
594 | QString sub; | 594 | QString sub; |
595 | sub = which->bd_media_text; | 595 | sub = which->bd_media_text; |
596 | target_part.setSubtype(sub.lower()); | 596 | target_part.setSubtype(sub.lower()); |
597 | target_part.setLines(which->bd_lines); | 597 | target_part.setLines(which->bd_lines); |
598 | fillBodyFields(target_part,which->bd_fields); | 598 | fillBodyFields(target_part,which->bd_fields); |
599 | } | 599 | } |
600 | 600 | ||
601 | void IMAPwrapper::fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which) | 601 | void IMAPwrapper::fillSingleMsgPart(RecPart&target_part,mailimap_body_type_msg*which) |
602 | { | 602 | { |
603 | if (!which) { | 603 | if (!which) { |
604 | return; | 604 | return; |
605 | } | 605 | } |
606 | // QString sub; | 606 | // QString sub; |
607 | // sub = which->bd_media_text; | 607 | // sub = which->bd_media_text; |
608 | // target_part.setSubtype(sub.lower()); | 608 | // target_part.setSubtype(sub.lower()); |
609 | qDebug("Message part"); | 609 | qDebug("Message part"); |
610 | /* we set this type to text/plain */ | 610 | /* we set this type to text/plain */ |
611 | target_part.setType("text"); | 611 | target_part.setType("text"); |
612 | target_part.setSubtype("plain"); | 612 | target_part.setSubtype("plain"); |
613 | target_part.setLines(which->bd_lines); | 613 | target_part.setLines(which->bd_lines); |
614 | fillBodyFields(target_part,which->bd_fields); | 614 | fillBodyFields(target_part,which->bd_fields); |
615 | } | 615 | } |
616 | 616 | ||
617 | void IMAPwrapper::fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which) | 617 | void IMAPwrapper::fillSingleBasicPart(RecPart&target_part,mailimap_body_type_basic*which) |
618 | { | 618 | { |
619 | if (!which) { | 619 | if (!which) { |
620 | return; | 620 | return; |
621 | } | 621 | } |
622 | QString type,sub; | 622 | QString type,sub; |
623 | switch (which->bd_media_basic->med_type) { | 623 | switch (which->bd_media_basic->med_type) { |
624 | case MAILIMAP_MEDIA_BASIC_APPLICATION: | 624 | case MAILIMAP_MEDIA_BASIC_APPLICATION: |
625 | type = "application"; | 625 | type = "application"; |
626 | break; | 626 | break; |
627 | case MAILIMAP_MEDIA_BASIC_AUDIO: | 627 | case MAILIMAP_MEDIA_BASIC_AUDIO: |
628 | type = "audio"; | 628 | type = "audio"; |
629 | break; | 629 | break; |
630 | case MAILIMAP_MEDIA_BASIC_IMAGE: | 630 | case MAILIMAP_MEDIA_BASIC_IMAGE: |
631 | type = "image"; | 631 | type = "image"; |
632 | break; | 632 | break; |
633 | case MAILIMAP_MEDIA_BASIC_MESSAGE: | 633 | case MAILIMAP_MEDIA_BASIC_MESSAGE: |
634 | type = "message"; | 634 | type = "message"; |
635 | break; | 635 | break; |
636 | case MAILIMAP_MEDIA_BASIC_VIDEO: | 636 | case MAILIMAP_MEDIA_BASIC_VIDEO: |
637 | type = "video"; | 637 | type = "video"; |
638 | break; | 638 | break; |
639 | case MAILIMAP_MEDIA_BASIC_OTHER: | 639 | case MAILIMAP_MEDIA_BASIC_OTHER: |
640 | default: | 640 | default: |
641 | if (which->bd_media_basic->med_basic_type) { | 641 | if (which->bd_media_basic->med_basic_type) { |
642 | type = which->bd_media_basic->med_basic_type; | 642 | type = which->bd_media_basic->med_basic_type; |
643 | } else { | 643 | } else { |
644 | type = ""; | 644 | type = ""; |
645 | } | 645 | } |
646 | break; | 646 | break; |
647 | } | 647 | } |
648 | if (which->bd_media_basic->med_subtype) { | 648 | if (which->bd_media_basic->med_subtype) { |
649 | sub = which->bd_media_basic->med_subtype; | 649 | sub = which->bd_media_basic->med_subtype; |
650 | } else { | 650 | } else { |
651 | sub = ""; | 651 | sub = ""; |
652 | } | 652 | } |
653 | qDebug("Type = %s/%s",type.latin1(),sub.latin1()); | 653 | qDebug("Type = %s/%s",type.latin1(),sub.latin1()); |
654 | target_part.setType(type.lower()); | 654 | target_part.setType(type.lower()); |
655 | target_part.setSubtype(sub.lower()); | 655 | target_part.setSubtype(sub.lower()); |
656 | fillBodyFields(target_part,which->bd_fields); | 656 | fillBodyFields(target_part,which->bd_fields); |
657 | } | 657 | } |
658 | 658 | ||
659 | void IMAPwrapper::fillBodyFields(RecPart&target_part,mailimap_body_fields*which) | 659 | void IMAPwrapper::fillBodyFields(RecPart&target_part,mailimap_body_fields*which) |
660 | { | 660 | { |
661 | if (!which) return; | 661 | if (!which) return; |
662 | if (which->bd_parameter && which->bd_parameter->pa_list && which->bd_parameter->pa_list->count>0) { | 662 | if (which->bd_parameter && which->bd_parameter->pa_list && which->bd_parameter->pa_list->count>0) { |
663 | clistcell*cur; | 663 | clistcell*cur; |
664 | mailimap_single_body_fld_param*param=0; | 664 | mailimap_single_body_fld_param*param=0; |
665 | for (cur = clist_begin(which->bd_parameter->pa_list);cur!=NULL;cur=clist_next(cur)) { | 665 | for (cur = clist_begin(which->bd_parameter->pa_list);cur!=NULL;cur=clist_next(cur)) { |
666 | param = (mailimap_single_body_fld_param*)cur->data; | 666 | param = (mailimap_single_body_fld_param*)cur->data; |
667 | if (param) { | 667 | if (param) { |
668 | target_part.addParameter(QString(param->pa_name).lower(),QString(param->pa_value)); | 668 | target_part.addParameter(QString(param->pa_name).lower(),QString(param->pa_value)); |
669 | } | 669 | } |
670 | } | 670 | } |
671 | } | 671 | } |
672 | mailimap_body_fld_enc*enc = which->bd_encoding; | 672 | mailimap_body_fld_enc*enc = which->bd_encoding; |
673 | QString encoding(""); | 673 | QString encoding(""); |
674 | switch (enc->enc_type) { | 674 | switch (enc->enc_type) { |
675 | case MAILIMAP_BODY_FLD_ENC_7BIT: | 675 | case MAILIMAP_BODY_FLD_ENC_7BIT: |
676 | encoding = "7bit"; | 676 | encoding = "7bit"; |
677 | break; | 677 | break; |
678 | case MAILIMAP_BODY_FLD_ENC_8BIT: | 678 | case MAILIMAP_BODY_FLD_ENC_8BIT: |
679 | encoding = "8bit"; | 679 | encoding = "8bit"; |
680 | break; | 680 | break; |
681 | case MAILIMAP_BODY_FLD_ENC_BINARY: | 681 | case MAILIMAP_BODY_FLD_ENC_BINARY: |
682 | encoding="binary"; | 682 | encoding="binary"; |
683 | break; | 683 | break; |
684 | case MAILIMAP_BODY_FLD_ENC_BASE64: | 684 | case MAILIMAP_BODY_FLD_ENC_BASE64: |
685 | encoding="base64"; | 685 | encoding="base64"; |
686 | break; | 686 | break; |
687 | case MAILIMAP_BODY_FLD_ENC_QUOTED_PRINTABLE: | 687 | case MAILIMAP_BODY_FLD_ENC_QUOTED_PRINTABLE: |
688 | encoding="quoted-printable"; | 688 | encoding="quoted-printable"; |
689 | break; | 689 | break; |
690 | case MAILIMAP_BODY_FLD_ENC_OTHER: | 690 | case MAILIMAP_BODY_FLD_ENC_OTHER: |
691 | default: | 691 | default: |
692 | if (enc->enc_value) { | 692 | if (enc->enc_value) { |
693 | char*t=enc->enc_value; | 693 | char*t=enc->enc_value; |
694 | encoding=QString(enc->enc_value); | 694 | encoding=QString(enc->enc_value); |
695 | enc->enc_value=0L; | 695 | enc->enc_value=0L; |
696 | free(t); | 696 | free(t); |
697 | } | 697 | } |
698 | } | 698 | } |
699 | if (which->bd_description) { | ||
700 | target_part.setDescription(QString(which->bd_description)); | ||
701 | } | ||
699 | target_part.setEncoding(encoding); | 702 | target_part.setEncoding(encoding); |
700 | target_part.setSize(which->bd_size); | 703 | target_part.setSize(which->bd_size); |
701 | } | 704 | } |
702 | 705 | ||
703 | QString IMAPwrapper::fetchPart(const RecMail&mail,const RecPart&part) | 706 | QString IMAPwrapper::fetchPart(const RecMail&mail,const RecPart&part) |
704 | { | 707 | { |
705 | return fetchPart(mail,part.Positionlist(),false); | 708 | return fetchPart(mail,part.Positionlist(),false); |
706 | } | 709 | } |
707 | 710 | ||
708 | void IMAPwrapper::deleteMail(const RecMail&mail) | 711 | void IMAPwrapper::deleteMail(const RecMail&mail) |
709 | { | 712 | { |
710 | mailimap_flag_list*flist; | 713 | mailimap_flag_list*flist; |
711 | mailimap_set *set; | 714 | mailimap_set *set; |
712 | mailimap_store_att_flags * store_flags; | 715 | mailimap_store_att_flags * store_flags; |
713 | int err; | 716 | int err; |
714 | login(); | 717 | login(); |
715 | if (!m_imap) { | 718 | if (!m_imap) { |
716 | return; | 719 | return; |
717 | } | 720 | } |
718 | const char *mb = mail.getMbox().latin1(); | 721 | const char *mb = mail.getMbox().latin1(); |
719 | err = mailimap_select( m_imap, (char*)mb); | 722 | err = mailimap_select( m_imap, (char*)mb); |
720 | if ( err != MAILIMAP_NO_ERROR ) { | 723 | if ( err != MAILIMAP_NO_ERROR ) { |
721 | qDebug("error selecting mailbox for delete: %s",m_imap->imap_response); | 724 | qDebug("error selecting mailbox for delete: %s",m_imap->imap_response); |
722 | return; | 725 | return; |
723 | } | 726 | } |
724 | flist = mailimap_flag_list_new_empty(); | 727 | flist = mailimap_flag_list_new_empty(); |
725 | mailimap_flag_list_add(flist,mailimap_flag_new_deleted()); | 728 | mailimap_flag_list_add(flist,mailimap_flag_new_deleted()); |
726 | store_flags = mailimap_store_att_flags_new_set_flags(flist); | 729 | store_flags = mailimap_store_att_flags_new_set_flags(flist); |
727 | set = mailimap_set_new_single(mail.getNumber()); | 730 | set = mailimap_set_new_single(mail.getNumber()); |
728 | err = mailimap_store(m_imap,set,store_flags); | 731 | err = mailimap_store(m_imap,set,store_flags); |
729 | mailimap_set_free( set ); | 732 | mailimap_set_free( set ); |
730 | mailimap_store_att_flags_free(store_flags); | 733 | mailimap_store_att_flags_free(store_flags); |
731 | 734 | ||
732 | if (err != MAILIMAP_NO_ERROR) { | 735 | if (err != MAILIMAP_NO_ERROR) { |
733 | qDebug("error deleting mail: %s",m_imap->imap_response); | 736 | qDebug("error deleting mail: %s",m_imap->imap_response); |
734 | return; | 737 | return; |
735 | } | 738 | } |
736 | qDebug("deleting mail: %s",m_imap->imap_response); | 739 | qDebug("deleting mail: %s",m_imap->imap_response); |
737 | /* should we realy do that at this moment? */ | 740 | /* should we realy do that at this moment? */ |
738 | err = mailimap_expunge(m_imap); | 741 | err = mailimap_expunge(m_imap); |
739 | if (err != MAILIMAP_NO_ERROR) { | 742 | if (err != MAILIMAP_NO_ERROR) { |
740 | qDebug("error deleting mail: %s",m_imap->imap_response); | 743 | qDebug("error deleting mail: %s",m_imap->imap_response); |
741 | } | 744 | } |
742 | qDebug("Delete successfull %s",m_imap->imap_response); | 745 | qDebug("Delete successfull %s",m_imap->imap_response); |
743 | } | 746 | } |
744 | 747 | ||
745 | void IMAPwrapper::answeredMail(const RecMail&mail) | 748 | void IMAPwrapper::answeredMail(const RecMail&mail) |
746 | { | 749 | { |
747 | mailimap_flag_list*flist; | 750 | mailimap_flag_list*flist; |
748 | mailimap_set *set; | 751 | mailimap_set *set; |
749 | mailimap_store_att_flags * store_flags; | 752 | mailimap_store_att_flags * store_flags; |
750 | int err; | 753 | int err; |
751 | login(); | 754 | login(); |
752 | if (!m_imap) { | 755 | if (!m_imap) { |
753 | return; | 756 | return; |
754 | } | 757 | } |
755 | const char *mb = mail.getMbox().latin1(); | 758 | const char *mb = mail.getMbox().latin1(); |
756 | err = mailimap_select( m_imap, (char*)mb); | 759 | err = mailimap_select( m_imap, (char*)mb); |
757 | if ( err != MAILIMAP_NO_ERROR ) { | 760 | if ( err != MAILIMAP_NO_ERROR ) { |
758 | qDebug("error selecting mailbox for mark: %s",m_imap->imap_response); | 761 | qDebug("error selecting mailbox for mark: %s",m_imap->imap_response); |
759 | return; | 762 | return; |
760 | } | 763 | } |
761 | flist = mailimap_flag_list_new_empty(); | 764 | flist = mailimap_flag_list_new_empty(); |
762 | mailimap_flag_list_add(flist,mailimap_flag_new_answered()); | 765 | mailimap_flag_list_add(flist,mailimap_flag_new_answered()); |
763 | store_flags = mailimap_store_att_flags_new_set_flags(flist); | 766 | store_flags = mailimap_store_att_flags_new_add_flags(flist); |
764 | set = mailimap_set_new_single(mail.getNumber()); | 767 | set = mailimap_set_new_single(mail.getNumber()); |
765 | err = mailimap_store(m_imap,set,store_flags); | 768 | err = mailimap_store(m_imap,set,store_flags); |
766 | mailimap_set_free( set ); | 769 | mailimap_set_free( set ); |
767 | mailimap_store_att_flags_free(store_flags); | 770 | mailimap_store_att_flags_free(store_flags); |
768 | 771 | ||
769 | if (err != MAILIMAP_NO_ERROR) { | 772 | if (err != MAILIMAP_NO_ERROR) { |
770 | qDebug("error marking mail: %s",m_imap->imap_response); | 773 | qDebug("error marking mail: %s",m_imap->imap_response); |
771 | return; | 774 | return; |
772 | } | 775 | } |
773 | } | 776 | } |
diff --git a/noncore/net/mail/libmailwrapper/mailtypes.cpp b/noncore/net/mail/libmailwrapper/mailtypes.cpp index 94f5d6f..8d9b247 100644 --- a/noncore/net/mail/libmailwrapper/mailtypes.cpp +++ b/noncore/net/mail/libmailwrapper/mailtypes.cpp | |||
@@ -1,237 +1,247 @@ | |||
1 | #include "mailtypes.h" | 1 | #include "mailtypes.h" |
2 | 2 | ||
3 | 3 | ||
4 | RecMail::RecMail() | 4 | RecMail::RecMail() |
5 | :subject(""),date(""),from(""),mbox(""),msg_id(""),msg_number(0),msg_size(0),msg_flags(7) | 5 | :subject(""),date(""),from(""),mbox(""),msg_id(""),msg_number(0),msg_size(0),msg_flags(7) |
6 | { | 6 | { |
7 | init(); | 7 | init(); |
8 | } | 8 | } |
9 | 9 | ||
10 | RecMail::RecMail(const RecMail&old) | 10 | RecMail::RecMail(const RecMail&old) |
11 | :subject(""),date(""),from(""),mbox(""),msg_id(""),msg_number(0),msg_flags(7) | 11 | :subject(""),date(""),from(""),mbox(""),msg_id(""),msg_number(0),msg_flags(7) |
12 | { | 12 | { |
13 | init(); | 13 | init(); |
14 | copy_old(old); | 14 | copy_old(old); |
15 | qDebug("Copy constructor RecMail"); | 15 | qDebug("Copy constructor RecMail"); |
16 | } | 16 | } |
17 | 17 | ||
18 | RecMail::~RecMail() | 18 | RecMail::~RecMail() |
19 | { | 19 | { |
20 | wrapper = 0; | 20 | wrapper = 0; |
21 | } | 21 | } |
22 | 22 | ||
23 | void RecMail::copy_old(const RecMail&old) | 23 | void RecMail::copy_old(const RecMail&old) |
24 | { | 24 | { |
25 | subject = old.subject; | 25 | subject = old.subject; |
26 | date = old.date; | 26 | date = old.date; |
27 | mbox = old.mbox; | 27 | mbox = old.mbox; |
28 | msg_id = old.msg_id; | 28 | msg_id = old.msg_id; |
29 | msg_size = old.msg_size; | 29 | msg_size = old.msg_size; |
30 | msg_number = old.msg_number; | 30 | msg_number = old.msg_number; |
31 | from = old.from; | 31 | from = old.from; |
32 | msg_flags = old.msg_flags; | 32 | msg_flags = old.msg_flags; |
33 | to = old.to; | 33 | to = old.to; |
34 | cc = old.cc; | 34 | cc = old.cc; |
35 | bcc = old.bcc; | 35 | bcc = old.bcc; |
36 | wrapper = old.wrapper; | 36 | wrapper = old.wrapper; |
37 | } | 37 | } |
38 | 38 | ||
39 | void RecMail::init() | 39 | void RecMail::init() |
40 | { | 40 | { |
41 | to.clear(); | 41 | to.clear(); |
42 | cc.clear(); | 42 | cc.clear(); |
43 | bcc.clear(); | 43 | bcc.clear(); |
44 | wrapper = 0; | 44 | wrapper = 0; |
45 | } | 45 | } |
46 | 46 | ||
47 | void RecMail::setWrapper(AbstractMail*awrapper) | 47 | void RecMail::setWrapper(AbstractMail*awrapper) |
48 | { | 48 | { |
49 | wrapper = awrapper; | 49 | wrapper = awrapper; |
50 | } | 50 | } |
51 | 51 | ||
52 | AbstractMail* RecMail::Wrapper() | 52 | AbstractMail* RecMail::Wrapper() |
53 | { | 53 | { |
54 | return wrapper; | 54 | return wrapper; |
55 | } | 55 | } |
56 | 56 | ||
57 | void RecMail::setTo(const QStringList&list) | 57 | void RecMail::setTo(const QStringList&list) |
58 | { | 58 | { |
59 | to = list; | 59 | to = list; |
60 | } | 60 | } |
61 | 61 | ||
62 | const QStringList&RecMail::To()const | 62 | const QStringList&RecMail::To()const |
63 | { | 63 | { |
64 | return to; | 64 | return to; |
65 | } | 65 | } |
66 | 66 | ||
67 | void RecMail::setCC(const QStringList&list) | 67 | void RecMail::setCC(const QStringList&list) |
68 | { | 68 | { |
69 | cc = list; | 69 | cc = list; |
70 | } | 70 | } |
71 | 71 | ||
72 | const QStringList&RecMail::CC()const | 72 | const QStringList&RecMail::CC()const |
73 | { | 73 | { |
74 | return cc; | 74 | return cc; |
75 | } | 75 | } |
76 | 76 | ||
77 | void RecMail::setBcc(const QStringList&list) | 77 | void RecMail::setBcc(const QStringList&list) |
78 | { | 78 | { |
79 | bcc = list; | 79 | bcc = list; |
80 | } | 80 | } |
81 | 81 | ||
82 | const QStringList& RecMail::Bcc()const | 82 | const QStringList& RecMail::Bcc()const |
83 | { | 83 | { |
84 | return bcc; | 84 | return bcc; |
85 | } | 85 | } |
86 | 86 | ||
87 | RecPart::RecPart() | 87 | RecPart::RecPart() |
88 | : m_type(""),m_subtype(""),m_identifier(""),m_encoding(""),m_lines(0),m_size(0) | 88 | : m_type(""),m_subtype(""),m_identifier(""),m_encoding(""),m_description(""),m_lines(0),m_size(0) |
89 | { | 89 | { |
90 | m_Parameters.clear(); | 90 | m_Parameters.clear(); |
91 | m_poslist.clear(); | 91 | m_poslist.clear(); |
92 | } | 92 | } |
93 | 93 | ||
94 | RecPart::~RecPart() | 94 | RecPart::~RecPart() |
95 | { | 95 | { |
96 | } | 96 | } |
97 | 97 | ||
98 | void RecPart::setSize(unsigned int size) | 98 | void RecPart::setSize(unsigned int size) |
99 | { | 99 | { |
100 | m_size = size; | 100 | m_size = size; |
101 | } | 101 | } |
102 | 102 | ||
103 | const unsigned int RecPart::Size()const | 103 | const unsigned int RecPart::Size()const |
104 | { | 104 | { |
105 | return m_size; | 105 | return m_size; |
106 | } | 106 | } |
107 | 107 | ||
108 | void RecPart::setLines(unsigned int lines) | 108 | void RecPart::setLines(unsigned int lines) |
109 | { | 109 | { |
110 | m_lines = lines; | 110 | m_lines = lines; |
111 | } | 111 | } |
112 | 112 | ||
113 | const unsigned int RecPart::Lines()const | 113 | const unsigned int RecPart::Lines()const |
114 | { | 114 | { |
115 | return m_lines; | 115 | return m_lines; |
116 | } | 116 | } |
117 | 117 | ||
118 | const QString& RecPart::Type()const | 118 | const QString& RecPart::Type()const |
119 | { | 119 | { |
120 | return m_type; | 120 | return m_type; |
121 | } | 121 | } |
122 | 122 | ||
123 | void RecPart::setType(const QString&type) | 123 | void RecPart::setType(const QString&type) |
124 | { | 124 | { |
125 | m_type = type; | 125 | m_type = type; |
126 | } | 126 | } |
127 | 127 | ||
128 | const QString& RecPart::Subtype()const | 128 | const QString& RecPart::Subtype()const |
129 | { | 129 | { |
130 | return m_subtype; | 130 | return m_subtype; |
131 | } | 131 | } |
132 | 132 | ||
133 | void RecPart::setSubtype(const QString&subtype) | 133 | void RecPart::setSubtype(const QString&subtype) |
134 | { | 134 | { |
135 | m_subtype = subtype; | 135 | m_subtype = subtype; |
136 | } | 136 | } |
137 | 137 | ||
138 | const QString& RecPart::Identifier()const | 138 | const QString& RecPart::Identifier()const |
139 | { | 139 | { |
140 | return m_identifier; | 140 | return m_identifier; |
141 | } | 141 | } |
142 | 142 | ||
143 | void RecPart::setIdentifier(const QString&identifier) | 143 | void RecPart::setIdentifier(const QString&identifier) |
144 | { | 144 | { |
145 | m_identifier = identifier; | 145 | m_identifier = identifier; |
146 | } | 146 | } |
147 | 147 | ||
148 | const QString& RecPart::Encoding()const | 148 | const QString& RecPart::Encoding()const |
149 | { | 149 | { |
150 | return m_encoding; | 150 | return m_encoding; |
151 | } | 151 | } |
152 | 152 | ||
153 | void RecPart::setEncoding(const QString&encoding) | 153 | void RecPart::setEncoding(const QString&encoding) |
154 | { | 154 | { |
155 | m_encoding = encoding; | 155 | m_encoding = encoding; |
156 | } | 156 | } |
157 | 157 | ||
158 | const QString& RecPart::Description()const | ||
159 | { | ||
160 | return m_description; | ||
161 | } | ||
162 | |||
163 | void RecPart::setDescription(const QString&desc) | ||
164 | { | ||
165 | m_description = desc; | ||
166 | } | ||
167 | |||
158 | void RecPart::setParameters(const part_plist_t&list) | 168 | void RecPart::setParameters(const part_plist_t&list) |
159 | { | 169 | { |
160 | m_Parameters = list; | 170 | m_Parameters = list; |
161 | } | 171 | } |
162 | 172 | ||
163 | const part_plist_t& RecPart::Parameters()const | 173 | const part_plist_t& RecPart::Parameters()const |
164 | { | 174 | { |
165 | return m_Parameters; | 175 | return m_Parameters; |
166 | } | 176 | } |
167 | 177 | ||
168 | void RecPart::addParameter(const QString&key,const QString&value) | 178 | void RecPart::addParameter(const QString&key,const QString&value) |
169 | { | 179 | { |
170 | m_Parameters[key]=value; | 180 | m_Parameters[key]=value; |
171 | } | 181 | } |
172 | 182 | ||
173 | const QString RecPart::searchParamter(const QString&key)const | 183 | const QString RecPart::searchParamter(const QString&key)const |
174 | { | 184 | { |
175 | QString value(""); | 185 | QString value(""); |
176 | part_plist_t::ConstIterator it = m_Parameters.find(key); | 186 | part_plist_t::ConstIterator it = m_Parameters.find(key); |
177 | if (it != m_Parameters.end()) { | 187 | if (it != m_Parameters.end()) { |
178 | value = it.data(); | 188 | value = it.data(); |
179 | } | 189 | } |
180 | return value; | 190 | return value; |
181 | } | 191 | } |
182 | 192 | ||
183 | void RecPart::setPositionlist(const QValueList<int>&poslist) | 193 | void RecPart::setPositionlist(const QValueList<int>&poslist) |
184 | { | 194 | { |
185 | m_poslist = poslist; | 195 | m_poslist = poslist; |
186 | } | 196 | } |
187 | 197 | ||
188 | const QValueList<int>& RecPart::Positionlist()const | 198 | const QValueList<int>& RecPart::Positionlist()const |
189 | { | 199 | { |
190 | return m_poslist; | 200 | return m_poslist; |
191 | } | 201 | } |
192 | 202 | ||
193 | RecBody::RecBody() | 203 | RecBody::RecBody() |
194 | : m_BodyText(),m_PartsList(),m_description() | 204 | : m_BodyText(),m_PartsList(),m_description() |
195 | { | 205 | { |
196 | m_PartsList.clear(); | 206 | m_PartsList.clear(); |
197 | } | 207 | } |
198 | 208 | ||
199 | RecBody::~RecBody() | 209 | RecBody::~RecBody() |
200 | { | 210 | { |
201 | } | 211 | } |
202 | 212 | ||
203 | void RecBody::setBodytext(const QString&bodyText) | 213 | void RecBody::setBodytext(const QString&bodyText) |
204 | { | 214 | { |
205 | m_BodyText = bodyText; | 215 | m_BodyText = bodyText; |
206 | } | 216 | } |
207 | 217 | ||
208 | const QString& RecBody::Bodytext()const | 218 | const QString& RecBody::Bodytext()const |
209 | { | 219 | { |
210 | return m_BodyText; | 220 | return m_BodyText; |
211 | } | 221 | } |
212 | 222 | ||
213 | void RecBody::setParts(const QValueList<RecPart>&parts) | 223 | void RecBody::setParts(const QValueList<RecPart>&parts) |
214 | { | 224 | { |
215 | m_PartsList.clear(); | 225 | m_PartsList.clear(); |
216 | m_PartsList = parts; | 226 | m_PartsList = parts; |
217 | } | 227 | } |
218 | 228 | ||
219 | const QValueList<RecPart>& RecBody::Parts()const | 229 | const QValueList<RecPart>& RecBody::Parts()const |
220 | { | 230 | { |
221 | return m_PartsList; | 231 | return m_PartsList; |
222 | } | 232 | } |
223 | 233 | ||
224 | void RecBody::addPart(const RecPart& part) | 234 | void RecBody::addPart(const RecPart& part) |
225 | { | 235 | { |
226 | m_PartsList.append(part); | 236 | m_PartsList.append(part); |
227 | } | 237 | } |
228 | 238 | ||
229 | void RecBody::setDescription(const RecPart&des) | 239 | void RecBody::setDescription(const RecPart&des) |
230 | { | 240 | { |
231 | m_description = des; | 241 | m_description = des; |
232 | } | 242 | } |
233 | 243 | ||
234 | const RecPart& RecBody::Description()const | 244 | const RecPart& RecBody::Description()const |
235 | { | 245 | { |
236 | return m_description; | 246 | return m_description; |
237 | } | 247 | } |
diff --git a/noncore/net/mail/libmailwrapper/mailtypes.h b/noncore/net/mail/libmailwrapper/mailtypes.h index 9ef762d..7d7bebc 100644 --- a/noncore/net/mail/libmailwrapper/mailtypes.h +++ b/noncore/net/mail/libmailwrapper/mailtypes.h | |||
@@ -1,136 +1,138 @@ | |||
1 | #ifndef __MAIL_TYPES_H | 1 | #ifndef __MAIL_TYPES_H |
2 | #define __MAIL_TYPES_H | 2 | #define __MAIL_TYPES_H |
3 | 3 | ||
4 | #define FLAG_ANSWERED 0 | 4 | #define FLAG_ANSWERED 0 |
5 | #define FLAG_FLAGGED 1 | 5 | #define FLAG_FLAGGED 1 |
6 | #define FLAG_DELETED 2 | 6 | #define FLAG_DELETED 2 |
7 | #define FLAG_SEEN 3 | 7 | #define FLAG_SEEN 3 |
8 | #define FLAG_DRAFT 4 | 8 | #define FLAG_DRAFT 4 |
9 | #define FLAG_RECENT 5 | 9 | #define FLAG_RECENT 5 |
10 | 10 | ||
11 | #include <qlist.h> | 11 | #include <qlist.h> |
12 | #include <qbitarray.h> | 12 | #include <qbitarray.h> |
13 | #include <qstring.h> | 13 | #include <qstring.h> |
14 | #include <qstringlist.h> | 14 | #include <qstringlist.h> |
15 | #include <qmap.h> | 15 | #include <qmap.h> |
16 | #include <qvaluelist.h> | 16 | #include <qvaluelist.h> |
17 | 17 | ||
18 | class AbstractMail; | 18 | class AbstractMail; |
19 | /* a class to describe mails in a mailbox */ | 19 | /* a class to describe mails in a mailbox */ |
20 | /* Attention! | 20 | /* Attention! |
21 | From programmers point of view it would make sense to | 21 | From programmers point of view it would make sense to |
22 | store the mail body into this class, too. | 22 | store the mail body into this class, too. |
23 | But: not from the point of view of the device. | 23 | But: not from the point of view of the device. |
24 | Mailbodies can be real large. So we request them when | 24 | Mailbodies can be real large. So we request them when |
25 | needed from the mail-wrapper class direct from the server itself | 25 | needed from the mail-wrapper class direct from the server itself |
26 | (imap) or from a file-based cache (pop3?) | 26 | (imap) or from a file-based cache (pop3?) |
27 | So there is no interface "const QString&body()" but you should | 27 | So there is no interface "const QString&body()" but you should |
28 | make a request to the mailwrapper with this class as parameter to | 28 | make a request to the mailwrapper with this class as parameter to |
29 | get the body. Same words for the attachments. | 29 | get the body. Same words for the attachments. |
30 | */ | 30 | */ |
31 | class RecMail | 31 | class RecMail |
32 | { | 32 | { |
33 | public: | 33 | public: |
34 | RecMail(); | 34 | RecMail(); |
35 | RecMail(const RecMail&old); | 35 | RecMail(const RecMail&old); |
36 | virtual ~RecMail(); | 36 | virtual ~RecMail(); |
37 | 37 | ||
38 | const int getNumber()const{return msg_number;} | 38 | const int getNumber()const{return msg_number;} |
39 | void setNumber(int number){msg_number=number;} | 39 | void setNumber(int number){msg_number=number;} |
40 | const QString&getDate()const{ return date; } | 40 | const QString&getDate()const{ return date; } |
41 | void setDate( const QString&a ) { date = a; } | 41 | void setDate( const QString&a ) { date = a; } |
42 | const QString&getFrom()const{ return from; } | 42 | const QString&getFrom()const{ return from; } |
43 | void setFrom( const QString&a ) { from = a; } | 43 | void setFrom( const QString&a ) { from = a; } |
44 | const QString&getSubject()const { return subject; } | 44 | const QString&getSubject()const { return subject; } |
45 | void setSubject( const QString&s ) { subject = s; } | 45 | void setSubject( const QString&s ) { subject = s; } |
46 | const QString&getMbox()const{return mbox;} | 46 | const QString&getMbox()const{return mbox;} |
47 | void setMbox(const QString&box){mbox = box;} | 47 | void setMbox(const QString&box){mbox = box;} |
48 | void setMsgid(const QString&id){msg_id=id;} | 48 | void setMsgid(const QString&id){msg_id=id;} |
49 | const QString&Msgid()const{return msg_id;} | 49 | const QString&Msgid()const{return msg_id;} |
50 | void setReplyto(const QString&reply){replyto=reply;} | 50 | void setReplyto(const QString&reply){replyto=reply;} |
51 | const QString&Replyto()const{return replyto;} | 51 | const QString&Replyto()const{return replyto;} |
52 | void setMsgsize(int size){msg_size = size;} | 52 | void setMsgsize(int size){msg_size = size;} |
53 | const int Msgsize()const{return msg_size;} | 53 | const int Msgsize()const{return msg_size;} |
54 | 54 | ||
55 | 55 | ||
56 | void setTo(const QStringList&list); | 56 | void setTo(const QStringList&list); |
57 | const QStringList&To()const; | 57 | const QStringList&To()const; |
58 | void setCC(const QStringList&list); | 58 | void setCC(const QStringList&list); |
59 | const QStringList&CC()const; | 59 | const QStringList&CC()const; |
60 | void setBcc(const QStringList&list); | 60 | void setBcc(const QStringList&list); |
61 | const QStringList&Bcc()const; | 61 | const QStringList&Bcc()const; |
62 | const QBitArray&getFlags()const{return msg_flags;} | 62 | const QBitArray&getFlags()const{return msg_flags;} |
63 | void setFlags(const QBitArray&flags){msg_flags = flags;} | 63 | void setFlags(const QBitArray&flags){msg_flags = flags;} |
64 | 64 | ||
65 | void setWrapper(AbstractMail*wrapper); | 65 | void setWrapper(AbstractMail*wrapper); |
66 | AbstractMail* Wrapper(); | 66 | AbstractMail* Wrapper(); |
67 | 67 | ||
68 | protected: | 68 | protected: |
69 | QString subject,date,from,mbox,msg_id,replyto; | 69 | QString subject,date,from,mbox,msg_id,replyto; |
70 | int msg_number,msg_size; | 70 | int msg_number,msg_size; |
71 | QBitArray msg_flags; | 71 | QBitArray msg_flags; |
72 | QStringList to,cc,bcc; | 72 | QStringList to,cc,bcc; |
73 | AbstractMail*wrapper; | 73 | AbstractMail*wrapper; |
74 | void init(); | 74 | void init(); |
75 | void copy_old(const RecMail&old); | 75 | void copy_old(const RecMail&old); |
76 | }; | 76 | }; |
77 | 77 | ||
78 | typedef QMap<QString,QString> part_plist_t; | 78 | typedef QMap<QString,QString> part_plist_t; |
79 | 79 | ||
80 | class RecPart | 80 | class RecPart |
81 | { | 81 | { |
82 | protected: | 82 | protected: |
83 | QString m_type,m_subtype,m_identifier,m_encoding; | 83 | QString m_type,m_subtype,m_identifier,m_encoding,m_description; |
84 | unsigned int m_lines,m_size; | 84 | unsigned int m_lines,m_size; |
85 | part_plist_t m_Parameters; | 85 | part_plist_t m_Parameters; |
86 | /* describes the position in the mail */ | 86 | /* describes the position in the mail */ |
87 | QValueList<int> m_poslist; | 87 | QValueList<int> m_poslist; |
88 | 88 | ||
89 | public: | 89 | public: |
90 | RecPart(); | 90 | RecPart(); |
91 | virtual ~RecPart(); | 91 | virtual ~RecPart(); |
92 | 92 | ||
93 | const QString&Type()const; | 93 | const QString&Type()const; |
94 | void setType(const QString&type); | 94 | void setType(const QString&type); |
95 | const QString&Subtype()const; | 95 | const QString&Subtype()const; |
96 | void setSubtype(const QString&subtype); | 96 | void setSubtype(const QString&subtype); |
97 | const QString&Identifier()const; | 97 | const QString&Identifier()const; |
98 | void setIdentifier(const QString&identifier); | 98 | void setIdentifier(const QString&identifier); |
99 | const QString&Encoding()const; | 99 | const QString&Encoding()const; |
100 | void setEncoding(const QString&encoding); | 100 | void setEncoding(const QString&encoding); |
101 | const QString&Description()const; | ||
102 | void setDescription(const QString&desc); | ||
101 | void setLines(unsigned int lines); | 103 | void setLines(unsigned int lines); |
102 | const unsigned int Lines()const; | 104 | const unsigned int Lines()const; |
103 | void setSize(unsigned int size); | 105 | void setSize(unsigned int size); |
104 | const unsigned int Size()const; | 106 | const unsigned int Size()const; |
105 | 107 | ||
106 | 108 | ||
107 | void setParameters(const part_plist_t&list); | 109 | void setParameters(const part_plist_t&list); |
108 | const part_plist_t&Parameters()const; | 110 | const part_plist_t&Parameters()const; |
109 | void addParameter(const QString&key,const QString&value); | 111 | void addParameter(const QString&key,const QString&value); |
110 | const QString searchParamter(const QString&key)const; | 112 | const QString searchParamter(const QString&key)const; |
111 | void setPositionlist(const QValueList<int>&poslist); | 113 | void setPositionlist(const QValueList<int>&poslist); |
112 | const QValueList<int>& Positionlist()const; | 114 | const QValueList<int>& Positionlist()const; |
113 | }; | 115 | }; |
114 | 116 | ||
115 | class RecBody | 117 | class RecBody |
116 | { | 118 | { |
117 | protected: | 119 | protected: |
118 | QString m_BodyText; | 120 | QString m_BodyText; |
119 | QValueList<RecPart> m_PartsList; | 121 | QValueList<RecPart> m_PartsList; |
120 | RecPart m_description; | 122 | RecPart m_description; |
121 | 123 | ||
122 | public: | 124 | public: |
123 | RecBody(); | 125 | RecBody(); |
124 | virtual ~RecBody(); | 126 | virtual ~RecBody(); |
125 | void setBodytext(const QString&); | 127 | void setBodytext(const QString&); |
126 | const QString& Bodytext()const; | 128 | const QString& Bodytext()const; |
127 | 129 | ||
128 | void setDescription(const RecPart&des); | 130 | void setDescription(const RecPart&des); |
129 | const RecPart& Description()const; | 131 | const RecPart& Description()const; |
130 | 132 | ||
131 | void setParts(const QValueList<RecPart>&parts); | 133 | void setParts(const QValueList<RecPart>&parts); |
132 | const QValueList<RecPart>& Parts()const; | 134 | const QValueList<RecPart>& Parts()const; |
133 | void addPart(const RecPart&part); | 135 | void addPart(const RecPart&part); |
134 | }; | 136 | }; |
135 | 137 | ||
136 | #endif | 138 | #endif |
diff --git a/noncore/net/mail/mailtypes.cpp b/noncore/net/mail/mailtypes.cpp index 94f5d6f..8d9b247 100644 --- a/noncore/net/mail/mailtypes.cpp +++ b/noncore/net/mail/mailtypes.cpp | |||
@@ -1,237 +1,247 @@ | |||
1 | #include "mailtypes.h" | 1 | #include "mailtypes.h" |
2 | 2 | ||
3 | 3 | ||
4 | RecMail::RecMail() | 4 | RecMail::RecMail() |
5 | :subject(""),date(""),from(""),mbox(""),msg_id(""),msg_number(0),msg_size(0),msg_flags(7) | 5 | :subject(""),date(""),from(""),mbox(""),msg_id(""),msg_number(0),msg_size(0),msg_flags(7) |
6 | { | 6 | { |
7 | init(); | 7 | init(); |
8 | } | 8 | } |
9 | 9 | ||
10 | RecMail::RecMail(const RecMail&old) | 10 | RecMail::RecMail(const RecMail&old) |
11 | :subject(""),date(""),from(""),mbox(""),msg_id(""),msg_number(0),msg_flags(7) | 11 | :subject(""),date(""),from(""),mbox(""),msg_id(""),msg_number(0),msg_flags(7) |
12 | { | 12 | { |
13 | init(); | 13 | init(); |
14 | copy_old(old); | 14 | copy_old(old); |
15 | qDebug("Copy constructor RecMail"); | 15 | qDebug("Copy constructor RecMail"); |
16 | } | 16 | } |
17 | 17 | ||
18 | RecMail::~RecMail() | 18 | RecMail::~RecMail() |
19 | { | 19 | { |
20 | wrapper = 0; | 20 | wrapper = 0; |
21 | } | 21 | } |
22 | 22 | ||
23 | void RecMail::copy_old(const RecMail&old) | 23 | void RecMail::copy_old(const RecMail&old) |
24 | { | 24 | { |
25 | subject = old.subject; | 25 | subject = old.subject; |
26 | date = old.date; | 26 | date = old.date; |
27 | mbox = old.mbox; | 27 | mbox = old.mbox; |
28 | msg_id = old.msg_id; | 28 | msg_id = old.msg_id; |
29 | msg_size = old.msg_size; | 29 | msg_size = old.msg_size; |
30 | msg_number = old.msg_number; | 30 | msg_number = old.msg_number; |
31 | from = old.from; | 31 | from = old.from; |
32 | msg_flags = old.msg_flags; | 32 | msg_flags = old.msg_flags; |
33 | to = old.to; | 33 | to = old.to; |
34 | cc = old.cc; | 34 | cc = old.cc; |
35 | bcc = old.bcc; | 35 | bcc = old.bcc; |
36 | wrapper = old.wrapper; | 36 | wrapper = old.wrapper; |
37 | } | 37 | } |
38 | 38 | ||
39 | void RecMail::init() | 39 | void RecMail::init() |
40 | { | 40 | { |
41 | to.clear(); | 41 | to.clear(); |
42 | cc.clear(); | 42 | cc.clear(); |
43 | bcc.clear(); | 43 | bcc.clear(); |
44 | wrapper = 0; | 44 | wrapper = 0; |
45 | } | 45 | } |
46 | 46 | ||
47 | void RecMail::setWrapper(AbstractMail*awrapper) | 47 | void RecMail::setWrapper(AbstractMail*awrapper) |
48 | { | 48 | { |
49 | wrapper = awrapper; | 49 | wrapper = awrapper; |
50 | } | 50 | } |
51 | 51 | ||
52 | AbstractMail* RecMail::Wrapper() | 52 | AbstractMail* RecMail::Wrapper() |
53 | { | 53 | { |
54 | return wrapper; | 54 | return wrapper; |
55 | } | 55 | } |
56 | 56 | ||
57 | void RecMail::setTo(const QStringList&list) | 57 | void RecMail::setTo(const QStringList&list) |
58 | { | 58 | { |
59 | to = list; | 59 | to = list; |
60 | } | 60 | } |
61 | 61 | ||
62 | const QStringList&RecMail::To()const | 62 | const QStringList&RecMail::To()const |
63 | { | 63 | { |
64 | return to; | 64 | return to; |
65 | } | 65 | } |
66 | 66 | ||
67 | void RecMail::setCC(const QStringList&list) | 67 | void RecMail::setCC(const QStringList&list) |
68 | { | 68 | { |
69 | cc = list; | 69 | cc = list; |
70 | } | 70 | } |
71 | 71 | ||
72 | const QStringList&RecMail::CC()const | 72 | const QStringList&RecMail::CC()const |
73 | { | 73 | { |
74 | return cc; | 74 | return cc; |
75 | } | 75 | } |
76 | 76 | ||
77 | void RecMail::setBcc(const QStringList&list) | 77 | void RecMail::setBcc(const QStringList&list) |
78 | { | 78 | { |
79 | bcc = list; | 79 | bcc = list; |
80 | } | 80 | } |
81 | 81 | ||
82 | const QStringList& RecMail::Bcc()const | 82 | const QStringList& RecMail::Bcc()const |
83 | { | 83 | { |
84 | return bcc; | 84 | return bcc; |
85 | } | 85 | } |
86 | 86 | ||
87 | RecPart::RecPart() | 87 | RecPart::RecPart() |
88 | : m_type(""),m_subtype(""),m_identifier(""),m_encoding(""),m_lines(0),m_size(0) | 88 | : m_type(""),m_subtype(""),m_identifier(""),m_encoding(""),m_description(""),m_lines(0),m_size(0) |
89 | { | 89 | { |
90 | m_Parameters.clear(); | 90 | m_Parameters.clear(); |
91 | m_poslist.clear(); | 91 | m_poslist.clear(); |
92 | } | 92 | } |
93 | 93 | ||
94 | RecPart::~RecPart() | 94 | RecPart::~RecPart() |
95 | { | 95 | { |
96 | } | 96 | } |
97 | 97 | ||
98 | void RecPart::setSize(unsigned int size) | 98 | void RecPart::setSize(unsigned int size) |
99 | { | 99 | { |
100 | m_size = size; | 100 | m_size = size; |
101 | } | 101 | } |
102 | 102 | ||
103 | const unsigned int RecPart::Size()const | 103 | const unsigned int RecPart::Size()const |
104 | { | 104 | { |
105 | return m_size; | 105 | return m_size; |
106 | } | 106 | } |
107 | 107 | ||
108 | void RecPart::setLines(unsigned int lines) | 108 | void RecPart::setLines(unsigned int lines) |
109 | { | 109 | { |
110 | m_lines = lines; | 110 | m_lines = lines; |
111 | } | 111 | } |
112 | 112 | ||
113 | const unsigned int RecPart::Lines()const | 113 | const unsigned int RecPart::Lines()const |
114 | { | 114 | { |
115 | return m_lines; | 115 | return m_lines; |
116 | } | 116 | } |
117 | 117 | ||
118 | const QString& RecPart::Type()const | 118 | const QString& RecPart::Type()const |
119 | { | 119 | { |
120 | return m_type; | 120 | return m_type; |
121 | } | 121 | } |
122 | 122 | ||
123 | void RecPart::setType(const QString&type) | 123 | void RecPart::setType(const QString&type) |
124 | { | 124 | { |
125 | m_type = type; | 125 | m_type = type; |
126 | } | 126 | } |
127 | 127 | ||
128 | const QString& RecPart::Subtype()const | 128 | const QString& RecPart::Subtype()const |
129 | { | 129 | { |
130 | return m_subtype; | 130 | return m_subtype; |
131 | } | 131 | } |
132 | 132 | ||
133 | void RecPart::setSubtype(const QString&subtype) | 133 | void RecPart::setSubtype(const QString&subtype) |
134 | { | 134 | { |
135 | m_subtype = subtype; | 135 | m_subtype = subtype; |
136 | } | 136 | } |
137 | 137 | ||
138 | const QString& RecPart::Identifier()const | 138 | const QString& RecPart::Identifier()const |
139 | { | 139 | { |
140 | return m_identifier; | 140 | return m_identifier; |
141 | } | 141 | } |
142 | 142 | ||
143 | void RecPart::setIdentifier(const QString&identifier) | 143 | void RecPart::setIdentifier(const QString&identifier) |
144 | { | 144 | { |
145 | m_identifier = identifier; | 145 | m_identifier = identifier; |
146 | } | 146 | } |
147 | 147 | ||
148 | const QString& RecPart::Encoding()const | 148 | const QString& RecPart::Encoding()const |
149 | { | 149 | { |
150 | return m_encoding; | 150 | return m_encoding; |
151 | } | 151 | } |
152 | 152 | ||
153 | void RecPart::setEncoding(const QString&encoding) | 153 | void RecPart::setEncoding(const QString&encoding) |
154 | { | 154 | { |
155 | m_encoding = encoding; | 155 | m_encoding = encoding; |
156 | } | 156 | } |
157 | 157 | ||
158 | const QString& RecPart::Description()const | ||
159 | { | ||
160 | return m_description; | ||
161 | } | ||
162 | |||
163 | void RecPart::setDescription(const QString&desc) | ||
164 | { | ||
165 | m_description = desc; | ||
166 | } | ||
167 | |||
158 | void RecPart::setParameters(const part_plist_t&list) | 168 | void RecPart::setParameters(const part_plist_t&list) |
159 | { | 169 | { |
160 | m_Parameters = list; | 170 | m_Parameters = list; |
161 | } | 171 | } |
162 | 172 | ||
163 | const part_plist_t& RecPart::Parameters()const | 173 | const part_plist_t& RecPart::Parameters()const |
164 | { | 174 | { |
165 | return m_Parameters; | 175 | return m_Parameters; |
166 | } | 176 | } |
167 | 177 | ||
168 | void RecPart::addParameter(const QString&key,const QString&value) | 178 | void RecPart::addParameter(const QString&key,const QString&value) |
169 | { | 179 | { |
170 | m_Parameters[key]=value; | 180 | m_Parameters[key]=value; |
171 | } | 181 | } |
172 | 182 | ||
173 | const QString RecPart::searchParamter(const QString&key)const | 183 | const QString RecPart::searchParamter(const QString&key)const |
174 | { | 184 | { |
175 | QString value(""); | 185 | QString value(""); |
176 | part_plist_t::ConstIterator it = m_Parameters.find(key); | 186 | part_plist_t::ConstIterator it = m_Parameters.find(key); |
177 | if (it != m_Parameters.end()) { | 187 | if (it != m_Parameters.end()) { |
178 | value = it.data(); | 188 | value = it.data(); |
179 | } | 189 | } |
180 | return value; | 190 | return value; |
181 | } | 191 | } |
182 | 192 | ||
183 | void RecPart::setPositionlist(const QValueList<int>&poslist) | 193 | void RecPart::setPositionlist(const QValueList<int>&poslist) |
184 | { | 194 | { |
185 | m_poslist = poslist; | 195 | m_poslist = poslist; |
186 | } | 196 | } |
187 | 197 | ||
188 | const QValueList<int>& RecPart::Positionlist()const | 198 | const QValueList<int>& RecPart::Positionlist()const |
189 | { | 199 | { |
190 | return m_poslist; | 200 | return m_poslist; |
191 | } | 201 | } |
192 | 202 | ||
193 | RecBody::RecBody() | 203 | RecBody::RecBody() |
194 | : m_BodyText(),m_PartsList(),m_description() | 204 | : m_BodyText(),m_PartsList(),m_description() |
195 | { | 205 | { |
196 | m_PartsList.clear(); | 206 | m_PartsList.clear(); |
197 | } | 207 | } |
198 | 208 | ||
199 | RecBody::~RecBody() | 209 | RecBody::~RecBody() |
200 | { | 210 | { |
201 | } | 211 | } |
202 | 212 | ||
203 | void RecBody::setBodytext(const QString&bodyText) | 213 | void RecBody::setBodytext(const QString&bodyText) |
204 | { | 214 | { |
205 | m_BodyText = bodyText; | 215 | m_BodyText = bodyText; |
206 | } | 216 | } |
207 | 217 | ||
208 | const QString& RecBody::Bodytext()const | 218 | const QString& RecBody::Bodytext()const |
209 | { | 219 | { |
210 | return m_BodyText; | 220 | return m_BodyText; |
211 | } | 221 | } |
212 | 222 | ||
213 | void RecBody::setParts(const QValueList<RecPart>&parts) | 223 | void RecBody::setParts(const QValueList<RecPart>&parts) |
214 | { | 224 | { |
215 | m_PartsList.clear(); | 225 | m_PartsList.clear(); |
216 | m_PartsList = parts; | 226 | m_PartsList = parts; |
217 | } | 227 | } |
218 | 228 | ||
219 | const QValueList<RecPart>& RecBody::Parts()const | 229 | const QValueList<RecPart>& RecBody::Parts()const |
220 | { | 230 | { |
221 | return m_PartsList; | 231 | return m_PartsList; |
222 | } | 232 | } |
223 | 233 | ||
224 | void RecBody::addPart(const RecPart& part) | 234 | void RecBody::addPart(const RecPart& part) |
225 | { | 235 | { |
226 | m_PartsList.append(part); | 236 | m_PartsList.append(part); |
227 | } | 237 | } |
228 | 238 | ||
229 | void RecBody::setDescription(const RecPart&des) | 239 | void RecBody::setDescription(const RecPart&des) |
230 | { | 240 | { |
231 | m_description = des; | 241 | m_description = des; |
232 | } | 242 | } |
233 | 243 | ||
234 | const RecPart& RecBody::Description()const | 244 | const RecPart& RecBody::Description()const |
235 | { | 245 | { |
236 | return m_description; | 246 | return m_description; |
237 | } | 247 | } |
diff --git a/noncore/net/mail/mailtypes.h b/noncore/net/mail/mailtypes.h index 9ef762d..7d7bebc 100644 --- a/noncore/net/mail/mailtypes.h +++ b/noncore/net/mail/mailtypes.h | |||
@@ -1,136 +1,138 @@ | |||
1 | #ifndef __MAIL_TYPES_H | 1 | #ifndef __MAIL_TYPES_H |
2 | #define __MAIL_TYPES_H | 2 | #define __MAIL_TYPES_H |
3 | 3 | ||
4 | #define FLAG_ANSWERED 0 | 4 | #define FLAG_ANSWERED 0 |
5 | #define FLAG_FLAGGED 1 | 5 | #define FLAG_FLAGGED 1 |
6 | #define FLAG_DELETED 2 | 6 | #define FLAG_DELETED 2 |
7 | #define FLAG_SEEN 3 | 7 | #define FLAG_SEEN 3 |
8 | #define FLAG_DRAFT 4 | 8 | #define FLAG_DRAFT 4 |
9 | #define FLAG_RECENT 5 | 9 | #define FLAG_RECENT 5 |
10 | 10 | ||
11 | #include <qlist.h> | 11 | #include <qlist.h> |
12 | #include <qbitarray.h> | 12 | #include <qbitarray.h> |
13 | #include <qstring.h> | 13 | #include <qstring.h> |
14 | #include <qstringlist.h> | 14 | #include <qstringlist.h> |
15 | #include <qmap.h> | 15 | #include <qmap.h> |
16 | #include <qvaluelist.h> | 16 | #include <qvaluelist.h> |
17 | 17 | ||
18 | class AbstractMail; | 18 | class AbstractMail; |
19 | /* a class to describe mails in a mailbox */ | 19 | /* a class to describe mails in a mailbox */ |
20 | /* Attention! | 20 | /* Attention! |
21 | From programmers point of view it would make sense to | 21 | From programmers point of view it would make sense to |
22 | store the mail body into this class, too. | 22 | store the mail body into this class, too. |
23 | But: not from the point of view of the device. | 23 | But: not from the point of view of the device. |
24 | Mailbodies can be real large. So we request them when | 24 | Mailbodies can be real large. So we request them when |
25 | needed from the mail-wrapper class direct from the server itself | 25 | needed from the mail-wrapper class direct from the server itself |
26 | (imap) or from a file-based cache (pop3?) | 26 | (imap) or from a file-based cache (pop3?) |
27 | So there is no interface "const QString&body()" but you should | 27 | So there is no interface "const QString&body()" but you should |
28 | make a request to the mailwrapper with this class as parameter to | 28 | make a request to the mailwrapper with this class as parameter to |
29 | get the body. Same words for the attachments. | 29 | get the body. Same words for the attachments. |
30 | */ | 30 | */ |
31 | class RecMail | 31 | class RecMail |
32 | { | 32 | { |
33 | public: | 33 | public: |
34 | RecMail(); | 34 | RecMail(); |
35 | RecMail(const RecMail&old); | 35 | RecMail(const RecMail&old); |
36 | virtual ~RecMail(); | 36 | virtual ~RecMail(); |
37 | 37 | ||
38 | const int getNumber()const{return msg_number;} | 38 | const int getNumber()const{return msg_number;} |
39 | void setNumber(int number){msg_number=number;} | 39 | void setNumber(int number){msg_number=number;} |
40 | const QString&getDate()const{ return date; } | 40 | const QString&getDate()const{ return date; } |
41 | void setDate( const QString&a ) { date = a; } | 41 | void setDate( const QString&a ) { date = a; } |
42 | const QString&getFrom()const{ return from; } | 42 | const QString&getFrom()const{ return from; } |
43 | void setFrom( const QString&a ) { from = a; } | 43 | void setFrom( const QString&a ) { from = a; } |
44 | const QString&getSubject()const { return subject; } | 44 | const QString&getSubject()const { return subject; } |
45 | void setSubject( const QString&s ) { subject = s; } | 45 | void setSubject( const QString&s ) { subject = s; } |
46 | const QString&getMbox()const{return mbox;} | 46 | const QString&getMbox()const{return mbox;} |
47 | void setMbox(const QString&box){mbox = box;} | 47 | void setMbox(const QString&box){mbox = box;} |
48 | void setMsgid(const QString&id){msg_id=id;} | 48 | void setMsgid(const QString&id){msg_id=id;} |
49 | const QString&Msgid()const{return msg_id;} | 49 | const QString&Msgid()const{return msg_id;} |
50 | void setReplyto(const QString&reply){replyto=reply;} | 50 | void setReplyto(const QString&reply){replyto=reply;} |
51 | const QString&Replyto()const{return replyto;} | 51 | const QString&Replyto()const{return replyto;} |
52 | void setMsgsize(int size){msg_size = size;} | 52 | void setMsgsize(int size){msg_size = size;} |
53 | const int Msgsize()const{return msg_size;} | 53 | const int Msgsize()const{return msg_size;} |
54 | 54 | ||
55 | 55 | ||
56 | void setTo(const QStringList&list); | 56 | void setTo(const QStringList&list); |
57 | const QStringList&To()const; | 57 | const QStringList&To()const; |
58 | void setCC(const QStringList&list); | 58 | void setCC(const QStringList&list); |
59 | const QStringList&CC()const; | 59 | const QStringList&CC()const; |
60 | void setBcc(const QStringList&list); | 60 | void setBcc(const QStringList&list); |
61 | const QStringList&Bcc()const; | 61 | const QStringList&Bcc()const; |
62 | const QBitArray&getFlags()const{return msg_flags;} | 62 | const QBitArray&getFlags()const{return msg_flags;} |
63 | void setFlags(const QBitArray&flags){msg_flags = flags;} | 63 | void setFlags(const QBitArray&flags){msg_flags = flags;} |
64 | 64 | ||
65 | void setWrapper(AbstractMail*wrapper); | 65 | void setWrapper(AbstractMail*wrapper); |
66 | AbstractMail* Wrapper(); | 66 | AbstractMail* Wrapper(); |
67 | 67 | ||
68 | protected: | 68 | protected: |
69 | QString subject,date,from,mbox,msg_id,replyto; | 69 | QString subject,date,from,mbox,msg_id,replyto; |
70 | int msg_number,msg_size; | 70 | int msg_number,msg_size; |
71 | QBitArray msg_flags; | 71 | QBitArray msg_flags; |
72 | QStringList to,cc,bcc; | 72 | QStringList to,cc,bcc; |
73 | AbstractMail*wrapper; | 73 | AbstractMail*wrapper; |
74 | void init(); | 74 | void init(); |
75 | void copy_old(const RecMail&old); | 75 | void copy_old(const RecMail&old); |
76 | }; | 76 | }; |
77 | 77 | ||
78 | typedef QMap<QString,QString> part_plist_t; | 78 | typedef QMap<QString,QString> part_plist_t; |
79 | 79 | ||
80 | class RecPart | 80 | class RecPart |
81 | { | 81 | { |
82 | protected: | 82 | protected: |
83 | QString m_type,m_subtype,m_identifier,m_encoding; | 83 | QString m_type,m_subtype,m_identifier,m_encoding,m_description; |
84 | unsigned int m_lines,m_size; | 84 | unsigned int m_lines,m_size; |
85 | part_plist_t m_Parameters; | 85 | part_plist_t m_Parameters; |
86 | /* describes the position in the mail */ | 86 | /* describes the position in the mail */ |
87 | QValueList<int> m_poslist; | 87 | QValueList<int> m_poslist; |
88 | 88 | ||
89 | public: | 89 | public: |
90 | RecPart(); | 90 | RecPart(); |
91 | virtual ~RecPart(); | 91 | virtual ~RecPart(); |
92 | 92 | ||
93 | const QString&Type()const; | 93 | const QString&Type()const; |
94 | void setType(const QString&type); | 94 | void setType(const QString&type); |
95 | const QString&Subtype()const; | 95 | const QString&Subtype()const; |
96 | void setSubtype(const QString&subtype); | 96 | void setSubtype(const QString&subtype); |
97 | const QString&Identifier()const; | 97 | const QString&Identifier()const; |
98 | void setIdentifier(const QString&identifier); | 98 | void setIdentifier(const QString&identifier); |
99 | const QString&Encoding()const; | 99 | const QString&Encoding()const; |
100 | void setEncoding(const QString&encoding); | 100 | void setEncoding(const QString&encoding); |
101 | const QString&Description()const; | ||
102 | void setDescription(const QString&desc); | ||
101 | void setLines(unsigned int lines); | 103 | void setLines(unsigned int lines); |
102 | const unsigned int Lines()const; | 104 | const unsigned int Lines()const; |
103 | void setSize(unsigned int size); | 105 | void setSize(unsigned int size); |
104 | const unsigned int Size()const; | 106 | const unsigned int Size()const; |
105 | 107 | ||
106 | 108 | ||
107 | void setParameters(const part_plist_t&list); | 109 | void setParameters(const part_plist_t&list); |
108 | const part_plist_t&Parameters()const; | 110 | const part_plist_t&Parameters()const; |
109 | void addParameter(const QString&key,const QString&value); | 111 | void addParameter(const QString&key,const QString&value); |
110 | const QString searchParamter(const QString&key)const; | 112 | const QString searchParamter(const QString&key)const; |
111 | void setPositionlist(const QValueList<int>&poslist); | 113 | void setPositionlist(const QValueList<int>&poslist); |
112 | const QValueList<int>& Positionlist()const; | 114 | const QValueList<int>& Positionlist()const; |
113 | }; | 115 | }; |
114 | 116 | ||
115 | class RecBody | 117 | class RecBody |
116 | { | 118 | { |
117 | protected: | 119 | protected: |
118 | QString m_BodyText; | 120 | QString m_BodyText; |
119 | QValueList<RecPart> m_PartsList; | 121 | QValueList<RecPart> m_PartsList; |
120 | RecPart m_description; | 122 | RecPart m_description; |
121 | 123 | ||
122 | public: | 124 | public: |
123 | RecBody(); | 125 | RecBody(); |
124 | virtual ~RecBody(); | 126 | virtual ~RecBody(); |
125 | void setBodytext(const QString&); | 127 | void setBodytext(const QString&); |
126 | const QString& Bodytext()const; | 128 | const QString& Bodytext()const; |
127 | 129 | ||
128 | void setDescription(const RecPart&des); | 130 | void setDescription(const RecPart&des); |
129 | const RecPart& Description()const; | 131 | const RecPart& Description()const; |
130 | 132 | ||
131 | void setParts(const QValueList<RecPart>&parts); | 133 | void setParts(const QValueList<RecPart>&parts); |
132 | const QValueList<RecPart>& Parts()const; | 134 | const QValueList<RecPart>& Parts()const; |
133 | void addPart(const RecPart&part); | 135 | void addPart(const RecPart&part); |
134 | }; | 136 | }; |
135 | 137 | ||
136 | #endif | 138 | #endif |
diff --git a/noncore/net/mail/mainwindow.cpp b/noncore/net/mail/mainwindow.cpp index fae3e97..8e2132e 100644 --- a/noncore/net/mail/mainwindow.cpp +++ b/noncore/net/mail/mainwindow.cpp | |||
@@ -10,213 +10,215 @@ | |||
10 | 10 | ||
11 | #include "defines.h" | 11 | #include "defines.h" |
12 | #include "mainwindow.h" | 12 | #include "mainwindow.h" |
13 | #include "viewmail.h" | 13 | #include "viewmail.h" |
14 | #include "mailtypes.h" | 14 | #include "mailtypes.h" |
15 | #include "mailistviewitem.h" | 15 | #include "mailistviewitem.h" |
16 | 16 | ||
17 | MainWindow::MainWindow( QWidget *parent, const char *name, WFlags flags ) | 17 | MainWindow::MainWindow( QWidget *parent, const char *name, WFlags flags ) |
18 | : QMainWindow( parent, name, flags ) | 18 | : QMainWindow( parent, name, flags ) |
19 | { | 19 | { |
20 | setCaption( tr( "Mail" ) ); | 20 | setCaption( tr( "Mail" ) ); |
21 | setToolBarsMovable( false ); | 21 | setToolBarsMovable( false ); |
22 | 22 | ||
23 | toolBar = new QToolBar( this ); | 23 | toolBar = new QToolBar( this ); |
24 | menuBar = new QMenuBar( toolBar ); | 24 | menuBar = new QMenuBar( toolBar ); |
25 | mailMenu = new QPopupMenu( menuBar ); | 25 | mailMenu = new QPopupMenu( menuBar ); |
26 | menuBar->insertItem( tr( "Mail" ), mailMenu ); | 26 | menuBar->insertItem( tr( "Mail" ), mailMenu ); |
27 | settingsMenu = new QPopupMenu( menuBar ); | 27 | settingsMenu = new QPopupMenu( menuBar ); |
28 | menuBar->insertItem( tr( "Settings" ), settingsMenu ); | 28 | menuBar->insertItem( tr( "Settings" ), settingsMenu ); |
29 | 29 | ||
30 | addToolBar( toolBar ); | 30 | addToolBar( toolBar ); |
31 | toolBar->setHorizontalStretchable( true ); | 31 | toolBar->setHorizontalStretchable( true ); |
32 | 32 | ||
33 | QLabel *spacer = new QLabel( toolBar ); | 33 | QLabel *spacer = new QLabel( toolBar ); |
34 | spacer->setBackgroundMode( QWidget::PaletteButton ); | 34 | spacer->setBackgroundMode( QWidget::PaletteButton ); |
35 | toolBar->setStretchableWidget( spacer ); | 35 | toolBar->setStretchableWidget( spacer ); |
36 | 36 | ||
37 | composeMail = new QAction( tr( "Compose new mail" ), ICON_COMPOSEMAIL, | 37 | composeMail = new QAction( tr( "Compose new mail" ), ICON_COMPOSEMAIL, |
38 | 0, 0, this ); | 38 | 0, 0, this ); |
39 | composeMail->addTo( toolBar ); | 39 | composeMail->addTo( toolBar ); |
40 | composeMail->addTo( mailMenu ); | 40 | composeMail->addTo( mailMenu ); |
41 | 41 | ||
42 | sendQueued = new QAction( tr( "Send queued mails" ), ICON_SENDQUEUED, | 42 | sendQueued = new QAction( tr( "Send queued mails" ), ICON_SENDQUEUED, |
43 | 0, 0, this ); | 43 | 0, 0, this ); |
44 | sendQueued->addTo( toolBar ); | 44 | sendQueued->addTo( toolBar ); |
45 | sendQueued->addTo( mailMenu ); | 45 | sendQueued->addTo( mailMenu ); |
46 | 46 | ||
47 | syncFolders = new QAction( tr( "Sync mailfolders" ), ICON_SYNC, | 47 | syncFolders = new QAction( tr( "Sync mailfolders" ), ICON_SYNC, |
48 | 0, 0, this ); | 48 | 0, 0, this ); |
49 | syncFolders->addTo( toolBar ); | 49 | syncFolders->addTo( toolBar ); |
50 | syncFolders->addTo( mailMenu ); | 50 | syncFolders->addTo( mailMenu ); |
51 | 51 | ||
52 | showFolders = new QAction( tr( "Show/Hide folders" ), ICON_SHOWFOLDERS, | 52 | showFolders = new QAction( tr( "Show/Hide folders" ), ICON_SHOWFOLDERS, |
53 | 0, 0, this, 0, true ); | 53 | 0, 0, this, 0, true ); |
54 | showFolders->addTo( toolBar ); | 54 | showFolders->addTo( toolBar ); |
55 | showFolders->addTo( mailMenu ); | 55 | showFolders->addTo( mailMenu ); |
56 | showFolders->setOn( true ); | 56 | showFolders->setOn( true ); |
57 | connect(showFolders, SIGNAL( toggled( bool ) ), | 57 | connect(showFolders, SIGNAL( toggled( bool ) ), |
58 | SLOT( slotShowFolders( bool ) ) ); | 58 | SLOT( slotShowFolders( bool ) ) ); |
59 | 59 | ||
60 | searchMails = new QAction( tr( "Search mails" ), ICON_SEARCHMAILS, | 60 | searchMails = new QAction( tr( "Search mails" ), ICON_SEARCHMAILS, |
61 | 0, 0, this ); | 61 | 0, 0, this ); |
62 | searchMails->addTo( toolBar ); | 62 | searchMails->addTo( toolBar ); |
63 | searchMails->addTo( mailMenu ); | 63 | searchMails->addTo( mailMenu ); |
64 | 64 | ||
65 | deleteMails = new QAction(tr("Delete Mail"), QIconSet(Resource::loadPixmap("mail/delete")), 0, 0, this); | 65 | deleteMails = new QAction(tr("Delete Mail"), QIconSet(Resource::loadPixmap("mail/delete")), 0, 0, this); |
66 | deleteMails->addTo( toolBar ); | 66 | deleteMails->addTo( toolBar ); |
67 | deleteMails->addTo( mailMenu ); | 67 | deleteMails->addTo( mailMenu ); |
68 | connect( deleteMails, SIGNAL( activated() ), | 68 | connect( deleteMails, SIGNAL( activated() ), |
69 | SLOT( slotDeleteMail() ) ); | 69 | SLOT( slotDeleteMail() ) ); |
70 | 70 | ||
71 | editSettings = new QAction( tr( "Edit settings" ), ICON_EDITSETTINGS, | 71 | editSettings = new QAction( tr( "Edit settings" ), ICON_EDITSETTINGS, |
72 | 0, 0, this ); | 72 | 0, 0, this ); |
73 | editSettings->addTo( settingsMenu ); | 73 | editSettings->addTo( settingsMenu ); |
74 | 74 | ||
75 | editAccounts = new QAction( tr( "Configure accounts" ), ICON_EDITACCOUNTS, | 75 | editAccounts = new QAction( tr( "Configure accounts" ), ICON_EDITACCOUNTS, |
76 | 0, 0, this ); | 76 | 0, 0, this ); |
77 | editAccounts->addTo( settingsMenu ); | 77 | editAccounts->addTo( settingsMenu ); |
78 | 78 | ||
79 | QWidget *view = new QWidget( this ); | 79 | QWidget *view = new QWidget( this ); |
80 | setCentralWidget( view ); | 80 | setCentralWidget( view ); |
81 | 81 | ||
82 | layout = new QBoxLayout ( view, QBoxLayout::LeftToRight ); | 82 | layout = new QBoxLayout ( view, QBoxLayout::LeftToRight ); |
83 | 83 | ||
84 | folderView = new AccountView( view ); | 84 | folderView = new AccountView( view ); |
85 | folderView->header()->hide(); | 85 | folderView->header()->hide(); |
86 | folderView->setRootIsDecorated( true ); | 86 | folderView->setRootIsDecorated( true ); |
87 | folderView->addColumn( tr( "Mailbox" ) ); | 87 | folderView->addColumn( tr( "Mailbox" ) ); |
88 | //folderView->hide(); | 88 | //folderView->hide(); |
89 | 89 | ||
90 | layout->addWidget( folderView ); | 90 | layout->addWidget( folderView ); |
91 | 91 | ||
92 | mailView = new QListView( view ); | 92 | mailView = new QListView( view ); |
93 | mailView->addColumn( tr( "" ) ); | 93 | mailView->addColumn( tr( "" ) ); |
94 | mailView->addColumn( tr( "Subject" ),QListView::Manual ); | 94 | mailView->addColumn( tr( "Subject" ),QListView::Manual ); |
95 | mailView->addColumn( tr( "Sender" ),QListView::Manual ); | 95 | mailView->addColumn( tr( "Sender" ),QListView::Manual ); |
96 | mailView->addColumn( tr( "Date" )); | 96 | mailView->addColumn( tr( "Date" )); |
97 | mailView->setAllColumnsShowFocus(true); | 97 | mailView->setAllColumnsShowFocus(true); |
98 | mailView->setSorting(-1); | 98 | mailView->setSorting(-1); |
99 | 99 | ||
100 | layout->addWidget( mailView ); | 100 | layout->addWidget( mailView ); |
101 | layout->setStretchFactor( folderView, 1 ); | 101 | layout->setStretchFactor( folderView, 1 ); |
102 | layout->setStretchFactor( mailView, 2 ); | 102 | layout->setStretchFactor( mailView, 2 ); |
103 | 103 | ||
104 | slotAdjustLayout(); | 104 | slotAdjustLayout(); |
105 | 105 | ||
106 | connect( mailView, SIGNAL( clicked( QListViewItem * ) ),this, | 106 | connect( mailView, SIGNAL( clicked( QListViewItem * ) ),this, |
107 | SLOT( displayMail( QListViewItem * ) ) ); | 107 | SLOT( displayMail( QListViewItem * ) ) ); |
108 | 108 | ||
109 | connect(folderView, SIGNAL(refreshMailview(QList<RecMail>*)),this,SLOT(refreshMailView(QList<RecMail>*))); | 109 | connect(folderView, SIGNAL(refreshMailview(QList<RecMail>*)),this,SLOT(refreshMailView(QList<RecMail>*))); |
110 | 110 | ||
111 | QTimer::singleShot( 1000, this, SLOT( slotAdjustColumns() ) ); | 111 | QTimer::singleShot( 1000, this, SLOT( slotAdjustColumns() ) ); |
112 | 112 | ||
113 | } | 113 | } |
114 | 114 | ||
115 | 115 | ||
116 | void MainWindow::slotAdjustLayout() { | 116 | void MainWindow::slotAdjustLayout() { |
117 | 117 | ||
118 | QWidget *d = QApplication::desktop(); | 118 | QWidget *d = QApplication::desktop(); |
119 | 119 | ||
120 | if ( d->width() < d->height() ) { | 120 | if ( d->width() < d->height() ) { |
121 | layout->setDirection( QBoxLayout::TopToBottom ); | 121 | layout->setDirection( QBoxLayout::TopToBottom ); |
122 | } else { | 122 | } else { |
123 | layout->setDirection( QBoxLayout::LeftToRight ); | 123 | layout->setDirection( QBoxLayout::LeftToRight ); |
124 | } | 124 | } |
125 | delete d; | 125 | delete d; |
126 | } | 126 | } |
127 | 127 | ||
128 | void MainWindow::slotAdjustColumns() | 128 | void MainWindow::slotAdjustColumns() |
129 | { | 129 | { |
130 | bool hidden = folderView->isHidden(); | 130 | bool hidden = folderView->isHidden(); |
131 | if ( hidden ) folderView->show(); | 131 | if ( hidden ) folderView->show(); |
132 | folderView->setColumnWidth( 0, folderView->visibleWidth() ); | 132 | folderView->setColumnWidth( 0, folderView->visibleWidth() ); |
133 | if ( hidden ) folderView->hide(); | 133 | if ( hidden ) folderView->hide(); |
134 | 134 | ||
135 | mailView->setColumnWidth( 0, 10 ); | 135 | mailView->setColumnWidth( 0, 10 ); |
136 | mailView->setColumnWidth( 1, mailView->visibleWidth() - 130 ); | 136 | mailView->setColumnWidth( 1, mailView->visibleWidth() - 130 ); |
137 | mailView->setColumnWidth( 2, 80 ); | 137 | mailView->setColumnWidth( 2, 80 ); |
138 | mailView->setColumnWidth( 3, 50 ); | 138 | mailView->setColumnWidth( 3, 50 ); |
139 | } | 139 | } |
140 | 140 | ||
141 | void MainWindow::slotShowFolders( bool show ) | 141 | void MainWindow::slotShowFolders( bool show ) |
142 | { | 142 | { |
143 | qDebug( "Show Folders" ); | 143 | qDebug( "Show Folders" ); |
144 | if ( show && folderView->isHidden() ) { | 144 | if ( show && folderView->isHidden() ) { |
145 | qDebug( "-> showing" ); | 145 | qDebug( "-> showing" ); |
146 | folderView->show(); | 146 | folderView->show(); |
147 | } else if ( !show && !folderView->isHidden() ) { | 147 | } else if ( !show && !folderView->isHidden() ) { |
148 | qDebug( "-> hiding" ); | 148 | qDebug( "-> hiding" ); |
149 | folderView->hide(); | 149 | folderView->hide(); |
150 | } | 150 | } |
151 | } | 151 | } |
152 | 152 | ||
153 | void MainWindow::refreshMailView(QList<RecMail>*list) | 153 | void MainWindow::refreshMailView(QList<RecMail>*list) |
154 | { | 154 | { |
155 | MailListViewItem*item = 0; | 155 | MailListViewItem*item = 0; |
156 | mailView->clear(); | 156 | mailView->clear(); |
157 | for (unsigned int i = 0; i < list->count();++i) { | 157 | for (unsigned int i = 0; i < list->count();++i) { |
158 | item = new MailListViewItem(mailView,item); | 158 | item = new MailListViewItem(mailView,item); |
159 | item->storeData(*(list->at(i))); | 159 | item->storeData(*(list->at(i))); |
160 | item->showEntry(); | 160 | item->showEntry(); |
161 | } | 161 | } |
162 | } | 162 | } |
163 | void MainWindow::displayMail(QListViewItem*item) | 163 | void MainWindow::displayMail(QListViewItem*item) |
164 | { | 164 | { |
165 | 165 | ||
166 | if (!item) return; | 166 | if (!item) return; |
167 | RecMail mail = ((MailListViewItem*)item)->data(); | 167 | RecMail mail = ((MailListViewItem*)item)->data(); |
168 | RecBody body = folderView->fetchBody(mail); | 168 | RecBody body = folderView->fetchBody(mail); |
169 | 169 | ||
170 | ViewMail readMail( this ); | 170 | ViewMail readMail( this ); |
171 | readMail.setBody( body ); | 171 | readMail.setBody( body ); |
172 | readMail.setMail( mail ); | 172 | readMail.setMail( mail ); |
173 | readMail.showMaximized(); | 173 | readMail.showMaximized(); |
174 | readMail.exec(); | 174 | readMail.exec(); |
175 | 175 | ||
176 | if ( readMail.deleted ) { | 176 | if ( readMail.deleted ) { |
177 | folderView->refreshCurrent(); | 177 | folderView->refreshCurrent(); |
178 | } else { | 178 | } else { |
179 | ( (MailListViewItem*)item )->setPixmap( 0, Resource::loadPixmap( "opiemail/kmmsgunseen") ); | 179 | ( (MailListViewItem*)item )->setPixmap( 0, Resource::loadPixmap( "opiemail/kmmsgunseen") ); |
180 | } | 180 | } |
181 | } | 181 | } |
182 | 182 | ||
183 | void MainWindow::slotDeleteMail() | 183 | void MainWindow::slotDeleteMail() |
184 | { | 184 | { |
185 | if (!mailView->currentItem()) return; | 185 | if (!mailView->currentItem()) return; |
186 | RecMail mail = ((MailListViewItem*)mailView->currentItem() )->data(); | 186 | RecMail mail = ((MailListViewItem*)mailView->currentItem() )->data(); |
187 | if ( QMessageBox::warning(this, tr("Delete Mail"), QString( tr("<p>Do you really want to delete this mail? <br><br>" ) + mail.getFrom() + " - " + mail.getSubject() ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) { | 187 | if ( QMessageBox::warning(this, tr("Delete Mail"), QString( tr("<p>Do you really want to delete this mail? <br><br>" ) + mail.getFrom() + " - " + mail.getSubject() ) , QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) { |
188 | mail.Wrapper()->deleteMail( mail ); | 188 | mail.Wrapper()->deleteMail( mail ); |
189 | folderView->refreshCurrent(); | 189 | folderView->refreshCurrent(); |
190 | } | 190 | } |
191 | } | 191 | } |
192 | 192 | ||
193 | 193 | ||
194 | 194 | ||
195 | MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * item ) | 195 | MailListViewItem::MailListViewItem(QListView * parent, MailListViewItem * item ) |
196 | :QListViewItem(parent,item),mail_data() | 196 | :QListViewItem(parent,item),mail_data() |
197 | { | 197 | { |
198 | } | 198 | } |
199 | 199 | ||
200 | void MailListViewItem::showEntry() | 200 | void MailListViewItem::showEntry() |
201 | { | 201 | { |
202 | if ( mail_data.getFlags().testBit( FLAG_SEEN ) == true ) { | 202 | if ( mail_data.getFlags().testBit( FLAG_ANSWERED ) == true) { |
203 | setPixmap( 0, Resource::loadPixmap( "opiemail/kmmsgreplied") ); | ||
204 | } else if ( mail_data.getFlags().testBit( FLAG_SEEN ) == true ) { | ||
203 | setPixmap( 0, Resource::loadPixmap( "opiemail/kmmsgunseen") ); | 205 | setPixmap( 0, Resource::loadPixmap( "opiemail/kmmsgunseen") ); |
204 | } else { | 206 | } else { |
205 | setPixmap( 0, Resource::loadPixmap( "opiemail/kmmsgnew") ); | 207 | setPixmap( 0, Resource::loadPixmap( "opiemail/kmmsgnew") ); |
206 | } | 208 | } |
207 | setText(1,mail_data.getSubject()); | 209 | setText(1,mail_data.getSubject()); |
208 | setText(2,mail_data.getFrom()); | 210 | setText(2,mail_data.getFrom()); |
209 | setText(3,mail_data.getDate()); | 211 | setText(3,mail_data.getDate()); |
210 | } | 212 | } |
211 | 213 | ||
212 | void MailListViewItem::storeData(const RecMail&data) | 214 | void MailListViewItem::storeData(const RecMail&data) |
213 | { | 215 | { |
214 | mail_data = data; | 216 | mail_data = data; |
215 | } | 217 | } |
216 | 218 | ||
217 | const RecMail& MailListViewItem::data()const | 219 | const RecMail& MailListViewItem::data()const |
218 | { | 220 | { |
219 | return mail_data; | 221 | return mail_data; |
220 | } | 222 | } |
221 | 223 | ||
222 | 224 | ||
diff --git a/noncore/net/mail/viewmail.cpp b/noncore/net/mail/viewmail.cpp index 68d3c51..48b71eb 100644 --- a/noncore/net/mail/viewmail.cpp +++ b/noncore/net/mail/viewmail.cpp | |||
@@ -1,318 +1,326 @@ | |||
1 | #include <qtextbrowser.h> | 1 | #include <qtextbrowser.h> |
2 | #include <qmessagebox.h> | 2 | #include <qmessagebox.h> |
3 | #include <qtextstream.h> | 3 | #include <qtextstream.h> |
4 | #include <qaction.h> | 4 | #include <qaction.h> |
5 | #include <qpopupmenu.h> | 5 | #include <qpopupmenu.h> |
6 | #include <qapplication.h> | 6 | #include <qapplication.h> |
7 | 7 | ||
8 | #include <opie/ofiledialog.h> | 8 | #include <opie/ofiledialog.h> |
9 | 9 | ||
10 | #include "settings.h" | 10 | #include "settings.h" |
11 | #include "composemail.h" | 11 | #include "composemail.h" |
12 | #include "viewmail.h" | 12 | #include "viewmail.h" |
13 | #include "abstractmail.h" | 13 | #include "abstractmail.h" |
14 | #include "accountview.h" | 14 | #include "accountview.h" |
15 | 15 | ||
16 | AttachItem::AttachItem(QListView * parent,QListViewItem *after, const QString&mime,const QString&file,const QString&desc,int num) | 16 | AttachItem::AttachItem(QListView * parent,QListViewItem *after, const QString&mime,const QString&desc,const QString&file, |
17 | const QString&fsize,int num) | ||
17 | : QListViewItem(parent,after),_partNum(num) | 18 | : QListViewItem(parent,after),_partNum(num) |
18 | { | 19 | { |
19 | setText(0, mime); | 20 | setText(0, mime); |
20 | setText(1, file); | 21 | setText(1, desc); |
21 | setText(2, desc); | 22 | setText(2, file); |
23 | setText(3, fsize); | ||
22 | } | 24 | } |
23 | 25 | ||
24 | void ViewMail::setBody( RecBody body ) { | 26 | void ViewMail::setBody( RecBody body ) { |
25 | 27 | ||
26 | m_body = body; | 28 | m_body = body; |
27 | m_mail[2] = body.Bodytext(); | 29 | m_mail[2] = body.Bodytext(); |
28 | attachbutton->setEnabled(body.Parts().count()>0); | 30 | attachbutton->setEnabled(body.Parts().count()>0); |
29 | attachments->setEnabled(body.Parts().count()>0); | 31 | attachments->setEnabled(body.Parts().count()>0); |
30 | if (body.Parts().count()==0) { | 32 | if (body.Parts().count()==0) { |
31 | return; | 33 | return; |
32 | } | 34 | } |
33 | AttachItem * curItem=0; | 35 | AttachItem * curItem=0; |
34 | QString type=body.Description().Type()+"/"+body.Description().Subtype(); | 36 | QString type=body.Description().Type()+"/"+body.Description().Subtype(); |
35 | QString desc; | 37 | QString desc,fsize; |
36 | double s = body.Description().Size(); | 38 | double s = body.Description().Size(); |
37 | int w; | 39 | int w; |
38 | w=0; | 40 | w=0; |
39 | 41 | ||
40 | while (s>1024) { | 42 | while (s>1024) { |
41 | s/=1024; | 43 | s/=1024; |
42 | ++w; | 44 | ++w; |
43 | if (w>=2) break; | 45 | if (w>=2) break; |
44 | } | 46 | } |
45 | 47 | ||
46 | QString q=""; | 48 | QString q=""; |
47 | switch(w) { | 49 | switch(w) { |
48 | case 1: | 50 | case 1: |
49 | q="k"; | 51 | q="k"; |
50 | break; | 52 | break; |
51 | case 2: | 53 | case 2: |
52 | q="M"; | 54 | q="M"; |
53 | break; | 55 | break; |
54 | default: | 56 | default: |
55 | break; | 57 | break; |
56 | } | 58 | } |
57 | 59 | ||
58 | { | 60 | { |
59 | /* I did not found a method to make a CONTENT reset on a QTextStream | 61 | /* I did not found a method to make a CONTENT reset on a QTextStream |
60 | so I use this construct that the stream will re-constructed in each | 62 | so I use this construct that the stream will re-constructed in each |
61 | loop. To let it work, the textstream is packed into a own area of | 63 | loop. To let it work, the textstream is packed into a own area of |
62 | code is it will be destructed after finishing its small job. | 64 | code is it will be destructed after finishing its small job. |
63 | */ | 65 | */ |
64 | QTextOStream o(&desc); | 66 | QTextOStream o(&fsize); |
65 | if (w>0) o.precision(2); else o.precision(0); | 67 | if (w>0) o.precision(2); else o.precision(0); |
66 | o.setf(QTextStream::fixed); | 68 | o.setf(QTextStream::fixed); |
67 | o << s << " " << q << "Byte"; | 69 | o << s << " " << q << "Byte"; |
68 | } | 70 | } |
69 | 71 | ||
70 | curItem=new AttachItem(attachments,curItem,type,"Mailbody",desc,-1); | 72 | curItem=new AttachItem(attachments,curItem,type,"Mailbody","",fsize,-1); |
71 | QString filename = ""; | 73 | QString filename = ""; |
72 | for (unsigned int i = 0; i < body.Parts().count();++i) { | 74 | for (unsigned int i = 0; i < body.Parts().count();++i) { |
73 | type = body.Parts()[i].Type()+"/"+body.Parts()[i].Subtype(); | 75 | type = body.Parts()[i].Type()+"/"+body.Parts()[i].Subtype(); |
74 | part_plist_t::ConstIterator it = body.Parts()[i].Parameters().begin(); | 76 | part_plist_t::ConstIterator it = body.Parts()[i].Parameters().begin(); |
75 | for (;it!=body.Parts()[i].Parameters().end();++it) { | 77 | for (;it!=body.Parts()[i].Parameters().end();++it) { |
78 | qDebug(it.key()); | ||
76 | if (it.key().lower()=="name") { | 79 | if (it.key().lower()=="name") { |
77 | filename=it.data(); | 80 | filename=it.data(); |
78 | } | 81 | } |
79 | } | 82 | } |
80 | s = body.Parts()[i].Size(); | 83 | s = body.Parts()[i].Size(); |
81 | w = 0; | 84 | w = 0; |
82 | while (s>1024) { | 85 | while (s>1024) { |
83 | s/=1024; | 86 | s/=1024; |
84 | ++w; | 87 | ++w; |
85 | if (w>=2) break; | 88 | if (w>=2) break; |
86 | } | 89 | } |
87 | switch(w) { | 90 | switch(w) { |
88 | case 1: | 91 | case 1: |
89 | q="k"; | 92 | q="k"; |
90 | break; | 93 | break; |
91 | case 2: | 94 | case 2: |
92 | q="M"; | 95 | q="M"; |
93 | break; | 96 | break; |
94 | default: | 97 | default: |
95 | q=""; | 98 | q=""; |
96 | break; | 99 | break; |
97 | } | 100 | } |
98 | QTextOStream o(&desc); | 101 | QTextOStream o(&fsize); |
99 | if (w>0) o.precision(2); else o.precision(0); | 102 | if (w>0) o.precision(2); else o.precision(0); |
100 | o.setf(QTextStream::fixed); | 103 | o.setf(QTextStream::fixed); |
101 | o << s << " " << q << "Byte"; | 104 | o << s << " " << q << "Byte"; |
102 | curItem=new AttachItem(attachments,curItem,type,filename,desc,i); | 105 | desc = body.Parts()[i].Description(); |
106 | curItem=new AttachItem(attachments,curItem,type,desc,filename,fsize,i); | ||
103 | } | 107 | } |
104 | } | 108 | } |
105 | 109 | ||
106 | void ViewMail::slotItemClicked( QListViewItem * item , const QPoint & point, int c ) { | 110 | void ViewMail::slotItemClicked( QListViewItem * item , const QPoint & point, int ) { |
107 | if (!item ) | 111 | if (!item ) |
108 | return; | 112 | return; |
109 | 113 | ||
110 | QPopupMenu *menu = new QPopupMenu(); | 114 | if ( ( ( AttachItem* )item )->Partnumber() == -1 ) { |
115 | setText(); | ||
116 | return; | ||
117 | } | ||
118 | QPopupMenu *menu = new QPopupMenu(); | ||
111 | int ret=0; | 119 | int ret=0; |
112 | 120 | ||
113 | if ( item->text( 0 ).left( 4 ) == "text" ) { | 121 | if ( item->text( 0 ).left( 5 ) == "text/" ) { |
114 | menu->insertItem( tr( "Show Text" ), 1 ); | 122 | menu->insertItem( tr( "Show Text" ), 1 ); |
115 | } | 123 | } |
116 | menu->insertItem( tr( "Save Attachment" ), 0 ); | 124 | menu->insertItem( tr( "Save Attachment" ), 0 ); |
117 | menu->insertSeparator(1); | 125 | menu->insertSeparator(1); |
118 | 126 | ||
119 | ret = menu->exec( point, 0 ); | 127 | ret = menu->exec( point, 0 ); |
120 | 128 | ||
121 | switch(ret) { | 129 | switch(ret) { |
122 | case 0: | 130 | case 0: |
123 | { MimeTypes types; | 131 | { MimeTypes types; |
124 | types.insert( "all", "*" ); | 132 | types.insert( "all", "*" ); |
125 | QString str = OFileDialog::getSaveFileName( 1, | 133 | QString str = OFileDialog::getSaveFileName( 1, |
126 | "/", item->text( 1 ) , types, 0 ); | 134 | "/", item->text( 2 ) , types, 0 ); |
127 | 135 | ||
128 | if( !str.isEmpty() ) { | 136 | if( !str.isEmpty() ) { |
129 | qDebug( "first we will need a MIME wrapper" ); | 137 | qDebug( "first we will need a MIME wrapper" ); |
130 | } | 138 | } |
131 | } | 139 | } |
132 | break ; | 140 | break ; |
133 | 141 | ||
134 | case 1: | 142 | case 1: |
135 | if ( ( ( AttachItem* )item )->Partnumber() == -1 ) { | 143 | if ( ( ( AttachItem* )item )->Partnumber() == -1 ) { |
136 | setText(); | 144 | setText(); |
137 | } else { | 145 | } else { |
138 | if ( m_recMail.Wrapper() != 0l ) { // make sure that there is a wrapper , even after delete or simular actions | 146 | if ( m_recMail.Wrapper() != 0l ) { // make sure that there is a wrapper , even after delete or simular actions |
139 | browser->setText( m_recMail.Wrapper()->fetchPart( m_recMail, m_body.Parts()[ ( ( AttachItem* )item )->Partnumber() ] ) ); | 147 | browser->setText( m_recMail.Wrapper()->fetchPart( m_recMail, m_body.Parts()[ ( ( AttachItem* )item )->Partnumber() ] ) ); |
140 | } | 148 | } |
141 | } | 149 | } |
142 | break; | 150 | break; |
143 | } | 151 | } |
144 | delete menu; | 152 | delete menu; |
145 | } | 153 | } |
146 | 154 | ||
147 | 155 | ||
148 | void ViewMail::setMail( RecMail mail ) { | 156 | void ViewMail::setMail( RecMail mail ) { |
149 | 157 | ||
150 | m_recMail = mail; | 158 | m_recMail = mail; |
151 | 159 | ||
152 | m_mail[0] = mail.getFrom(); | 160 | m_mail[0] = mail.getFrom(); |
153 | m_mail[1] = mail.getSubject(); | 161 | m_mail[1] = mail.getSubject(); |
154 | m_mail[3] = mail.getDate(); | 162 | m_mail[3] = mail.getDate(); |
155 | m_mail[4] = mail.Msgid(); | 163 | m_mail[4] = mail.Msgid(); |
156 | 164 | ||
157 | m_mail2[0] = mail.To(); | 165 | m_mail2[0] = mail.To(); |
158 | m_mail2[1] = mail.CC(); | 166 | m_mail2[1] = mail.CC(); |
159 | m_mail2[2] = mail.Bcc(); | 167 | m_mail2[2] = mail.Bcc(); |
160 | 168 | ||
161 | setText(); | 169 | setText(); |
162 | } | 170 | } |
163 | 171 | ||
164 | 172 | ||
165 | 173 | ||
166 | ViewMail::ViewMail( QWidget *parent, const char *name, WFlags fl) | 174 | ViewMail::ViewMail( QWidget *parent, const char *name, WFlags fl) |
167 | : ViewMailBase(parent, name, fl), _inLoop(false) | 175 | : ViewMailBase(parent, name, fl), _inLoop(false) |
168 | { | 176 | { |
169 | m_gotBody = false; | 177 | m_gotBody = false; |
170 | 178 | ||
171 | connect(reply, SIGNAL(activated()), SLOT(slotReply())); | 179 | connect(reply, SIGNAL(activated()), SLOT(slotReply())); |
172 | connect(forward, SIGNAL(activated()), SLOT(slotForward())); | 180 | connect(forward, SIGNAL(activated()), SLOT(slotForward())); |
173 | connect( deleteMail, SIGNAL( activated() ), SLOT( slotDeleteMail( ) ) ); | 181 | connect( deleteMail, SIGNAL( activated() ), SLOT( slotDeleteMail( ) ) ); |
174 | 182 | ||
175 | attachments->setEnabled(m_gotBody); | 183 | attachments->setEnabled(m_gotBody); |
176 | connect( attachments, SIGNAL( clicked ( QListViewItem *, const QPoint & , int ) ), SLOT( slotItemClicked( QListViewItem *, const QPoint & , int ) ) ); | 184 | connect( attachments, SIGNAL( clicked ( QListViewItem *, const QPoint & , int ) ), SLOT( slotItemClicked( QListViewItem *, const QPoint & , int ) ) ); |
177 | 185 | ||
178 | } | 186 | } |
179 | 187 | ||
180 | void ViewMail::setText() | 188 | void ViewMail::setText() |
181 | { | 189 | { |
182 | 190 | ||
183 | QString toString; | 191 | QString toString; |
184 | QString ccString; | 192 | QString ccString; |
185 | QString bccString; | 193 | QString bccString; |
186 | 194 | ||
187 | for ( QStringList::Iterator it = ( m_mail2[0] ).begin(); it != ( m_mail2[0] ).end(); ++it ) { | 195 | for ( QStringList::Iterator it = ( m_mail2[0] ).begin(); it != ( m_mail2[0] ).end(); ++it ) { |
188 | toString += (*it); | 196 | toString += (*it); |
189 | } | 197 | } |
190 | for ( QStringList::Iterator it = ( m_mail2[1] ).begin(); it != ( m_mail2[1] ).end(); ++it ) { | 198 | for ( QStringList::Iterator it = ( m_mail2[1] ).begin(); it != ( m_mail2[1] ).end(); ++it ) { |
191 | ccString += (*it); | 199 | ccString += (*it); |
192 | } | 200 | } |
193 | for ( QStringList::Iterator it = ( m_mail2[2] ).begin(); it != ( m_mail2[2] ).end(); ++it ) { | 201 | for ( QStringList::Iterator it = ( m_mail2[2] ).begin(); it != ( m_mail2[2] ).end(); ++it ) { |
194 | bccString += (*it); | 202 | bccString += (*it); |
195 | } | 203 | } |
196 | 204 | ||
197 | setCaption( caption().arg( m_mail[0] ) ); | 205 | setCaption( caption().arg( m_mail[0] ) ); |
198 | 206 | ||
199 | m_mailHtml = "<html><body>" | 207 | m_mailHtml = "<html><body>" |
200 | "<table width=\"100%\" border=\"0\"><tr bgcolor=\"#FFDD76\"><td>" | 208 | "<table width=\"100%\" border=\"0\"><tr bgcolor=\"#FFDD76\"><td>" |
201 | "<div align=left><b>" + deHtml( m_mail[1] ) + "</b></div>" | 209 | "<div align=left><b>" + deHtml( m_mail[1] ) + "</b></div>" |
202 | "</td></tr><tr bgcolor=\"#EEEEE6\"><td>" | 210 | "</td></tr><tr bgcolor=\"#EEEEE6\"><td>" |
203 | "<b>" + tr( "From" ) + ": </b><font color=#6C86C0>" + deHtml( m_mail[0] ) + "</font><br>" | 211 | "<b>" + tr( "From" ) + ": </b><font color=#6C86C0>" + deHtml( m_mail[0] ) + "</font><br>" |
204 | "<b>" + tr( "To" ) + ": </b><font color=#6C86C0>" + deHtml( toString ) + "</font><br><b>" + | 212 | "<b>" + tr( "To" ) + ": </b><font color=#6C86C0>" + deHtml( toString ) + "</font><br><b>" + |
205 | tr( "Cc" ) + ": </b>" + deHtml( ccString ) + "<br>" | 213 | tr( "Cc" ) + ": </b>" + deHtml( ccString ) + "<br>" |
206 | "<b>" + tr( "Date" ) + ": </b> " + m_mail[3] + | 214 | "<b>" + tr( "Date" ) + ": </b> " + m_mail[3] + |
207 | "</td></tr></table><font face=fixed>"; | 215 | "</td></tr></table><font face=fixed>"; |
208 | 216 | ||
209 | browser->setText( QString( m_mailHtml) + deHtml( m_mail[2] ) + "</font></html>" ); | 217 | browser->setText( QString( m_mailHtml) + deHtml( m_mail[2] ) + "</font></html>" ); |
210 | // remove later in favor of a real handling | 218 | // remove later in favor of a real handling |
211 | m_gotBody = true; | 219 | m_gotBody = true; |
212 | } | 220 | } |
213 | 221 | ||
214 | 222 | ||
215 | ViewMail::~ViewMail() | 223 | ViewMail::~ViewMail() |
216 | { | 224 | { |
217 | hide(); | 225 | hide(); |
218 | } | 226 | } |
219 | 227 | ||
220 | void ViewMail::hide() | 228 | void ViewMail::hide() |
221 | { | 229 | { |
222 | QWidget::hide(); | 230 | QWidget::hide(); |
223 | 231 | ||
224 | if (_inLoop) { | 232 | if (_inLoop) { |
225 | _inLoop = false; | 233 | _inLoop = false; |
226 | qApp->exit_loop(); | 234 | qApp->exit_loop(); |
227 | 235 | ||
228 | } | 236 | } |
229 | 237 | ||
230 | } | 238 | } |
231 | 239 | ||
232 | void ViewMail::exec() | 240 | void ViewMail::exec() |
233 | { | 241 | { |
234 | show(); | 242 | show(); |
235 | 243 | ||
236 | if (!_inLoop) { | 244 | if (!_inLoop) { |
237 | _inLoop = true; | 245 | _inLoop = true; |
238 | qApp->enter_loop(); | 246 | qApp->enter_loop(); |
239 | } | 247 | } |
240 | 248 | ||
241 | } | 249 | } |
242 | 250 | ||
243 | QString ViewMail::deHtml(const QString &string) | 251 | QString ViewMail::deHtml(const QString &string) |
244 | { | 252 | { |
245 | QString string_ = string; | 253 | QString string_ = string; |
246 | string_.replace(QRegExp("&"), "&"); | 254 | string_.replace(QRegExp("&"), "&"); |
247 | string_.replace(QRegExp("<"), "<"); | 255 | string_.replace(QRegExp("<"), "<"); |
248 | string_.replace(QRegExp(">"), ">"); | 256 | string_.replace(QRegExp(">"), ">"); |
249 | string_.replace(QRegExp("\\n"), "<br>"); | 257 | string_.replace(QRegExp("\\n"), "<br>"); |
250 | return string_; | 258 | return string_; |
251 | } | 259 | } |
252 | 260 | ||
253 | void ViewMail::slotReply() | 261 | void ViewMail::slotReply() |
254 | { | 262 | { |
255 | if (!m_gotBody) { | 263 | if (!m_gotBody) { |
256 | QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot reply yet."), tr("Ok")); | 264 | QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot reply yet."), tr("Ok")); |
257 | return; | 265 | return; |
258 | } | 266 | } |
259 | 267 | ||
260 | QString rtext; | 268 | QString rtext; |
261 | rtext += QString("* %1 wrote on %2:\n") // no i18n on purpose | 269 | rtext += QString("* %1 wrote on %2:\n") // no i18n on purpose |
262 | .arg( m_mail[0] ) | 270 | .arg( m_mail[0] ) |
263 | .arg( m_mail[3] ); | 271 | .arg( m_mail[3] ); |
264 | 272 | ||
265 | QString text = m_mail[2]; | 273 | QString text = m_mail[2]; |
266 | QStringList lines = QStringList::split(QRegExp("\\n"), text); | 274 | QStringList lines = QStringList::split(QRegExp("\\n"), text); |
267 | QStringList::Iterator it; | 275 | QStringList::Iterator it; |
268 | for (it = lines.begin(); it != lines.end(); it++) { | 276 | for (it = lines.begin(); it != lines.end(); it++) { |
269 | rtext += "> " + *it + "\n"; | 277 | rtext += "> " + *it + "\n"; |
270 | } | 278 | } |
271 | rtext += "\n"; | 279 | rtext += "\n"; |
272 | 280 | ||
273 | QString prefix; | 281 | QString prefix; |
274 | if ( m_mail[1].find(QRegExp("^Re: *$")) != -1) prefix = ""; | 282 | if ( m_mail[1].find(QRegExp("^Re: *$")) != -1) prefix = ""; |
275 | else prefix = "Re: "; // no i18n on purpose | 283 | else prefix = "Re: "; // no i18n on purpose |
276 | 284 | ||
277 | Settings *settings = new Settings(); | 285 | Settings *settings = new Settings(); |
278 | ComposeMail composer( settings ,this, 0, true); | 286 | ComposeMail composer( settings ,this, 0, true); |
279 | composer.setTo( m_mail[0] ); | 287 | composer.setTo( m_mail[0] ); |
280 | composer.setSubject( "Re: " + m_mail[1] ); | 288 | composer.setSubject( "Re: " + m_mail[1] ); |
281 | composer.setMessage( rtext ); | 289 | composer.setMessage( rtext ); |
282 | composer.showMaximized(); | 290 | composer.showMaximized(); |
283 | if ( QDialog::Accepted==composer.exec()) { | 291 | if ( QDialog::Accepted==composer.exec()) { |
284 | m_recMail.Wrapper()->answeredMail(m_recMail); | 292 | m_recMail.Wrapper()->answeredMail(m_recMail); |
285 | } | 293 | } |
286 | } | 294 | } |
287 | 295 | ||
288 | void ViewMail::slotForward() | 296 | void ViewMail::slotForward() |
289 | { | 297 | { |
290 | if (!m_gotBody) { | 298 | if (!m_gotBody) { |
291 | QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot forward yet."), tr("Ok")); | 299 | QMessageBox::information(this, tr("Error"), tr("<p>The mail body is not yet downloaded, so you cannot forward yet."), tr("Ok")); |
292 | return; | 300 | return; |
293 | } | 301 | } |
294 | 302 | ||
295 | QString ftext; | 303 | QString ftext; |
296 | ftext += QString("\n----- Forwarded message from %1 -----\n\n") | 304 | ftext += QString("\n----- Forwarded message from %1 -----\n\n") |
297 | .arg( m_mail[0] ); | 305 | .arg( m_mail[0] ); |
298 | if (!m_mail[3].isNull()) | 306 | if (!m_mail[3].isNull()) |
299 | ftext += QString("Date: %1\n") | 307 | ftext += QString("Date: %1\n") |
300 | .arg( m_mail[3] ); | 308 | .arg( m_mail[3] ); |
301 | if (!m_mail[0].isNull()) | 309 | if (!m_mail[0].isNull()) |
302 | ftext += QString("From: %1\n") | 310 | ftext += QString("From: %1\n") |
303 | .arg( m_mail[0] ); | 311 | .arg( m_mail[0] ); |
304 | if (!m_mail[1].isNull()) | 312 | if (!m_mail[1].isNull()) |
305 | ftext += QString("Subject: %1\n") | 313 | ftext += QString("Subject: %1\n") |
306 | .arg( m_mail[1] ); | 314 | .arg( m_mail[1] ); |
307 | 315 | ||
308 | ftext += QString("\n%1\n") | 316 | ftext += QString("\n%1\n") |
309 | .arg( m_mail[2]); | 317 | .arg( m_mail[2]); |
310 | 318 | ||
311 | ftext += QString("----- End forwarded message -----\n"); | 319 | ftext += QString("----- End forwarded message -----\n"); |
312 | 320 | ||
313 | Settings *settings = new Settings(); | 321 | Settings *settings = new Settings(); |
314 | ComposeMail composer( settings ,this, 0, true); | 322 | ComposeMail composer( settings ,this, 0, true); |
315 | composer.setSubject( "Fwd: " + m_mail[1] ); | 323 | composer.setSubject( "Fwd: " + m_mail[1] ); |
316 | composer.setMessage( ftext ); | 324 | composer.setMessage( ftext ); |
317 | composer.showMaximized(); | 325 | composer.showMaximized(); |
318 | if ( QDialog::Accepted==composer.exec()) { | 326 | if ( QDialog::Accepted==composer.exec()) { |
diff --git a/noncore/net/mail/viewmail.h b/noncore/net/mail/viewmail.h index 765464c..dd7f854 100644 --- a/noncore/net/mail/viewmail.h +++ b/noncore/net/mail/viewmail.h | |||
@@ -1,60 +1,61 @@ | |||
1 | #ifndef VIEWMAIL_H | 1 | #ifndef VIEWMAIL_H |
2 | #define VIEWMAIL_H | 2 | #define VIEWMAIL_H |
3 | 3 | ||
4 | #include <qlistview.h> | 4 | #include <qlistview.h> |
5 | #include <qmap.h> | 5 | #include <qmap.h> |
6 | #include <qstringlist.h> | 6 | #include <qstringlist.h> |
7 | 7 | ||
8 | #include "viewmailbase.h" | 8 | #include "viewmailbase.h" |
9 | #include "mailtypes.h" | 9 | #include "mailtypes.h" |
10 | 10 | ||
11 | class AttachItem : public QListViewItem | 11 | class AttachItem : public QListViewItem |
12 | { | 12 | { |
13 | public: | 13 | public: |
14 | AttachItem(QListView * parent,QListViewItem *after, const QString&mime,const QString&file,const QString&desc,int num); | 14 | AttachItem(QListView * parent,QListViewItem *after, const QString&mime,const QString&desc,const QString&file, |
15 | const QString&fsize,int num); | ||
15 | int Partnumber() { return _partNum; } | 16 | int Partnumber() { return _partNum; } |
16 | 17 | ||
17 | private: | 18 | private: |
18 | int _partNum; | 19 | int _partNum; |
19 | }; | 20 | }; |
20 | 21 | ||
21 | class ViewMail : public ViewMailBase | 22 | class ViewMail : public ViewMailBase |
22 | { | 23 | { |
23 | Q_OBJECT | 24 | Q_OBJECT |
24 | 25 | ||
25 | public: | 26 | public: |
26 | ViewMail( QWidget *parent = 0, const char *name = 0, WFlags fl = Qt::WType_Modal); | 27 | ViewMail( QWidget *parent = 0, const char *name = 0, WFlags fl = Qt::WType_Modal); |
27 | ~ViewMail(); | 28 | ~ViewMail(); |
28 | 29 | ||
29 | void hide(); | 30 | void hide(); |
30 | void exec(); | 31 | void exec(); |
31 | void setMail( RecMail mail ); | 32 | void setMail( RecMail mail ); |
32 | void setBody( RecBody body ); | 33 | void setBody( RecBody body ); |
33 | bool deleted; | 34 | bool deleted; |
34 | 35 | ||
35 | protected: | 36 | protected: |
36 | QString deHtml(const QString &string); | 37 | QString deHtml(const QString &string); |
37 | 38 | ||
38 | protected slots: | 39 | protected slots: |
39 | void slotReply(); | 40 | void slotReply(); |
40 | void slotForward(); | 41 | void slotForward(); |
41 | void setText(); | 42 | void setText(); |
42 | void slotItemClicked( QListViewItem * item , const QPoint & point, int c ); | 43 | void slotItemClicked( QListViewItem * item , const QPoint & point, int c ); |
43 | void slotDeleteMail( ); | 44 | void slotDeleteMail( ); |
44 | 45 | ||
45 | 46 | ||
46 | private: | 47 | private: |
47 | bool _inLoop; | 48 | bool _inLoop; |
48 | QString m_mailHtml; | 49 | QString m_mailHtml; |
49 | bool m_gotBody; | 50 | bool m_gotBody; |
50 | RecBody m_body; | 51 | RecBody m_body; |
51 | RecMail m_recMail; | 52 | RecMail m_recMail; |
52 | 53 | ||
53 | // 0 from 1 subject 2 bodytext 3 date | 54 | // 0 from 1 subject 2 bodytext 3 date |
54 | QMap <int,QString> m_mail; | 55 | QMap <int,QString> m_mail; |
55 | // 0 to 1 cc 2 bcc | 56 | // 0 to 1 cc 2 bcc |
56 | QMap <int,QStringList> m_mail2; | 57 | QMap <int,QStringList> m_mail2; |
57 | 58 | ||
58 | }; | 59 | }; |
59 | 60 | ||
60 | #endif | 61 | #endif |
diff --git a/noncore/net/mail/viewmailbase.cpp b/noncore/net/mail/viewmailbase.cpp index 38f92b4..0c7f671 100644 --- a/noncore/net/mail/viewmailbase.cpp +++ b/noncore/net/mail/viewmailbase.cpp | |||
@@ -1,76 +1,77 @@ | |||
1 | #include <qtextbrowser.h> | 1 | #include <qtextbrowser.h> |
2 | #include <qlistview.h> | 2 | #include <qlistview.h> |
3 | #include <qaction.h> | 3 | #include <qaction.h> |
4 | #include <qlabel.h> | 4 | #include <qlabel.h> |
5 | #include <qvbox.h> | 5 | #include <qvbox.h> |
6 | #include <qpopupmenu.h> | 6 | #include <qpopupmenu.h> |
7 | 7 | ||
8 | #include <qpe/qpetoolbar.h> | 8 | #include <qpe/qpetoolbar.h> |
9 | #include <qmenubar.h> | 9 | #include <qmenubar.h> |
10 | #include <qpe/resource.h> | 10 | #include <qpe/resource.h> |
11 | 11 | ||
12 | #include "viewmailbase.h" | 12 | #include "viewmailbase.h" |
13 | //#include "opendiag.h" | 13 | //#include "opendiag.h" |
14 | 14 | ||
15 | ViewMailBase::ViewMailBase(QWidget *parent, const char *name, WFlags fl) | 15 | ViewMailBase::ViewMailBase(QWidget *parent, const char *name, WFlags fl) |
16 | : QMainWindow(parent, name, fl) | 16 | : QMainWindow(parent, name, fl) |
17 | { | 17 | { |
18 | setCaption(tr("E-Mail by %1")); | 18 | setCaption(tr("E-Mail by %1")); |
19 | setToolBarsMovable(false); | 19 | setToolBarsMovable(false); |
20 | 20 | ||
21 | toolbar = new QToolBar(this); | 21 | toolbar = new QToolBar(this); |
22 | menubar = new QMenuBar( toolbar ); | 22 | menubar = new QMenuBar( toolbar ); |
23 | mailmenu = new QPopupMenu( menubar ); | 23 | mailmenu = new QPopupMenu( menubar ); |
24 | menubar->insertItem( tr( "Mail" ), mailmenu ); | 24 | menubar->insertItem( tr( "Mail" ), mailmenu ); |
25 | 25 | ||
26 | toolbar->setHorizontalStretchable(true); | 26 | toolbar->setHorizontalStretchable(true); |
27 | addToolBar(toolbar); | 27 | addToolBar(toolbar); |
28 | 28 | ||
29 | QLabel *spacer = new QLabel(toolbar); | 29 | QLabel *spacer = new QLabel(toolbar); |
30 | spacer->setBackgroundMode(QWidget::PaletteButton); | 30 | spacer->setBackgroundMode(QWidget::PaletteButton); |
31 | toolbar->setStretchableWidget(spacer); | 31 | toolbar->setStretchableWidget(spacer); |
32 | 32 | ||
33 | reply = new QAction(tr("Reply"), QIconSet(Resource::loadPixmap("mail/reply")), 0, 0, this); | 33 | reply = new QAction(tr("Reply"), QIconSet(Resource::loadPixmap("mail/reply")), 0, 0, this); |
34 | reply->addTo(toolbar); | 34 | reply->addTo(toolbar); |
35 | reply->addTo(mailmenu); | 35 | reply->addTo(mailmenu); |
36 | 36 | ||
37 | forward = new QAction(tr("Forward"), QIconSet(Resource::loadPixmap("mail/forward")), 0, 0, this); | 37 | forward = new QAction(tr("Forward"), QIconSet(Resource::loadPixmap("mail/forward")), 0, 0, this); |
38 | forward->addTo(toolbar); | 38 | forward->addTo(toolbar); |
39 | forward->addTo(mailmenu); | 39 | forward->addTo(mailmenu); |
40 | 40 | ||
41 | attachbutton = new QAction(tr("Attachments"), QIconSet(Resource::loadPixmap("mail/attach")), 0, 0, this, 0, true); | 41 | attachbutton = new QAction(tr("Attachments"), QIconSet(Resource::loadPixmap("mail/attach")), 0, 0, this, 0, true); |
42 | attachbutton->addTo(toolbar); | 42 | attachbutton->addTo(toolbar); |
43 | attachbutton->addTo(mailmenu); | 43 | attachbutton->addTo(mailmenu); |
44 | connect(attachbutton, SIGNAL(toggled(bool)), SLOT(slotChangeAttachview(bool))); | 44 | connect(attachbutton, SIGNAL(toggled(bool)), SLOT(slotChangeAttachview(bool))); |
45 | 45 | ||
46 | deleteMail = new QAction(tr("Delete Mail"), QIconSet(Resource::loadPixmap("mail/delete")), 0, 0, this); | 46 | deleteMail = new QAction(tr("Delete Mail"), QIconSet(Resource::loadPixmap("mail/delete")), 0, 0, this); |
47 | deleteMail->addTo(toolbar); | 47 | deleteMail->addTo(toolbar); |
48 | deleteMail->addTo(mailmenu); | 48 | deleteMail->addTo(mailmenu); |
49 | 49 | ||
50 | QVBox *view = new QVBox(this); | 50 | QVBox *view = new QVBox(this); |
51 | setCentralWidget(view); | 51 | setCentralWidget(view); |
52 | 52 | ||
53 | attachments = new QListView(view); | 53 | attachments = new QListView(view); |
54 | attachments->setMinimumHeight(90); | 54 | attachments->setMinimumHeight(90); |
55 | attachments->setMaximumHeight(90); | 55 | attachments->setMaximumHeight(90); |
56 | attachments->setAllColumnsShowFocus(true); | 56 | attachments->setAllColumnsShowFocus(true); |
57 | attachments->addColumn("Mime Type", 60); | 57 | attachments->addColumn("Mime Type", 60); |
58 | attachments->addColumn(tr("Filename"), 100); | 58 | attachments->addColumn(tr("Description"), 100); |
59 | attachments->addColumn(tr("Size"), 80); | 59 | attachments->addColumn(tr("Filename"), 80); |
60 | attachments->addColumn(tr("Size"), 80); | ||
60 | attachments->setSorting(-1); | 61 | attachments->setSorting(-1); |
61 | attachments->hide(); | 62 | attachments->hide(); |
62 | 63 | ||
63 | browser = new QTextBrowser(view); | 64 | browser = new QTextBrowser(view); |
64 | 65 | ||
65 | //openDiag = new OpenDiag(view); | 66 | //openDiag = new OpenDiag(view); |
66 | //openDiag->hide(); | 67 | //openDiag->hide(); |
67 | 68 | ||
68 | } | 69 | } |
69 | 70 | ||
70 | void ViewMailBase::slotChangeAttachview(bool state) | 71 | void ViewMailBase::slotChangeAttachview(bool state) |
71 | { | 72 | { |
72 | if (state) attachments->show(); | 73 | if (state) attachments->show(); |
73 | else attachments->hide(); | 74 | else attachments->hide(); |
74 | } | 75 | } |
75 | 76 | ||
76 | 77 | ||