Merge "replace delegate with EventHandler<T>"
[platform/core/csapi/tizenfx.git] / src / Tizen.Multimedia.Remoting / MediaController / PlaybackCommandReceivedEventArgs.cs
1 /*
2  * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the License);
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an AS IS BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 using System;
18
19 namespace Tizen.Multimedia.Remoting
20 {
21     /// <summary>
22     /// Provides data for the <see cref="MediaControlServer.PlaybackCommandReceived"/> event.
23     /// </summary>
24     public class PlaybackCommandReceivedEventArgs : EventArgs
25     {
26         /// <summary>
27         /// Initializes a new instance of the <see cref="PlaybackCommandReceivedEventArgs"/> class.
28         /// </summary>
29         /// <param name="clientAppId">The client application id.</param>
30         /// <param name="command">The playback command.</param>
31         /// <exception cref="ArgumentNullException"><paramref name="clientAppId"/> is null.</exception>
32         /// <exception cref="ArgumentException"><paramref name="command"/> is invalid.</exception>
33         public PlaybackCommandReceivedEventArgs(string clientAppId, MediaControlPlaybackCommand command)
34         {
35             if (clientAppId == null)
36             {
37                 throw new ArgumentNullException(nameof(clientAppId));
38             }
39
40             ValidationUtil.ValidateEnum(typeof(MediaControlPlaybackCommand), command, nameof(command));
41
42             ClientAppId = clientAppId;
43             Command = command;
44         }
45
46         /// <summary>
47         /// Gets the application id of the client that sent command.
48         /// </summary>
49         /// <value>The client application id.</value>
50         public string ClientAppId { get; }
51
52         /// <summary>
53         /// Gets the command.
54         /// </summary>
55         /// <value>The <see cref="MediaControlPlaybackCommand"/>.</value>
56         public MediaControlPlaybackCommand Command { get; }
57     }
58 }