Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 1 | // Copyright 2021 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 | |
Charlie Hu | d2002ce | 2021-07-20 14:58:31 | [diff] [blame] | 5 | import * as i18n from '../../../core/i18n/i18n.js'; |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 6 | import * as Protocol from '../../../generated/protocol.js'; |
Sigurd Schneider | d45f6ad | 2021-07-08 09:19:24 | [diff] [blame] | 7 | import * as Adorners from '../../../ui/components/adorners/adorners.js'; |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 8 | import * as ComponentHelpers from '../../../ui/components/helpers/helpers.js'; |
| 9 | import * as TreeOutline from '../../../ui/components/tree_outline/tree_outline.js'; |
| 10 | import * as LitHtml from '../../../ui/lit-html/lit-html.js'; |
Charlie Hu | d2002ce | 2021-07-20 14:58:31 | [diff] [blame] | 11 | |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 12 | import badgeStyles from './badge.css.js'; |
| 13 | import originTrialTokenRowsStyles from './originTrialTokenRows.css.js'; |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 14 | |
| 15 | const UIStrings = { |
| 16 | /** |
Jack Franklin | fd72c07 | 2022-12-21 11:45:01 | [diff] [blame^] | 17 | *@description Label for the 'origin' field in a parsed Origin Trial Token. |
| 18 | */ |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 19 | origin: 'Origin', |
| 20 | /** |
Charlie Hu | 20b933e | 2021-10-07 20:32:07 | [diff] [blame] | 21 | *@description Label for `trialName` field in a parsed Origin Trial Token. |
| 22 | * This field is only shown when token has unknown trial name as the token |
| 23 | * will be put into 'UNKNOWN' group. |
| 24 | */ |
| 25 | trialName: 'Trial Name', |
| 26 | /** |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 27 | *@description Label for `expiryTime` field in a parsed Origin Trial Token. |
| 28 | */ |
| 29 | expiryTime: 'Expiry Time', |
| 30 | /** |
| 31 | *@description Label for `usageRestriction` field in a parsed Origin Trial Token. |
| 32 | */ |
| 33 | usageRestriction: 'Usage Restriction', |
| 34 | /** |
| 35 | *@description Label for `isThirdParty` field in a parsed Origin Trial Token. |
| 36 | */ |
| 37 | isThirdParty: 'Third Party', |
| 38 | /** |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 39 | *@description Label for a field containing info about an Origin Trial Token's `matchSubDomains` field. |
| 40 | *An Origin Trial Token contains an origin URL. The `matchSubDomains` field describes whether the token |
| 41 | *only applies to the origin URL or to all subdomains of the origin URL as well. |
| 42 | *The field contains either 'true' or 'false'. |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 43 | */ |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 44 | matchSubDomains: 'Subdomain Matching', |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 45 | /** |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 46 | *@description Label for the raw(= encoded / not human-readable) Origin Trial Token. |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 47 | */ |
| 48 | rawTokenText: 'Raw Token', |
| 49 | /** |
| 50 | *@description Label for `status` field in an Origin Trial Token. |
| 51 | */ |
Charlie Hu | 5ebe35a | 2021-07-14 18:37:37 | [diff] [blame] | 52 | status: 'Token Status', |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 53 | /** |
| 54 | *@description Label for tokenWithStatus node. |
| 55 | */ |
| 56 | token: 'Token', |
| 57 | /** |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 58 | *@description Label for a badge showing the number of Origin Trial Tokens. This number is always greater than 1. |
| 59 | *@example {2} PH1 |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 60 | */ |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 61 | tokens: '{PH1} tokens', |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 62 | }; |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 63 | const str_ = i18n.i18n.registerUIStrings('panels/application/components/OriginTrialTreeView.ts', UIStrings); |
| 64 | const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_); |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 65 | |
| 66 | export interface BadgeData { |
| 67 | badgeContent: string; |
| 68 | style: 'error'|'success'|'secondary'; |
| 69 | } |
| 70 | |
| 71 | export class Badge extends HTMLElement { |
| 72 | static readonly litTagName = LitHtml.literal`devtools-resources-origin-trial-tree-view-badge`; |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 73 | readonly #shadow = this.attachShadow({mode: 'open'}); |
| 74 | #adorner = new Adorners.Adorner.Adorner(); |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 75 | |
| 76 | set data(data: BadgeData) { |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 77 | this.#render(data); |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 78 | } |
| 79 | |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 80 | connectedCallback(): void { |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 81 | this.#shadow.adoptedStyleSheets = [badgeStyles]; |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 82 | } |
| 83 | |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 84 | #render(data: BadgeData): void { |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 85 | const adornerContent = document.createElement('span'); |
| 86 | adornerContent.textContent = data.badgeContent; |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 87 | this.#adorner.data = { |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 88 | name: 'badge', |
| 89 | content: adornerContent, |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 90 | }; |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 91 | this.#adorner.classList.add(`badge-${data.style}`); |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 92 | |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 93 | LitHtml.render( |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 94 | LitHtml.html` |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 95 | ${this.#adorner} |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 96 | `, |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 97 | this.#shadow, {host: this}); |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 98 | } |
| 99 | } |
| 100 | |
| 101 | ComponentHelpers.CustomElements.defineComponent('devtools-resources-origin-trial-tree-view-badge', Badge); |
| 102 | |
| 103 | type TreeNode<DataType> = TreeOutline.TreeOutlineUtils.TreeNode<DataType>; |
| 104 | |
| 105 | // The Origin Trial Tree has 4 levels of content: |
| 106 | // - Origin Trial (has multiple Origin Trial tokens) |
| 107 | // - Origin Trial Token (has only 1 raw token text) |
| 108 | // - Fields in Origin Trial Token |
| 109 | // - Raw Origin Trial Token text (folded because the content is long) |
| 110 | export type OriginTrialTreeNodeData = Protocol.Page.OriginTrial|Protocol.Page.OriginTrialTokenWithStatus|string; |
| 111 | |
| 112 | function constructOriginTrialTree(originTrial: Protocol.Page.OriginTrial): TreeNode<OriginTrialTreeNodeData> { |
| 113 | return { |
| 114 | treeNodeData: originTrial, |
Johan Bay | 08670a7 | 2021-08-24 11:51:17 | [diff] [blame] | 115 | id: 'OriginTrialTreeNode#' + originTrial.trialName, |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 116 | children: async(): Promise<TreeNode<OriginTrialTreeNodeData>[]> => originTrial.tokensWithStatus.length > 1 ? |
| 117 | originTrial.tokensWithStatus.map(constructTokenNode) : |
| 118 | constructTokenDetailsNodes(originTrial.tokensWithStatus[0]), |
| 119 | renderer: (node: TreeNode<OriginTrialTreeNodeData>): LitHtml.TemplateResult => { |
| 120 | const trial = node.treeNodeData as Protocol.Page.OriginTrial; |
| 121 | const tokenCountBadge = LitHtml.html` |
| 122 | <${Badge.litTagName} .data=${{ |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 123 | badgeContent: i18nString(UIStrings.tokens, {PH1: trial.tokensWithStatus.length}), |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 124 | style: 'secondary', |
| 125 | } as BadgeData}></${Badge.litTagName}> |
| 126 | `; |
| 127 | |
| 128 | return LitHtml.html` |
| 129 | ${trial.trialName} |
| 130 | <${Badge.litTagName} .data=${{ |
| 131 | badgeContent: trial.status, |
| 132 | style: trial.status === Protocol.Page.OriginTrialStatus.Enabled ? 'success' : 'error', |
| 133 | } as BadgeData}></${Badge.litTagName}> |
| 134 | ${trial.tokensWithStatus.length > 1 ? tokenCountBadge : LitHtml.nothing} |
| 135 | `; |
| 136 | }, |
| 137 | }; |
| 138 | } |
| 139 | |
| 140 | function constructTokenNode(token: Protocol.Page.OriginTrialTokenWithStatus): TreeNode<OriginTrialTreeNodeData> { |
| 141 | return { |
| 142 | treeNodeData: token.status, |
Johan Bay | 08670a7 | 2021-08-24 11:51:17 | [diff] [blame] | 143 | id: 'TokenNode#' + token.rawTokenText, |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 144 | children: async(): Promise<TreeNode<OriginTrialTreeNodeData>[]> => constructTokenDetailsNodes(token), |
| 145 | renderer: (node: TreeNode<OriginTrialTreeNodeData>, state: {isExpanded: boolean}): LitHtml.TemplateResult => { |
| 146 | const tokenStatus = node.treeNodeData as string; |
| 147 | const statusBadge = LitHtml.html` |
| 148 | <${Badge.litTagName} .data=${{ |
| 149 | badgeContent: tokenStatus, |
| 150 | style: tokenStatus === Protocol.Page.OriginTrialTokenStatus.Success ? 'success' : 'error', |
| 151 | } as BadgeData}></${Badge.litTagName}> |
| 152 | `; |
| 153 | // Only display token status for convenience when the node is not expanded. |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 154 | return LitHtml.html`${i18nString(UIStrings.token)} ${state.isExpanded ? LitHtml.nothing : statusBadge}`; |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 155 | }, |
| 156 | }; |
| 157 | } |
| 158 | |
| 159 | interface TokenField { |
| 160 | name: string; |
| 161 | value: LitHtml.TemplateResult; |
| 162 | } |
| 163 | |
| 164 | function renderTokenDetails(node: TreeNode<OriginTrialTreeNodeData>): LitHtml.TemplateResult { |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 165 | return LitHtml.html` |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 166 | <${OriginTrialTokenRows.litTagName} .data=${{node: node} as OriginTrialTokenRowsData}> |
| 167 | </${OriginTrialTokenRows.litTagName}> |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 168 | `; |
| 169 | } |
| 170 | |
| 171 | function constructTokenDetailsNodes(token: Protocol.Page.OriginTrialTokenWithStatus): |
| 172 | TreeNode<OriginTrialTreeNodeData>[] { |
| 173 | return [ |
| 174 | { |
| 175 | treeNodeData: token, |
Johan Bay | 08670a7 | 2021-08-24 11:51:17 | [diff] [blame] | 176 | id: 'TokenDetailsNode#' + token.rawTokenText, |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 177 | renderer: renderTokenDetails, |
| 178 | }, |
| 179 | constructRawTokenTextNode(token.rawTokenText), |
| 180 | ]; |
| 181 | } |
| 182 | |
| 183 | function constructRawTokenTextNode(tokenText: string): TreeNode<OriginTrialTreeNodeData> { |
| 184 | return { |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 185 | treeNodeData: i18nString(UIStrings.rawTokenText), |
Johan Bay | 08670a7 | 2021-08-24 11:51:17 | [diff] [blame] | 186 | id: 'TokenRawTextContainerNode#' + tokenText, |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 187 | children: async(): Promise<TreeNode<OriginTrialTreeNodeData>[]> => [{ |
| 188 | treeNodeData: tokenText, |
Johan Bay | 08670a7 | 2021-08-24 11:51:17 | [diff] [blame] | 189 | id: 'TokenRawTextNode#' + tokenText, |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 190 | renderer: (data: TreeNode<OriginTrialTreeNodeData>): LitHtml.TemplateResult => { |
| 191 | const tokenText = data.treeNodeData as string; |
| 192 | return LitHtml.html` |
| 193 | <div style="overflow-wrap: break-word;"> |
| 194 | ${tokenText} |
| 195 | </div> |
| 196 | `; |
| 197 | }, |
| 198 | }], |
| 199 | }; |
| 200 | } |
| 201 | |
| 202 | function defaultRenderer(node: TreeNode<OriginTrialTreeNodeData>): LitHtml.TemplateResult { |
| 203 | return LitHtml.html`${String(node.treeNodeData)}`; |
| 204 | } |
| 205 | |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 206 | export interface OriginTrialTokenRowsData { |
| 207 | node: TreeNode<OriginTrialTreeNodeData>; |
| 208 | } |
| 209 | |
| 210 | export class OriginTrialTokenRows extends HTMLElement { |
Jack Franklin | 734befd | 2021-09-03 13:11:35 | [diff] [blame] | 211 | static readonly litTagName = LitHtml.literal`devtools-resources-origin-trial-token-rows`; |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 212 | readonly #shadow = this.attachShadow({mode: 'open'}); |
| 213 | #tokenWithStatus: Protocol.Page.OriginTrialTokenWithStatus|null = null; |
| 214 | #parsedTokenDetails: TokenField[] = []; |
| 215 | #dateFormatter: Intl.DateTimeFormat = new Intl.DateTimeFormat( |
Charlie Hu | d2002ce | 2021-07-20 14:58:31 | [diff] [blame] | 216 | i18n.DevToolsLocale.DevToolsLocale.instance().locale, |
| 217 | {dateStyle: 'long', timeStyle: 'long'}, |
| 218 | ); |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 219 | |
| 220 | set data(data: OriginTrialTokenRowsData) { |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 221 | this.#tokenWithStatus = data.node.treeNodeData as Protocol.Page.OriginTrialTokenWithStatus; |
| 222 | this.#setTokenFields(); |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 223 | } |
| 224 | |
| 225 | connectedCallback(): void { |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 226 | this.#shadow.adoptedStyleSheets = [originTrialTokenRowsStyles]; |
| 227 | this.#render(); |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 228 | } |
| 229 | |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 230 | #renderTokenField = (fieldValue: string, hasError?: boolean): LitHtml.TemplateResult => LitHtml.html` |
Jack Franklin | a31102b | 2021-12-03 15:01:22 | [diff] [blame] | 231 | <div class=${LitHtml.Directives.ifDefined(hasError ? 'error-text' : undefined)}> |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 232 | ${fieldValue} |
| 233 | </div>`; |
| 234 | |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 235 | #setTokenFields(): void { |
| 236 | if (!this.#tokenWithStatus?.parsedToken) { |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 237 | return; |
| 238 | } |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 239 | this.#parsedTokenDetails = [ |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 240 | { |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 241 | name: i18nString(UIStrings.origin), |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 242 | value: this.#renderTokenField( |
| 243 | this.#tokenWithStatus.parsedToken.origin, |
| 244 | this.#tokenWithStatus.status === Protocol.Page.OriginTrialTokenStatus.WrongOrigin), |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 245 | }, |
| 246 | { |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 247 | name: i18nString(UIStrings.expiryTime), |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 248 | value: this.#renderTokenField( |
| 249 | this.#dateFormatter.format(this.#tokenWithStatus.parsedToken.expiryTime * 1000), |
| 250 | this.#tokenWithStatus.status === Protocol.Page.OriginTrialTokenStatus.Expired), |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 251 | }, |
| 252 | { |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 253 | name: i18nString(UIStrings.usageRestriction), |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 254 | value: this.#renderTokenField(this.#tokenWithStatus.parsedToken.usageRestriction), |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 255 | }, |
| 256 | { |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 257 | name: i18nString(UIStrings.isThirdParty), |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 258 | value: this.#renderTokenField(this.#tokenWithStatus.parsedToken.isThirdParty.toString()), |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 259 | }, |
| 260 | { |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 261 | name: i18nString(UIStrings.matchSubDomains), |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 262 | value: this.#renderTokenField(this.#tokenWithStatus.parsedToken.matchSubDomains.toString()), |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 263 | }, |
| 264 | ]; |
Charlie Hu | 20b933e | 2021-10-07 20:32:07 | [diff] [blame] | 265 | |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 266 | if (this.#tokenWithStatus.status === Protocol.Page.OriginTrialTokenStatus.UnknownTrial) { |
| 267 | this.#parsedTokenDetails = [ |
Charlie Hu | 20b933e | 2021-10-07 20:32:07 | [diff] [blame] | 268 | { |
| 269 | name: i18nString(UIStrings.trialName), |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 270 | value: this.#renderTokenField(this.#tokenWithStatus.parsedToken.trialName), |
Charlie Hu | 20b933e | 2021-10-07 20:32:07 | [diff] [blame] | 271 | }, |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 272 | ...this.#parsedTokenDetails, |
Charlie Hu | 20b933e | 2021-10-07 20:32:07 | [diff] [blame] | 273 | ]; |
| 274 | } |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 275 | } |
| 276 | |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 277 | #render(): void { |
| 278 | if (!this.#tokenWithStatus) { |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 279 | return; |
| 280 | } |
| 281 | |
| 282 | const tokenDetails: TokenField[] = [ |
| 283 | { |
Wolfgang Beyer | 657d45c | 2021-07-22 10:10:46 | [diff] [blame] | 284 | name: i18nString(UIStrings.status), |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 285 | value: LitHtml.html` |
| 286 | <${Badge.litTagName} .data=${{ |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 287 | badgeContent: this.#tokenWithStatus.status, |
| 288 | style: this.#tokenWithStatus.status === Protocol.Page.OriginTrialTokenStatus.Success ? 'success' : 'error', |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 289 | } as BadgeData}></${Badge.litTagName}>`, |
| 290 | }, |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 291 | ...this.#parsedTokenDetails, |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 292 | ]; |
| 293 | |
| 294 | const tokenDetailRows = tokenDetails.map((field: TokenField): LitHtml.TemplateResult => { |
| 295 | return LitHtml.html` |
| 296 | <div class="key">${field.name}</div> |
| 297 | <div class="value">${field.value}</div> |
| 298 | `; |
| 299 | }); |
| 300 | |
| 301 | LitHtml.render( |
| 302 | LitHtml.html` |
| 303 | <div class="content"> |
| 304 | ${tokenDetailRows} |
| 305 | </div> |
| 306 | `, |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 307 | this.#shadow, {host: this}); |
Kriti Sapra | d143c6e | 2021-07-16 11:03:51 | [diff] [blame] | 308 | } |
| 309 | } |
| 310 | |
| 311 | ComponentHelpers.CustomElements.defineComponent('devtools-resources-origin-trial-token-rows', OriginTrialTokenRows); |
| 312 | |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 313 | export interface OriginTrialTreeViewData { |
| 314 | trials: Protocol.Page.OriginTrial[]; |
| 315 | } |
| 316 | |
| 317 | export class OriginTrialTreeView extends HTMLElement { |
Jack Franklin | 734befd | 2021-09-03 13:11:35 | [diff] [blame] | 318 | static readonly litTagName = LitHtml.literal`devtools-resources-origin-trial-tree-view`; |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 319 | readonly #shadow = this.attachShadow({mode: 'open'}); |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 320 | |
| 321 | set data(data: OriginTrialTreeViewData) { |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 322 | this.#render(data.trials); |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 323 | } |
| 324 | |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 325 | #render(trials: Protocol.Page.OriginTrial[]): void { |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 326 | if (!trials.length) { |
| 327 | return; |
| 328 | } |
| 329 | |
| 330 | LitHtml.render( |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 331 | LitHtml.html` |
Jack Franklin | a31102b | 2021-12-03 15:01:22 | [diff] [blame] | 332 | <${TreeOutline.TreeOutline.TreeOutline.litTagName} .data=${{ |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 333 | tree: trials.map(constructOriginTrialTree), |
| 334 | defaultRenderer, |
Jack Franklin | a31102b | 2021-12-03 15:01:22 | [diff] [blame] | 335 | } as TreeOutline.TreeOutline.TreeOutlineData<OriginTrialTreeNodeData>}> |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 336 | </${TreeOutline.TreeOutline.TreeOutline.litTagName}> |
| 337 | `, |
Tim van der Lippe | c3f835a | 2021-12-15 13:28:32 | [diff] [blame] | 338 | this.#shadow, {host: this}); |
Charlie Hu | 2086be5 | 2021-07-02 16:12:12 | [diff] [blame] | 339 | } |
| 340 | } |
| 341 | |
| 342 | ComponentHelpers.CustomElements.defineComponent('devtools-resources-origin-trial-tree-view', OriginTrialTreeView); |
Jack Franklin | 734befd | 2021-09-03 13:11:35 | [diff] [blame] | 343 | |
| 344 | declare global { |
| 345 | interface HTMLElementTagNameMap { |
| 346 | 'devtools-resources-origin-trial-tree-view': OriginTrialTreeView; |
| 347 | 'devtools-resources-origin-trial-token-rows': OriginTrialTokenRows; |
| 348 | 'devtools-resources-origin-trial-tree-view-badge': Badge; |
| 349 | } |
| 350 | } |