Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2015 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 cr.define('media_router', function() { | |
| 6 'use strict'; | |
| 7 | |
| 8 /** | |
| 9 * @param {number} castMode The type of cast mode. | |
|
mark a. foltz
2015/03/24 18:09:16
Where are legal values defined?
apacible
2015/03/24 20:46:26
RE: all legal values questions --
These are all de
| |
| 10 * @param {string} title The title of the cast mode. | |
|
mark a. foltz
2015/03/24 18:09:17
Is the title and description for internal use, or
apacible
2015/03/24 20:46:26
The description is shown.
RE: all localization qu
| |
| 11 * @param {string} description The description of the cast mode. | |
| 12 * @constructor | |
| 13 * @struct | |
| 14 */ | |
| 15 var CastMode = function(castMode, title, description) { | |
| 16 /** @type {number} */ | |
| 17 this.castMode = castMode; | |
| 18 | |
| 19 /** @type {string} */ | |
| 20 this.title = title; | |
| 21 | |
| 22 /** @type {string} */ | |
| 23 this.description = description; | |
| 24 }; | |
| 25 | |
| 26 /** | |
|
James Hawkins
2015/03/24 17:48:06
nit: Double blank lines between top-level JSDoc bl
apacible
2015/03/24 20:46:26
Done.
| |
| 27 * @param {string} id The ID of this issue. | |
|
mark a. foltz
2015/03/24 18:09:15
What are legal values? Are these defined somewher
apacible
2015/03/24 20:46:26
Issue IDs are created in Media Router using Genera
| |
| 28 * @param {string} title The issue title. | |
|
mark a. foltz
2015/03/24 18:09:16
Similar questions about localization for all the s
apacible
2015/03/24 20:46:27
Acknowledged.
| |
| 29 * @param {string} message The issue message. | |
| 30 * @param {string} defaultActionText The button text of default action. | |
|
mark a. foltz
2015/03/24 18:09:16
What if the text overflows the dimensions of the b
apacible
2015/03/24 20:46:26
We'll need to talk to UX about this (and all other
| |
| 31 * @param {number} defaultActionType The type of default action. | |
|
mark a. foltz
2015/03/24 18:09:16
Where are the types defined?
apacible
2015/03/24 20:46:26
Acknowledged.
| |
| 32 * @param {?string} optActionText The button text of optional action. | |
| 33 * @param {?number} optActionType The type of optional action. | |
|
mark a. foltz
2015/03/24 18:09:16
Where are the types defined?
apacible
2015/03/24 20:46:26
Acknowledged.
| |
| 34 * @param {?string} routeId The route ID to which this issue | |
|
mark a. foltz
2015/03/24 18:09:17
mediaRouteId
apacible
2015/03/24 20:46:26
Done.
| |
| 35 * pertains. If not set, this is a global issue. | |
|
mark a. foltz
2015/03/24 18:09:16
What if the issue occurred before or after the rou
apacible
2015/03/24 20:46:26
We currently don't have screen-specific issues. If
| |
| 36 * @param {boolean} isBlocking True if this issue blocks other UI. | |
| 37 * @param {?string} helpURL The URL to be opened if learn more is clicked. | |
| 38 * @constructor | |
| 39 * @struct | |
| 40 */ | |
| 41 var Issue = function(id, title, message, defaultActionText, | |
| 42 defaultActionType, optActionText, optActionType, | |
|
James Hawkins
2015/03/24 17:48:06
nit: opt_actionText, opt_actionType
apacible
2015/03/24 20:46:26
Ack, question in next comment before I change this
| |
| 43 routeId, isBlocking, helpURL) { | |
| 44 /** @type {string} */ | |
| 45 this.id = id; | |
| 46 | |
| 47 /** @type {string} */ | |
| 48 this.title = title; | |
| 49 | |
| 50 /** @type {string} */ | |
| 51 this.message = message; | |
| 52 | |
| 53 /** @type {string} */ | |
| 54 this.defaultActionText = defaultActionText; | |
| 55 | |
| 56 /** @type {number} */ | |
| 57 this.defaultActionType = defaultActionType; | |
| 58 | |
| 59 /** @type {?string} */ | |
| 60 this.optActionText = optActionText; | |
|
James Hawkins
2015/03/24 17:48:06
nit: Only the parameter should have 'opt' in the n
apacible
2015/03/24 20:46:26
Why is 'opt' restricted to the parameter?
Should
James Hawkins
2015/03/24 21:27:56
Because the member variable itself is not optional
apacible
2015/03/24 21:58:11
Thanks! Also, should I prepend all optional parame
| |
| 61 | |
| 62 /** @type {?number} */ | |
| 63 this.optActionType = optActionType; | |
| 64 | |
| 65 /** @type {?string} */ | |
| 66 this.routeId = routeId; | |
| 67 | |
| 68 /** @type {boolean} */ | |
| 69 this.isBlocking = isBlocking; | |
| 70 | |
| 71 /** @type {?string} */ | |
| 72 this.helpURL = helpURL; | |
| 73 }; | |
| 74 | |
| 75 /** | |
| 76 * @param {string} id The route ID. | |
|
mark a. foltz
2015/03/24 18:09:15
The media route ID
apacible
2015/03/24 20:46:26
Done.
| |
| 77 * @param {string} sinkId The ID of the sink running this route. | |
|
mark a. foltz
2015/03/24 18:09:15
"the media sink"
apacible
2015/03/24 20:46:26
Done.
| |
| 78 * @param {?string} iconUrl The icon URL of this route. | |
|
mark a. foltz
2015/03/24 18:09:16
This should just point to a bundled resource, corr
apacible
2015/03/24 20:46:27
This is the favicon of whatever we're casting. Tal
| |
| 79 * @param {string} title The short description of this route. | |
| 80 * @param {?number} tabId The ID of the tab in which web app is running and | |
| 81 * accessing the route. | |
| 82 * @param {boolean} isLocal True if this is a locally launched route. | |
|
mark a. foltz
2015/03/24 18:09:16
s/launched/created/
apacible
2015/03/24 20:46:27
Done.
| |
| 83 * @constructor | |
| 84 * @struct | |
| 85 */ | |
| 86 var Route = function(id, sinkId, iconUrl, title, tabId, isLocal) { | |
| 87 /** @type {string} */ | |
| 88 this.id = id; | |
| 89 | |
| 90 /** @type {string} */ | |
| 91 this.sinkId = sinkId; | |
| 92 | |
| 93 /** @type {?string} */ | |
| 94 this.iconUrl = iconUrl; | |
| 95 | |
| 96 /** @type {string} */ | |
| 97 this.title = title; | |
| 98 | |
| 99 /** @type {?number} */ | |
| 100 this.tabId = tabId; | |
| 101 | |
| 102 /** @type {boolean} */ | |
| 103 this.isLocal = isLocal; | |
| 104 }; | |
| 105 | |
| 106 /** | |
| 107 * @param {string} id The ID of the sink. | |
|
mark a. foltz
2015/03/24 18:09:17
"the media sink"
apacible
2015/03/24 20:46:26
Done.
| |
| 108 * @param {string} name The name of the sink. | |
| 109 * @param {media_router.SinkStatus} status The readiness state of the sink. | |
| 110 * @param {!Array<number>} castModes Cast modes compatible with the sink. | |
| 111 * @constructor | |
| 112 * @struct | |
| 113 */ | |
| 114 var Sink = function(id, name, status) { | |
| 115 /** @type {string} */ | |
| 116 this.id = id; | |
| 117 | |
| 118 /** @type {string} */ | |
| 119 this.name = name; | |
| 120 | |
| 121 /** @type {media_router.SinkStatus} */ | |
| 122 this.status = status; | |
| 123 | |
| 124 /** @type {!Array<number>} */ | |
| 125 this.castModes = castModes; | |
| 126 }; | |
| 127 | |
| 128 /** | |
| 129 * @enum {string} | |
| 130 */ | |
| 131 var SinkStatus = { | |
|
James Hawkins
2015/03/24 17:48:06
Consider moving SinkStatus higher up (at least hig
apacible
2015/03/24 20:46:26
Moved to top.
| |
| 132 IDLE: 'idle', | |
| 133 ACTIVE: 'active', | |
| 134 REQUEST_PENDING: 'request_pending' | |
| 135 }; | |
| 136 | |
| 137 /** | |
| 138 * @param {number} tabId The current tab ID. | |
| 139 * @param {string} domain The domain of the current tab. | |
| 140 * @param {boolean} hasCastApp True if tab has a current Cast App. | |
|
mark a. foltz
2015/03/24 18:09:16
When is this set to true? Does it mean to say "an
apacible
2015/03/24 20:46:26
It's when the tab has a current cast app (e.g. You
| |
| 141 * @constructor | |
| 142 * @struct | |
| 143 */ | |
| 144 var TabInfo = function(tabId, domain, hasCastApp) { | |
| 145 /** @type {number} */ | |
| 146 this.tabId = tabId; | |
| 147 | |
| 148 /** @type {string} */ | |
| 149 this.domain = domain; | |
| 150 | |
| 151 /** @type {boolean} */ | |
| 152 this.hasCastApp = hasCastApp; | |
| 153 }; | |
| 154 | |
| 155 return { | |
| 156 CastMode: CastMode, | |
| 157 Issue: Issue, | |
| 158 Route: Route, | |
| 159 Sink: Sink, | |
| 160 SinkStatus: SinkStatus, | |
| 161 TabInfo: TabInfo, | |
| 162 }; | |
| 163 }); | |
| OLD | NEW |