aboutsummaryrefslogtreecommitdiffstats
path: root/src/net/java/sip/communicator/impl/systray/StatusMessageMenu.java
blob: b1745ceac937b079964b02237ee92001a2c36b44 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
/*
 * SIP Communicator, the OpenSource Java VoIP and Instant Messaging client.
 *
 * Distributable under LGPL license.
 * See terms of license at gnu.org.
 */
package net.java.sip.communicator.impl.systray;

import java.awt.*;
import java.awt.event.*;

import javax.swing.*;

import net.java.sip.communicator.service.protocol.*;
import net.java.sip.communicator.util.*;

public class StatusMessageMenu
    extends JMenu
    implements ActionListener
{
    private Logger logger = Logger.getLogger(StatusMessageMenu.class);

    private JMenuItem noMessageItem
        = new JMenuItem(Resources.getString("noMessage"));

    private JMenuItem newMessageItem
        = new JMenuItem(Resources.getString("newMessage"));

    private JMenuItem busyMessageItem
        =  new JMenuItem(Resources.getString("busyMessage"));

    private JMenuItem brbMessageItem
        = new JMenuItem(Resources.getString("brbMessage"));

    private ProtocolProviderService protocolProvider;

    public StatusMessageMenu(  ProtocolProviderService protocolProvider)
    {
        super(Resources.getString("setStatusMessage"));

        this.protocolProvider = protocolProvider;

        this.noMessageItem.addActionListener(this);
        this.newMessageItem.addActionListener(this);
        this.busyMessageItem.addActionListener(this);
        this.brbMessageItem.addActionListener(this);

        this.add(noMessageItem);
        this.add(newMessageItem);

        this.addSeparator();

        this.add(busyMessageItem);
        this.add(brbMessageItem);
    }

    public void actionPerformed(ActionEvent e)
    {
        JMenuItem menuItem = (JMenuItem) e.getSource();

        String statusMessage = "";

        if (menuItem.equals(newMessageItem))
        {
            NewStatusMessageDialog dialog
                = new NewStatusMessageDialog(protocolProvider);

            dialog.setLocation(
                Toolkit.getDefaultToolkit().getScreenSize().width/2
                    - dialog.getWidth()/2,
                Toolkit.getDefaultToolkit().getScreenSize().height/2
                    - dialog.getHeight()/2
                );

            dialog.setVisible(true);

            dialog.requestFocusInFiled();
        }
        else if (menuItem.equals(busyMessageItem))
        {
            statusMessage = Resources.getString("busyMessage");
        }
        else if (menuItem.equals(brbMessageItem))
        {
            statusMessage = Resources.getString("brbMessage");
        }

        new PublishStatusMessageThread(statusMessage).start();
    }

    /**
     *  This class allow to use a thread to change the presence status.
     */
    private class PublishStatusMessageThread extends Thread
    {
        private String message;

        private PresenceStatus currentStatus;

        private OperationSetPresence presenceOpSet;

        public PublishStatusMessageThread(String message)
        {
            this.message = message;

            presenceOpSet
                = (OperationSetPersistentPresence) protocolProvider
                    .getOperationSet(OperationSetPresence.class);

            this.currentStatus = presenceOpSet.getPresenceStatus();
        }

        public void run()
        {
            try
            {
                presenceOpSet.publishPresenceStatus(currentStatus, message);
            }
            catch (IllegalArgumentException e1)
            {

                logger.error("Error - changing status", e1);
            }
            catch (IllegalStateException e1)
            {

                logger.error("Error - changing status", e1);
            }
            catch (OperationFailedException e1)
            {
                
                if (e1.getErrorCode()
                    == OperationFailedException.GENERAL_ERROR)
                {
                    logger.error(
                        "General error occured while "
                        + "publishing presence status.",
                        e1);
                }
                else if (e1.getErrorCode()
                        == OperationFailedException
                            .NETWORK_FAILURE) 
                {
                    logger.error(
                        "Network failure occured while "
                        + "publishing presence status.",
                        e1);
                } 
                else if (e1.getErrorCode()
                        == OperationFailedException
                            .PROVIDER_NOT_REGISTERED) 
                {
                    logger.error(
                        "Protocol provider must be"
                        + "registered in order to change status.",
                        e1);
                }
            }
        }
    }
}