diff --git a/packages/debugger-frontend/BUILD_INFO b/packages/debugger-frontend/BUILD_INFO index 968f8de9d5cab5..02ef2c4980485a 100644 --- a/packages/debugger-frontend/BUILD_INFO +++ b/packages/debugger-frontend/BUILD_INFO @@ -1,5 +1,5 @@ -@generated SignedSource<> -Git revision: 8cce39003f66f66a8fb4c0e581a2b5046cf9c1d1 +@generated SignedSource<> +Git revision: 54afd8765db32a9640edef3788085b991fe4b88a Built with --nohooks: false Is local checkout: false Remote URL: https://github.com/facebook/react-native-devtools-frontend diff --git a/packages/debugger-frontend/dist/third-party/front_end/entrypoints/heap_snapshot_worker/heap_snapshot_worker.js b/packages/debugger-frontend/dist/third-party/front_end/entrypoints/heap_snapshot_worker/heap_snapshot_worker.js index a39cbee0af74dc..b411727f252291 100644 --- a/packages/debugger-frontend/dist/third-party/front_end/entrypoints/heap_snapshot_worker/heap_snapshot_worker.js +++ b/packages/debugger-frontend/dist/third-party/front_end/entrypoints/heap_snapshot_worker/heap_snapshot_worker.js @@ -1 +1 @@ -import*as e from"../../models/heap_snapshot_model/heap_snapshot_model.js";import*as t from"../../core/i18n/i18n.js";import*as s from"../../core/platform/platform.js";import*as n from"../../models/text_utils/text_utils.js";class i{#e;#t;#s;#n;#i;#o;#r;constructor(e,t){this.#e=e.strings,this.#t=1,this.#s=[],this.#n={},this.#i={},this.#o={},this.#r=null,this.#a(e),this.#d(e,t)}#a(e){const t=this.#e,s=e.snapshot.meta.trace_function_info_fields,n=s.indexOf("name"),i=s.indexOf("script_name"),o=s.indexOf("script_id"),r=s.indexOf("line"),d=s.indexOf("column"),h=s.length,l=e.trace_function_infos,c=l.length,u=this.#s=new Array(c/h);let g=0;for(let e=0;e0}}class a{functionName;scriptName;scriptId;line;column;totalCount;totalSize;totalLiveCount;totalLiveSize;#r;#g;constructor(e,t,s,n,i){this.functionName=e,this.scriptName=t,this.scriptId=s,this.line=n,this.column=i,this.totalCount=0,this.totalSize=0,this.totalLiveCount=0,this.totalLiveSize=0,this.#r=[]}addTraceTopNode(e){0!==e.allocationCount&&(this.#r.push(e),this.totalCount+=e.allocationCount,this.totalSize+=e.allocationSize,this.totalLiveCount+=e.liveCount,this.totalLiveSize+=e.liveSize)}bottomUpRoot(){return this.#r.length?(this.#g||this.#p(),this.#g):null}#p(){this.#g=new r(this);for(let e=0;e>>O}classKeyInternal(){if(this.rawType()!==this.snapshot.nodeObjectType)return this.classIndex();const e=this.snapshot.getLocation(this.nodeIndex);return e?`${e.scriptId},${e.lineNumber},${e.columnNumber},${this.className()}`:this.classIndex()}setClassIndex(e){let t=this.#E();if(t&=C,t|=e<100||e.push(t)}function w(e,t){t.postMessage({problemReport:e})}class T{argsStep1;argsStep2;argsStep3;constructor(e){const{promise:t,resolve:s}=Promise.withResolvers();this.argsStep1=t;const{promise:n,resolve:i}=Promise.withResolvers();this.argsStep2=n;const{promise:o,resolve:r}=Promise.withResolvers();this.argsStep3=o,e.onmessage=e=>{const t=e.data;switch(t.step){case 1:s(t.args);break;case 2:i(t.args);break;case 3:r(t.args)}},this.initialize(e)}async getNodeSelfSizes(){return(await this.argsStep3).nodeSelfSizes}async initialize(e){try{const t=await this.argsStep1,n=E.buildRetainers(t),i=await this.argsStep2,o={...i,...t,...n,essentialEdges:s.TypedArrayUtilities.createBitVector(i.essentialEdgesBuffer),port:e,nodeSelfSizesPromise:this.getNodeSelfSizes()},r=await E.calculateDominatorsAndRetainedSizes(o),a=E.buildDominatedNodes({...o,...r}),d={...n,...r,...a};e.postMessage({resultsFromSecondWorker:d},{transfer:[d.dominatorsTree.buffer,d.firstRetainerIndex.buffer,d.retainedSizes.buffer,d.retainingEdges.buffer,d.retainingNodes.buffer,d.dominatedNodes.buffer,d.firstDominatedNodeIndex.buffer]})}catch(t){e.postMessage({error:t+"\n"+t?.stack})}}}const C=3,O=2;class E{nodes;containmentEdges;#k;#V;#j=null;strings;#M;#P;#H=-5;rootNodeIndexInternal=0;#U={};#B;#L={};#W={};profile;nodeTypeOffset;nodeNameOffset;nodeIdOffset;nodeSelfSizeOffset;#J;nodeTraceNodeIdOffset;nodeFieldCount;nodeTypes;nodeArrayType;nodeHiddenType;nodeObjectType;nodeNativeType;nodeStringType;nodeConsStringType;nodeSlicedStringType;nodeCodeType;nodeSyntheticType;nodeClosureType;nodeRegExpType;edgeFieldsCount;edgeTypeOffset;edgeNameOffset;edgeToNodeOffset;edgeTypes;edgeElementType;edgeHiddenType;edgeInternalType;edgeShortcutType;edgeWeakType;edgeInvisibleType;edgePropertyType;#K;#$;#Q;#q;#G;nodeCount;#X;retainedSizes;firstEdgeIndexes;retainingNodes;retainingEdges;firstRetainerIndex;nodeDistances;firstDominatedNodeIndex;dominatedNodes;dominatorsTree;#Y;nodeDetachednessAndClassIndexOffset;#Z;#ee=new Set;#te=new Set;#se;#ne;detachednessAndClassIndexArray;#ie=new Map;#oe;constructor(e,t){this.nodes=e.nodes,this.containmentEdges=e.edges,this.#k=e.snapshot.meta,this.#V=e.samples,this.strings=e.strings,this.#M=e.locations,this.#P=t,e.snapshot.root_index&&(this.rootNodeIndexInternal=e.snapshot.root_index),this.profile=e,this.#ne=s.TypedArrayUtilities.createBitVector(this.strings.length)}async initialize(e){const t=this.#k;this.nodeTypeOffset=t.node_fields.indexOf("type"),this.nodeNameOffset=t.node_fields.indexOf("name"),this.nodeIdOffset=t.node_fields.indexOf("id"),this.nodeSelfSizeOffset=t.node_fields.indexOf("self_size"),this.#J=t.node_fields.indexOf("edge_count"),this.nodeTraceNodeIdOffset=t.node_fields.indexOf("trace_node_id"),this.nodeDetachednessAndClassIndexOffset=t.node_fields.indexOf("detachedness"),this.nodeFieldCount=t.node_fields.length,this.nodeTypes=t.node_types[this.nodeTypeOffset],this.nodeArrayType=this.nodeTypes.indexOf("array"),this.nodeHiddenType=this.nodeTypes.indexOf("hidden"),this.nodeObjectType=this.nodeTypes.indexOf("object"),this.nodeNativeType=this.nodeTypes.indexOf("native"),this.nodeStringType=this.nodeTypes.indexOf("string"),this.nodeConsStringType=this.nodeTypes.indexOf("concatenated string"),this.nodeSlicedStringType=this.nodeTypes.indexOf("sliced string"),this.nodeCodeType=this.nodeTypes.indexOf("code"),this.nodeSyntheticType=this.nodeTypes.indexOf("synthetic"),this.nodeClosureType=this.nodeTypes.indexOf("closure"),this.nodeRegExpType=this.nodeTypes.indexOf("regexp"),this.edgeFieldsCount=t.edge_fields.length,this.edgeTypeOffset=t.edge_fields.indexOf("type"),this.edgeNameOffset=t.edge_fields.indexOf("name_or_index"),this.edgeToNodeOffset=t.edge_fields.indexOf("to_node"),this.edgeTypes=t.edge_types[this.edgeTypeOffset],this.edgeTypes.push("invisible"),this.edgeElementType=this.edgeTypes.indexOf("element"),this.edgeHiddenType=this.edgeTypes.indexOf("hidden"),this.edgeInternalType=this.edgeTypes.indexOf("internal"),this.edgeShortcutType=this.edgeTypes.indexOf("shortcut"),this.edgeWeakType=this.edgeTypes.indexOf("weak"),this.edgeInvisibleType=this.edgeTypes.indexOf("invisible"),this.edgePropertyType=this.edgeTypes.indexOf("property");const s=t.location_fields||[];this.#K=s.indexOf("object_index"),this.#$=s.indexOf("script_id"),this.#Q=s.indexOf("line"),this.#q=s.indexOf("column"),this.#G=s.length,this.nodeCount=this.nodes.length/this.nodeFieldCount,this.#X=this.containmentEdges.length/this.edgeFieldsCount,this.#P.updateStatus("Building edge indexes…"),this.firstEdgeIndexes=new Uint32Array(this.nodeCount+1),this.buildEdgeIndexes(),this.#P.updateStatus("Building retainers…");const n=this.startInitStep1InSecondThread(e);if(this.#P.updateStatus("Propagating DOM state…"),this.propagateDOMState(),this.#P.updateStatus("Calculating node flags…"),this.calculateFlags(),this.#P.updateStatus("Building dominated nodes…"),this.startInitStep2InSecondThread(e),this.#P.updateStatus("Calculating shallow sizes…"),this.calculateShallowSizes(),this.#P.updateStatus("Calculating retained sizes…"),this.startInitStep3InSecondThread(e),this.#P.updateStatus("Calculating distances…"),this.nodeDistances=new Int32Array(this.nodeCount),this.calculateDistances(!1),this.#P.updateStatus("Calculating object names…"),this.calculateObjectNames(),this.applyInterfaceDefinitions(this.inferInterfaceDefinitions()),this.#P.updateStatus("Calculating samples…"),this.buildSamples(),this.#P.updateStatus("Building locations…"),this.buildLocationMap(),this.#P.updateStatus("Calculating retained sizes…"),await this.installResultsFromSecondThread(n),this.#P.updateStatus("Calculating statistics…"),this.calculateStatistics(),this.profile.snapshot.trace_function_count){this.#P.updateStatus("Building allocation statistics…");const e=this.nodes.length,t=this.nodeFieldCount,s=this.rootNode(),n={};for(let i=0;i{e.onmessage=e=>{const n=e.data;if(n?.problemReport){const e=n.problemReport;console.warn(function(e,t){const s=e.rootNode();return t.map((e=>"string"==typeof e?e:(s.nodeIndex=e,`${s.name()} @${s.id()}`))).join("\n ")}(this,e))}else if(n?.resultsFromSecondWorker){const e=n.resultsFromSecondWorker;t(e)}else n?.error&&s(n.error)}})),s=this.#X,{containmentEdges:n,edgeToNodeOffset:i,edgeFieldsCount:o,nodeFieldCount:r}=this,a=new Uint32Array(s);for(let e=0;ee&&n<=t}}createAllocationStackFilter(e){if(!this.#Y)throw new Error("No Allocation Profile provided");const t=this.#Y.traceIds(e);if(!t.length)return;const s={};for(let e=0;e{const s=e.nodeIndex/this.nodeFieldCount;return t.getBit(s)},i=e=>{const s=new Int32Array(this.nodeCount);for(let e=0;e{for(let e=0;e2!==t.node().detachedness())),o(),e=>!n(e);case"objectsRetainedByConsole":return i(((e,t)=>!(e.isSynthetic()&&t.hasStringName()&&t.name().endsWith(" / DevTools console")))),o(),e=>!n(e);case"duplicatedStrings":{const e=new Map,s=this.createNode(0);for(let n=0;n!this.#ee.has(s.nodeIndex())&&(!e||e(t,s)),void 0===this.#se&&(this.#se=new Int32Array(n))}const i=t?this.#se:this.nodeDistances,o=this.#H;for(let e=0;e0?e.HeapSnapshotModel.baseSystemDistance:0,r[0]=this.rootNode().nodeIndex,a=1,this.bfs(r,a,i,s)}bfs(e,t,s,n){const i=this.edgeFieldsCount,o=this.nodeFieldCount,r=this.containmentEdges,a=this.firstEdgeIndexes,d=this.edgeToNodeOffset,h=this.edgeTypeOffset,l=this.nodeCount,c=this.edgeWeakType,u=this.#H;let g=0;const p=this.createEdge(0),f=this.createNode(0);for(;gl)throw new Error("BFS failed. Nodes to visit ("+t+") is more than nodes count ("+l+")")}buildAggregates(e){const t=new Map,s=this.nodes,n=s.length,i=this.nodeFieldCount,o=this.nodeSelfSizeOffset,r=this.rootNode(),a=this.nodeDistances;for(let d=0;d(t.nodeIndex=e,s.nodeIndex=n,t.id() \/ part of key \(.*? @\d+\) -> value \(.*? @\d+\) pair in WeakMap \(table @(?\d+)\))$/);if(t)return t.groups;this.#ne.setBit(e)}computeIsEssentialEdge(e,t,s){const n=this.containmentEdges.getValue(t+this.edgeTypeOffset);if(n===this.edgeInternalType){const s=this.containmentEdges.getValue(t+this.edgeNameOffset),n=this.tryParseWeakMapEdgeName(s);if(n){if(this.nodes.getValue(e+this.nodeIdOffset)===parseInt(n.tableId,10))return!1}}if(n===this.edgeWeakType)return!1;const i=this.containmentEdges.getValue(t+this.edgeToNodeOffset);if(e===i)return!1;if(e!==this.rootNodeIndex){if(n===this.edgeShortcutType)return!1;const t=s?s.map:null,o=s?s.flag:0,r=e/this.nodeFieldCount,a=i/this.nodeFieldCount,d=!t||t[r]&o;if((!t||t[a]&o)&&!d)return!1}return!0}initEssentialEdges(){const e=s.TypedArrayUtilities.createBitVector(this.#X),{nodes:t,nodeFieldCount:n,edgeFieldsCount:i}=this,o=this.userObjectsMapAndFlag(),r=t.length,a=this.createNode(0);for(let t=0;t{const t=e-1;C[t]=s[t];let i=e;for(;0!==i;){0===y[i]&&(y[i]=++T,m[T]=x[i]=i);let e=f[i];const t=i-1;for(;C[t]0===I[e]?e:((e=>{let t=0;for(;0!==I[I[e]];)b[++t]=e,e=I[e];for(;t>0;){const e=b[t--];y[x[I[e]]]{I[t]=e},v=h+1;T=0;const D=new Uint32Array(p);if(O(v),T=2;--e){const t=m[e],s=t-1;let n=!0;for(let e=o[s];e1;e--){const t=m[e]-1;R[z[t]]+=R[t]}return{dominatorsTree:z,retainedSizes:R}}static buildDominatedNodes(e){const{nodeCount:t,dominatorsTree:s,rootNodeOrdinal:n,nodeFieldCount:i}=e,o=new Uint32Array(t+1),r=new Uint32Array(t-1);let a=0,d=t;if(n===a)a=1;else{if(n!==d-1)throw new Error("Root node is expected to be either first or last");d-=1}for(let e=a;e{let t=h.get(e);return void 0===t&&(t=this.addString(e),h.set(e,t)),t},c=l("(system)"),u=l("(compiled code)"),g=l("Function"),p=l("RegExp");function f(t){switch(t.rawType()){case i:return c;case o:case n:{let n=t.rawName();if(n.startsWith("<")){const e=n.indexOf(" ");return-1!==e&&(n=n.substring(0,e)+">"),l(n)}if(n.startsWith("Detached <")){const e=n.indexOf(" ",10);return-1!==e&&(n=n.substring(0,e)+">"),l(n)}return e.getValue(t.nodeIndex+s)}case r:return u;case a:return g;case d:return p;default:return l("("+t.type()+")")}}const I=this.createNode(0);for(let e=0;e1&&o.length+i.length>120)break;1!==o.length&&(o+=", "),o+=i,r.push(n)}if(0===r.length)continue;o+="}";const a=t.get(o);a?++a.count:t.set(o,{name:o,properties:r,count:1})}const n=Array.from(t.values());n.sort(((e,t)=>t.count-e.count));const i=[],o=Math.max(2,s/1e3);for(let e=0;et.propertyCount?e:t.propertyCount>e.propertyCount?t:e.index<=t.index?e:t}this.#oe=e,this.#L={},this.#W={};const n={next:new Map,matchInfo:null,greatestNext:null};for(let t=0;t=t.greatestNext)&&a.delete(t);const n=t.next.get(e);n&&(a.add(n),d=s(d,n.matchInfo))}let h=d===i?o.rawNameIndex():this.#ie.get(d.name);void 0===h&&(h=this.addString(d.name),this.#ie.set(d.name,h)),o.setClassIndex(h)}}iterateFilteredChildren(e,t,s){const n=this.firstEdgeIndexes[e],i=this.firstEdgeIndexes[e+1];for(let e=n;e![e.edgeHiddenType,e.edgeInvisibleType,e.edgeWeakType].includes(t)),(t=>o(e,t,s)))};for(let e=0;eu.id()?(c.addedIndexes.push(r[d]),c.addedCount++,c.addedSize+=u.selfSize(),u.nodeIndex=r[++d]):(++a,u.nodeIndex=r[++d])}for(;a0}getDistanceForRetainersView(t){const s=t/this.nodeFieldCount,n=(this.#se??this.nodeDistances)[s];return n===this.#H?Math.max(0,this.nodeDistances[s])+e.HeapSnapshotModel.baseUnreachableDistance:n}isNodeIgnoredInRetainersView(e){return this.#ee.has(e)}isEdgeIgnoredInRetainersView(e){return this.#te.has(e)}}class b{iterator;#ae;#de;iterationOrder;currentComparator;#he;#le;constructor(e,t){this.iterator=e,this.#ae=t,this.#de=!e.hasNext(),this.iterationOrder=null,this.currentComparator=null,this.#he=0,this.#le=0}createIterationOrder(){if(!this.iterationOrder){this.iterationOrder=[];for(let e=this.iterator;e.hasNext();e.next())this.iterationOrder.push(e.item().itemIndex())}}isEmpty(){return this.#de}serializeItemsRange(t,s){if(this.createIterationOrder(),t>s)throw new Error("Start position > end position: "+t+" > "+s);if(!this.iterationOrder)throw new Error("Iteration order undefined");if(s>this.iterationOrder.length&&(s=this.iterationOrder.length),this.#he=this.iterationOrder.length-this.#le&&(this.#le=this.iterationOrder.length-t)}let n=t;const i=s-t,o=new Array(i);for(let e=0;ec.name()?1:0:l.hasStringName()?-1:1}else i=l.getValueForSorting(e)-c.getValueForSorting(e);return t?i:-i}function f(e,t,s,n){l.edgeIndex=s,u.nodeIndex=l.nodeIndex();const i=u[e]();c.edgeIndex=n,g.nodeIndex=c.nodeIndex();const o=g[e](),r=io?1:0;return t?r:-r}if(!this.iterationOrder)throw new Error("Iteration order not defined");function I(e){return e.startsWith("!edge")}I(r)?I(a)?s.ArrayUtilities.sortRange(this.iterationOrder,(function(e,t){let s=p(r,d,e,t);return 0===s&&(s=p(a,h,e,t)),0===s?e-t:s}),t,n,i,o):s.ArrayUtilities.sortRange(this.iterationOrder,(function(e,t){let s=p(r,d,e,t);return 0===s&&(s=f(a,h,e,t)),0===s?e-t:s}),t,n,i,o):I(a)?s.ArrayUtilities.sortRange(this.iterationOrder,(function(e,t){let s=f(r,d,e,t);return 0===s&&(s=p(a,h,e,t)),0===s?e-t:s}),t,n,i,o):s.ArrayUtilities.sortRange(this.iterationOrder,(function(e,t){let s=f(r,d,e,t);return 0===s&&(s=f(a,h,e,t)),0===s?e-t:s}),t,n,i,o)}}class A extends b{snapshot;constructor(e,t){const s=new l(e);super(new x(s,t),s),this.snapshot=e}nodePosition(e){this.createIterationOrder();const t=this.snapshot.createNode();let s=0;if(!this.iterationOrder)throw new Error("Iteration order not defined");for(;so?n:0}return function(e,d){t.nodeIndex=e,s.nodeIndex=d;let h=a(n,o);return 0===h&&(h=a(i,r)),h||e-d}}sort(e,t,n,i,o){if(!this.iterationOrder)throw new Error("Iteration order not defined");s.ArrayUtilities.sortRange(this.iterationOrder,this.buildCompareFunction(e),t,n,i,o)}}class v extends E{nodeFlags;flags;#ce;constructor(e,t){super(e,t),this.nodeFlags={canBeQueried:1,detachedDOMTreeNode:2,pageObject:4}}createNode(e){return new D(this,void 0===e?-1:e)}createEdge(e){return new z(this,e)}createRetainingEdge(e){return new R(this,e)}containmentEdgesFilter(){return e=>!e.isInvisible()}retainingEdgesFilter(){const e=this.containmentEdgesFilter();return function(t){return e(t)&&!t.node().isRoot()&&!t.isWeak()}}calculateFlags(){this.flags=new Uint8Array(this.nodeCount),this.markDetachedDOMTreeNodes(),this.markQueriableHeapObjects(),this.markPageOwnedNodes()}#ue(){for(let e=this.rootNode().edges();e.hasNext();e.next())if(this.isUserRoot(e.edge.node()))return!0;return!1}calculateShallowSizes(){if(!this.#ue())return;const{nodeCount:e,nodes:t,nodeFieldCount:s,nodeSelfSizeOffset:n}=this,i=4294967295,o=4294967294;if(e>=o)throw new Error("Too many nodes for calculateShallowSizes");const r=new Uint32Array(e),a=[],d=this.createNode(0);for(let t=0;t1&&i.length+o.length+e.length>100)break;d?(a-=t,o.length>1&&(o=", "+o),o=e+o):(r+=t,i.length>1&&(i+=", "),i+=e),d=!d}return r<=a&&(i+=", ..."),o.length>1&&(i+=", "),i+o}static formatPropertyName(e){return/[,'"{}]/.test(e)&&(e=(e=JSON.stringify({[e]:0})).substring(1,e.length-3)),e}id(){const e=this.snapshot;return e.nodes.getValue(this.nodeIndex+e.nodeIdOffset)}isHidden(){return this.rawType()===this.snapshot.nodeHiddenType}isArray(){return this.rawType()===this.snapshot.nodeArrayType}isSynthetic(){return this.rawType()===this.snapshot.nodeSyntheticType}isNative(){return this.rawType()===this.snapshot.nodeNativeType}isUserRoot(){return!this.isSynthetic()}isDocumentDOMTreesRoot(){return this.isSynthetic()&&"(Document DOM trees)"===this.rawName()}serialize(){const e=super.serialize(),t=this.snapshot,s=t.flagsOfNode(this);return s&t.nodeFlags.canBeQueried&&(e.canBeQueried=!0),s&t.nodeFlags.detachedDOMTreeNode&&(e.detachedDOMTreeNode=!0),e}}class z extends h{constructor(e,t){super(e,t)}clone(){const e=this.snapshot;return new z(e,this.edgeIndex)}hasStringName(){return this.isShortcut()?isNaN(parseInt(this.nameInternal(),10)):this.hasStringNameInternal()}isElement(){return this.rawType()===this.snapshot.edgeElementType}isHidden(){return this.rawType()===this.snapshot.edgeHiddenType}isWeak(){return this.rawType()===this.snapshot.edgeWeakType}isInternal(){return this.rawType()===this.snapshot.edgeInternalType}isInvisible(){return this.rawType()===this.snapshot.edgeInvisibleType}isShortcut(){return this.rawType()===this.snapshot.edgeShortcutType}name(){const e=this.nameInternal();if(!this.isShortcut())return String(e);const t=parseInt(e,10);return String(isNaN(t)?e:t)}toString(){const e=this.name();switch(this.type()){case"context":return"->"+e;case"element":return"["+e+"]";case"weak":return"[["+e+"]]";case"property":return-1===e.indexOf(" ")?"."+e:'["'+e+'"]';case"shortcut":return"string"==typeof e?-1===e.indexOf(" ")?"."+e:'["'+e+'"]':"["+e+"]";case"internal":case"hidden":case"invisible":return"{"+e+"}"}return"?"+e+"?"}hasStringNameInternal(){const e=this.rawType(),t=this.snapshot;return e!==t.edgeElementType&&e!==t.edgeHiddenType}nameInternal(){return this.hasStringNameInternal()?this.snapshot.strings[this.nameOrIndex()]:this.nameOrIndex()}nameOrIndex(){return this.edges.getValue(this.edgeIndex+this.snapshot.edgeNameOffset)}rawType(){return this.edges.getValue(this.edgeIndex+this.snapshot.edgeTypeOffset)}nameIndex(){if(!this.hasStringNameInternal())throw new Error("Edge does not have string name");return this.nameOrIndex()}}class R extends p{constructor(e,t){super(e,t)}clone(){const e=this.snapshot;return new R(e,this.retainerIndex())}isHidden(){return this.edge().isHidden()}isInvisible(){return this.edge().isInvisible()}isShortcut(){return this.edge().isShortcut()}isWeak(){return this.edge().isWeak()}}var _=Object.freeze({__proto__:null,HeapSnapshot:E,HeapSnapshotEdge:h,HeapSnapshotEdgeIndexProvider:c,HeapSnapshotEdgeIterator:g,HeapSnapshotEdgesProvider:F,HeapSnapshotFilteredIterator:y,HeapSnapshotIndexRangeIterator:x,HeapSnapshotItemProvider:b,HeapSnapshotNode:I,HeapSnapshotNodeIndexProvider:l,HeapSnapshotNodeIterator:m,HeapSnapshotNodesProvider:A,HeapSnapshotProgress:N,HeapSnapshotRetainerEdge:p,HeapSnapshotRetainerEdgeIndexProvider:u,HeapSnapshotRetainerEdgeIterator:f,JSHeapSnapshot:v,JSHeapSnapshotEdge:z,JSHeapSnapshotNode:D,JSHeapSnapshotRetainerEdge:R,SecondaryInitManager:T,createJSHeapSnapshotForTesting:async function(e){const t=new v(e,new N),s=new MessageChannel;return new T(s.port2),await t.initialize(s.port1),t}});class k{#P;#pe;#fe;#Ie;#me;#xe;#ye;#Ne="";parsingComplete;constructor(e){this.#Se(),this.#P=new N(e),this.#pe=[],this.#fe=null,this.#Ie=!1,this.parsingComplete=this.#we()}dispose(){this.#Se()}#Se(){this.#Ne="",this.#me=void 0}close(){this.#Ie=!0,this.#fe&&this.#fe("")}async buildSnapshot(e){this.#me=this.#me||{},this.#P.updateStatus("Processing snapshot…");const t=new v(this.#me,this.#P);return await t.initialize(e),this.#Se(),t}#Te(){let e=0;const t="0".charCodeAt(0),s="9".charCodeAt(0),n="]".charCodeAt(0),i=this.#Ne.length;for(;;){for(;en||n>s)break;o*=10,o+=n-t,++e}if(e===i)return this.#Ne=this.#Ne.slice(r),!0;if(!this.#xe)throw new Error("Array not instantiated");this.#xe.setValue(this.#ye++,o)}}#Ce(){this.#P.updateStatus("Parsing strings…");const e=this.#Ne.lastIndexOf("]");if(-1===e)throw new Error("Incomplete JSON");if(this.#Ne=this.#Ne.slice(0,e+1),!this.#me)throw new Error("No snapshot in parseStringsArray");this.#me.strings=JSON.parse(this.#Ne)}write(e){this.#pe.push(e),this.#fe&&(this.#fe(this.#pe.shift()),this.#fe=null)}#Oe(){if(this.#pe.length>0)return Promise.resolve(this.#pe.shift());const{promise:e,resolve:t}=Promise.withResolvers();return this.#fe=t,e}async#Ee(e,t){for(;;){const s=this.#Ne.indexOf(e,t||0);if(-1!==s)return s;t=this.#Ne.length-e.length+1,this.#Ne+=await this.#Oe()}}async#be(e,t,n){const i=await this.#Ee(e),o=await this.#Ee("[",i);for(this.#Ne=this.#Ne.slice(o+1),this.#xe=void 0===n?s.TypedArrayUtilities.createExpandableBigUint32Array():s.TypedArrayUtilities.createFixedBigUint32Array(n),this.#ye=0;this.#Te();)n?this.#P.updateProgress(t,this.#ye,this.#xe.length):this.#P.updateStatus(t),this.#Ne+=await this.#Oe();const r=this.#xe;return this.#xe=null,r}async#we(){const e='"snapshot"',t=await this.#Ee(e);if(-1===t)throw new Error("Snapshot token not found");this.#P.updateStatus("Loading snapshot info…");const s=this.#Ne.slice(t+10+1);let i=!1;const o=new n.TextUtils.BalancedJSONTokenizer((e=>{this.#Ne=o.remainder(),i=!0,this.#me=this.#me||{},this.#me.snapshot=JSON.parse(e)}));for(o.write(s);!i;)o.write(await this.#Oe());this.#me=this.#me||{};const r=await this.#be('"nodes"',"Loading nodes… {PH1}%",this.#me.snapshot.meta.node_fields.length*this.#me.snapshot.node_count);this.#me.nodes=r;const a=await this.#be('"edges"',"Loading edges… {PH1}%",this.#me.snapshot.meta.edge_fields.length*this.#me.snapshot.edge_count);if(this.#me.edges=a,this.#me.snapshot.trace_function_count){const e=await this.#be('"trace_function_infos"',"Loading allocation traces… {PH1}%",this.#me.snapshot.meta.trace_function_info_fields.length*this.#me.snapshot.trace_function_count);this.#me.trace_function_infos=e.asUint32ArrayOrFail();const t=await this.#Ee(":"),s=await this.#Ee('"',t),n=this.#Ne.indexOf("["),i=this.#Ne.lastIndexOf("]",s);this.#me.trace_tree=JSON.parse(this.#Ne.substring(n,i+1)),this.#Ne=this.#Ne.slice(i+1)}if(this.#me.snapshot.meta.sample_fields){const e=await this.#be('"samples"',"Loading samples…");this.#me.samples=e.asArrayOrFail()}if(this.#me.snapshot.meta.location_fields){const e=await this.#be('"locations"',"Loading locations…");this.#me.locations=e.asArrayOrFail()}else this.#me.locations=[];this.#P.updateStatus("Loading strings…");const d=await this.#Ee('"strings"'),h=await this.#Ee("[",d);for(this.#Ne=this.#Ne.slice(h);this.#pe.length>0||!this.#Ie;)this.#Ne+=await this.#Oe();this.#Ce()}}var V=Object.freeze({__proto__:null,HeapSnapshotLoader:k});var j=Object.freeze({__proto__:null,HeapSnapshotWorkerDispatcher:class{#Fe;#Ae;constructor(e){this.#Fe=[],this.#Ae=e}sendEvent(e,t){this.#Ae({eventName:e,data:t})}async dispatchMessage({data:t,ports:s}){const n={callId:t.callId,result:null,error:void 0,errorCallStack:void 0,errorMethodName:void 0};try{switch(t.disposition){case"createLoader":this.#Fe[t.objectId]=new k(this);break;case"dispose":delete this.#Fe[t.objectId];break;case"getter":{const e=this.#Fe[t.objectId][t.methodName];n.result=e;break}case"factory":{const e=this.#Fe[t.objectId],i=t.methodArguments.slice();i.push(...s);const o=await e[t.methodName].apply(e,i);o&&(this.#Fe[t.newObjectId]=o),n.result=Boolean(o);break}case"method":{const e=this.#Fe[t.objectId];n.result=e[t.methodName].apply(e,t.methodArguments);break}case"evaluateForTest":try{globalThis.HeapSnapshotWorker={AllocationProfile:d,HeapSnapshot:_,HeapSnapshotLoader:V},globalThis.HeapSnapshotModel=e,n.result=await self.eval(t.source)}catch(e){n.result=e.toString()}break;case"setupForSecondaryInit":this.#Fe[t.objectId]=new T(s[0])}}catch(e){n.error=e.toString(),n.errorCallStack=e.stack,t.methodName&&(n.errorMethodName=t.methodName)}this.#Ae(n)}}});export{d as AllocationProfile,_ as HeapSnapshot,V as HeapSnapshotLoader,j as HeapSnapshotWorkerDispatcher}; +import*as e from"../../models/heap_snapshot_model/heap_snapshot_model.js";import*as t from"../../core/i18n/i18n.js";import*as s from"../../core/platform/platform.js";import*as n from"../../models/text_utils/text_utils.js";class i{#e;#t;#s;#n;#i;#o;#r;constructor(e,t){this.#e=e.strings,this.#t=1,this.#s=[],this.#n={},this.#i={},this.#o={},this.#r=null,this.#a(e),this.#d(e,t)}#a(e){const t=this.#e,s=e.snapshot.meta.trace_function_info_fields,n=s.indexOf("name"),i=s.indexOf("script_name"),o=s.indexOf("script_id"),r=s.indexOf("line"),d=s.indexOf("column"),h=s.length,l=e.trace_function_infos,c=l.length,u=this.#s=new Array(c/h);let g=0;for(let e=0;e0}}class a{functionName;scriptName;scriptId;line;column;totalCount;totalSize;totalLiveCount;totalLiveSize;#r;#g;constructor(e,t,s,n,i){this.functionName=e,this.scriptName=t,this.scriptId=s,this.line=n,this.column=i,this.totalCount=0,this.totalSize=0,this.totalLiveCount=0,this.totalLiveSize=0,this.#r=[]}addTraceTopNode(e){0!==e.allocationCount&&(this.#r.push(e),this.totalCount+=e.allocationCount,this.totalSize+=e.allocationSize,this.totalLiveCount+=e.liveCount,this.totalLiveSize+=e.liveSize)}bottomUpRoot(){return this.#r.length?(this.#g||this.#p(),this.#g):null}#p(){this.#g=new r(this);for(let e=0;e>>O}classKeyInternal(){if(this.rawType()!==this.snapshot.nodeObjectType)return this.classIndex();const e=this.snapshot.getLocation(this.nodeIndex);return e?`${e.scriptId},${e.lineNumber},${e.columnNumber},${this.className()}`:this.classIndex()}setClassIndex(e){let t=this.#E();if(t&=C,t|=e<100||e.push(t)}function w(e,t){t.postMessage({problemReport:e})}class T{argsStep1;argsStep2;argsStep3;constructor(e){const{promise:t,resolve:s}=Promise.withResolvers();this.argsStep1=t;const{promise:n,resolve:i}=Promise.withResolvers();this.argsStep2=n;const{promise:o,resolve:r}=Promise.withResolvers();this.argsStep3=o,e.onmessage=e=>{const t=e.data;switch(t.step){case 1:s(t.args);break;case 2:i(t.args);break;case 3:r(t.args)}},this.initialize(e)}async getNodeSelfSizes(){return(await this.argsStep3).nodeSelfSizes}async initialize(e){try{const t=await this.argsStep1,n=E.buildRetainers(t),i=await this.argsStep2,o={...i,...t,...n,essentialEdges:s.TypedArrayUtilities.createBitVector(i.essentialEdgesBuffer),port:e,nodeSelfSizesPromise:this.getNodeSelfSizes()},r=await E.calculateDominatorsAndRetainedSizes(o),a=E.buildDominatedNodes({...o,...r}),d={...n,...r,...a};e.postMessage({resultsFromSecondWorker:d},{transfer:[d.dominatorsTree.buffer,d.firstRetainerIndex.buffer,d.retainedSizes.buffer,d.retainingEdges.buffer,d.retainingNodes.buffer,d.dominatedNodes.buffer,d.firstDominatedNodeIndex.buffer]})}catch(t){e.postMessage({error:t+"\n"+t?.stack})}}}const C=3,O=2;class E{nodes;containmentEdges;#k;#V;#j=null;strings;#M;#P;#H=-5;rootNodeIndexInternal=0;#U={};#B;#L={};#W={};profile;nodeTypeOffset;nodeNameOffset;nodeIdOffset;nodeSelfSizeOffset;#J;nodeTraceNodeIdOffset;nodeFieldCount;nodeTypes;nodeArrayType;nodeHiddenType;nodeObjectType;nodeNativeType;nodeStringType;nodeConsStringType;nodeSlicedStringType;nodeCodeType;nodeSyntheticType;nodeClosureType;nodeRegExpType;edgeFieldsCount;edgeTypeOffset;edgeNameOffset;edgeToNodeOffset;edgeTypes;edgeElementType;edgeHiddenType;edgeInternalType;edgeShortcutType;edgeWeakType;edgeInvisibleType;edgePropertyType;#K;#$;#Q;#q;#G;nodeCount;#X;retainedSizes;firstEdgeIndexes;retainingNodes;retainingEdges;firstRetainerIndex;nodeDistances;firstDominatedNodeIndex;dominatedNodes;dominatorsTree;#Y;nodeDetachednessAndClassIndexOffset;#Z;#ee=new Set;#te=new Set;#se;#ne;detachednessAndClassIndexArray;#ie=new Map;#oe;constructor(e,t){this.nodes=e.nodes,this.containmentEdges=e.edges,this.#k=e.snapshot.meta,this.#V=e.samples,this.strings=e.strings,this.#M=e.locations,this.#P=t,e.snapshot.root_index&&(this.rootNodeIndexInternal=e.snapshot.root_index),this.profile=e,this.#ne=s.TypedArrayUtilities.createBitVector(this.strings.length)}async initialize(e){const t=this.#k;this.nodeTypeOffset=t.node_fields.indexOf("type"),this.nodeNameOffset=t.node_fields.indexOf("name"),this.nodeIdOffset=t.node_fields.indexOf("id"),this.nodeSelfSizeOffset=t.node_fields.indexOf("self_size"),this.#J=t.node_fields.indexOf("edge_count"),this.nodeTraceNodeIdOffset=t.node_fields.indexOf("trace_node_id"),this.nodeDetachednessAndClassIndexOffset=t.node_fields.indexOf("detachedness"),this.nodeFieldCount=t.node_fields.length,this.nodeTypes=t.node_types[this.nodeTypeOffset],this.nodeArrayType=this.nodeTypes.indexOf("array"),this.nodeHiddenType=this.nodeTypes.indexOf("hidden"),this.nodeObjectType=this.nodeTypes.indexOf("object"),this.nodeNativeType=this.nodeTypes.indexOf("native"),this.nodeStringType=this.nodeTypes.indexOf("string"),this.nodeConsStringType=this.nodeTypes.indexOf("concatenated string"),this.nodeSlicedStringType=this.nodeTypes.indexOf("sliced string"),this.nodeCodeType=this.nodeTypes.indexOf("code"),this.nodeSyntheticType=this.nodeTypes.indexOf("synthetic"),this.nodeClosureType=this.nodeTypes.indexOf("closure"),this.nodeRegExpType=this.nodeTypes.indexOf("regexp"),this.edgeFieldsCount=t.edge_fields.length,this.edgeTypeOffset=t.edge_fields.indexOf("type"),this.edgeNameOffset=t.edge_fields.indexOf("name_or_index"),this.edgeToNodeOffset=t.edge_fields.indexOf("to_node"),this.edgeTypes=t.edge_types[this.edgeTypeOffset],this.edgeTypes.push("invisible"),this.edgeElementType=this.edgeTypes.indexOf("element"),this.edgeHiddenType=this.edgeTypes.indexOf("hidden"),this.edgeInternalType=this.edgeTypes.indexOf("internal"),this.edgeShortcutType=this.edgeTypes.indexOf("shortcut"),this.edgeWeakType=this.edgeTypes.indexOf("weak"),this.edgeInvisibleType=this.edgeTypes.indexOf("invisible"),this.edgePropertyType=this.edgeTypes.indexOf("property");const s=t.location_fields||[];this.#K=s.indexOf("object_index"),this.#$=s.indexOf("script_id"),this.#Q=s.indexOf("line"),this.#q=s.indexOf("column"),this.#G=s.length,this.nodeCount=this.nodes.length/this.nodeFieldCount,this.#X=this.containmentEdges.length/this.edgeFieldsCount,this.#P.updateStatus("Building edge indexes…"),this.firstEdgeIndexes=new Uint32Array(this.nodeCount+1),this.buildEdgeIndexes(),this.#P.updateStatus("Building retainers…");const n=this.startInitStep1InSecondThread(e);if(this.#P.updateStatus("Propagating DOM state…"),this.propagateDOMState(),this.#P.updateStatus("Calculating node flags…"),this.calculateFlags(),this.#P.updateStatus("Building dominated nodes…"),this.startInitStep2InSecondThread(e),this.#P.updateStatus("Calculating shallow sizes…"),this.calculateShallowSizes(),this.#P.updateStatus("Calculating retained sizes…"),this.startInitStep3InSecondThread(e),this.#P.updateStatus("Calculating distances…"),this.nodeDistances=new Int32Array(this.nodeCount),this.calculateDistances(!1),this.#P.updateStatus("Calculating object names…"),this.calculateObjectNames(),this.applyInterfaceDefinitions(this.inferInterfaceDefinitions()),this.#P.updateStatus("Calculating samples…"),this.buildSamples(),this.#P.updateStatus("Building locations…"),this.buildLocationMap(),this.#P.updateStatus("Calculating retained sizes…"),await this.installResultsFromSecondThread(n),this.#P.updateStatus("Calculating statistics…"),this.calculateStatistics(),this.profile.snapshot.trace_function_count){this.#P.updateStatus("Building allocation statistics…");const e=this.nodes.length,t=this.nodeFieldCount,s=this.rootNode(),n={};for(let i=0;i{e.onmessage=e=>{const n=e.data;if(n?.problemReport){const e=n.problemReport;console.warn(function(e,t){const s=e.rootNode();return t.map((e=>"string"==typeof e?e:(s.nodeIndex=e,`${s.name()} @${s.id()}`))).join("\n ")}(this,e))}else if(n?.resultsFromSecondWorker){const e=n.resultsFromSecondWorker;t(e)}else n?.error&&s(n.error)}})),s=this.#X,{containmentEdges:n,edgeToNodeOffset:i,edgeFieldsCount:o,nodeFieldCount:r}=this,a=new Uint32Array(s);for(let e=0;ee&&n<=t}}createAllocationStackFilter(e){if(!this.#Y)throw new Error("No Allocation Profile provided");const t=this.#Y.traceIds(e);if(!t.length)return;const s={};for(let e=0;e{const s=e.nodeIndex/this.nodeFieldCount;return t.getBit(s)},i=e=>{const s=new Int32Array(this.nodeCount);for(let e=0;e{for(let e=0;e2!==t.node().detachedness())),o(),e=>!n(e);case"objectsRetainedByConsole":return i(((e,t)=>!(e.isSynthetic()&&t.hasStringName()&&t.name().endsWith(" / DevTools console")))),o(),e=>!n(e);case"duplicatedStrings":{const e=new Map,s=this.createNode(0);for(let n=0;n!this.#ee.has(s.nodeIndex())&&(!e||e(t,s)),void 0===this.#se&&(this.#se=new Int32Array(n))}const i=t?this.#se:this.nodeDistances,o=this.#H;for(let e=0;e0?e.HeapSnapshotModel.baseSystemDistance:0,r[0]=this.rootNode().nodeIndex,a=1,this.bfs(r,a,i,s)}bfs(e,t,s,n){const i=this.edgeFieldsCount,o=this.nodeFieldCount,r=this.containmentEdges,a=this.firstEdgeIndexes,d=this.edgeToNodeOffset,h=this.edgeTypeOffset,l=this.nodeCount,c=this.edgeWeakType,u=this.#H;let g=0;const p=this.createEdge(0),f=this.createNode(0);for(;gl)throw new Error("BFS failed. Nodes to visit ("+t+") is more than nodes count ("+l+")")}buildAggregates(e){const t=new Map,s=this.nodes,n=s.length,i=this.nodeFieldCount,o=this.nodeSelfSizeOffset,r=this.rootNode(),a=this.nodeDistances;for(let d=0;d(t.nodeIndex=e,s.nodeIndex=n,t.id() \/ part of key \(.*? @\d+\) -> value \(.*? @\d+\) pair in WeakMap \(table @(?\d+)\))$/);if(t)return t.groups;this.#ne.setBit(e)}computeIsEssentialEdge(e,t,s){const n=this.containmentEdges.getValue(t+this.edgeTypeOffset);if(n===this.edgeInternalType){const s=this.containmentEdges.getValue(t+this.edgeNameOffset),n=this.tryParseWeakMapEdgeName(s);if(n){if(this.nodes.getValue(e+this.nodeIdOffset)===parseInt(n.tableId,10))return!1}}if(n===this.edgeWeakType)return!1;const i=this.containmentEdges.getValue(t+this.edgeToNodeOffset);if(e===i)return!1;if(e!==this.rootNodeIndex){if(n===this.edgeShortcutType)return!1;const t=s?s.map:null,o=s?s.flag:0,r=e/this.nodeFieldCount,a=i/this.nodeFieldCount,d=!t||t[r]&o;if((!t||t[a]&o)&&!d)return!1}return!0}initEssentialEdges(){const e=s.TypedArrayUtilities.createBitVector(this.#X),{nodes:t,nodeFieldCount:n,edgeFieldsCount:i}=this,o=this.userObjectsMapAndFlag(),r=t.length,a=this.createNode(0);for(let t=0;t{const t=e-1;C[t]=s[t];let i=e;for(;0!==i;){0===y[i]&&(y[i]=++T,m[T]=x[i]=i);let e=f[i];const t=i-1;for(;C[t]0===I[e]?e:((e=>{let t=0;for(;0!==I[I[e]];)b[++t]=e,e=I[e];for(;t>0;){const e=b[t--];y[x[I[e]]]{I[t]=e},v=h+1;T=0;const D=new Uint32Array(p);if(O(v),T=2;--e){const t=m[e],s=t-1;let n=!0;for(let e=o[s];e1;e--){const t=m[e]-1;R[z[t]]+=R[t]}return{dominatorsTree:z,retainedSizes:R}}static buildDominatedNodes(e){const{nodeCount:t,dominatorsTree:s,rootNodeOrdinal:n,nodeFieldCount:i}=e,o=new Uint32Array(t+1),r=new Uint32Array(t-1);let a=0,d=t;if(n===a)a=1;else{if(n!==d-1)throw new Error("Root node is expected to be either first or last");d-=1}for(let e=a;e{let t=h.get(e);return void 0===t&&(t=this.addString(e),h.set(e,t)),t},c=l("(system)"),u=l("(compiled code)"),g=l("Function"),p=l("RegExp");function f(t){switch(t.rawType()){case i:return c;case o:case n:{let n=t.rawName();if(n.startsWith("<")){const e=n.indexOf(" ");return-1!==e&&(n=n.substring(0,e)+">"),l(n)}if(n.startsWith("Detached <")){const e=n.indexOf(" ",10);return-1!==e&&(n=n.substring(0,e)+">"),l(n)}return e.getValue(t.nodeIndex+s)}case r:return u;case a:return g;case d:return p;default:return l("("+t.type()+")")}}const I=this.createNode(0);for(let e=0;e1&&o.length+i.length>120)break;1!==o.length&&(o+=", "),o+=i,r.push(n)}if(0===r.length)continue;o+="}";const a=t.get(o);a?++a.count:t.set(o,{name:o,properties:r,count:1})}const n=Array.from(t.values());n.sort(((e,t)=>t.count-e.count));const i=[],o=Math.max(2,s/1e3);for(let e=0;et.propertyCount?e:t.propertyCount>e.propertyCount?t:e.index<=t.index?e:t}this.#oe=e,this.#L={},this.#W={};const n={next:new Map,matchInfo:null,greatestNext:null};for(let t=0;t=t.greatestNext)&&a.delete(t);const n=t.next.get(e);n&&(a.add(n),d=s(d,n.matchInfo))}let h=d===i?o.rawNameIndex():this.#ie.get(d.name);void 0===h&&(h=this.addString(d.name),this.#ie.set(d.name,h)),o.setClassIndex(h)}}iterateFilteredChildren(e,t,s){const n=this.firstEdgeIndexes[e],i=this.firstEdgeIndexes[e+1];for(let e=n;e![e.edgeHiddenType,e.edgeInvisibleType,e.edgeWeakType].includes(t)),(t=>o(e,t,s)))};for(let e=0;eu.id()?(c.addedIndexes.push(r[d]),c.addedCount++,c.addedSize+=u.selfSize(),u.nodeIndex=r[++d]):(++a,u.nodeIndex=r[++d])}for(;a0}getDistanceForRetainersView(t){const s=t/this.nodeFieldCount,n=(this.#se??this.nodeDistances)[s];return n===this.#H?Math.max(0,this.nodeDistances[s])+e.HeapSnapshotModel.baseUnreachableDistance:n}isNodeIgnoredInRetainersView(e){return this.#ee.has(e)}isEdgeIgnoredInRetainersView(e){return this.#te.has(e)}}class b{iterator;#ae;#de;iterationOrder;currentComparator;#he;#le;constructor(e,t){this.iterator=e,this.#ae=t,this.#de=!e.hasNext(),this.iterationOrder=null,this.currentComparator=null,this.#he=0,this.#le=0}createIterationOrder(){if(!this.iterationOrder){this.iterationOrder=[];for(let e=this.iterator;e.hasNext();e.next())this.iterationOrder.push(e.item().itemIndex())}}isEmpty(){return this.#de}serializeItemsRange(t,s){if(this.createIterationOrder(),t>s)throw new Error("Start position > end position: "+t+" > "+s);if(!this.iterationOrder)throw new Error("Iteration order undefined");if(s>this.iterationOrder.length&&(s=this.iterationOrder.length),this.#he=this.iterationOrder.length-this.#le&&(this.#le=this.iterationOrder.length-t)}let n=t;const i=s-t,o=new Array(i);for(let e=0;ec.name()?1:0:l.hasStringName()?-1:1}else i=l.getValueForSorting(e)-c.getValueForSorting(e);return t?i:-i}function f(e,t,s,n){l.edgeIndex=s,u.nodeIndex=l.nodeIndex();const i=u[e]();c.edgeIndex=n,g.nodeIndex=c.nodeIndex();const o=g[e](),r=io?1:0;return t?r:-r}if(!this.iterationOrder)throw new Error("Iteration order not defined");function I(e){return e.startsWith("!edge")}I(r)?I(a)?s.ArrayUtilities.sortRange(this.iterationOrder,(function(e,t){let s=p(r,d,e,t);return 0===s&&(s=p(a,h,e,t)),0===s?e-t:s}),t,n,i,o):s.ArrayUtilities.sortRange(this.iterationOrder,(function(e,t){let s=p(r,d,e,t);return 0===s&&(s=f(a,h,e,t)),0===s?e-t:s}),t,n,i,o):I(a)?s.ArrayUtilities.sortRange(this.iterationOrder,(function(e,t){let s=f(r,d,e,t);return 0===s&&(s=p(a,h,e,t)),0===s?e-t:s}),t,n,i,o):s.ArrayUtilities.sortRange(this.iterationOrder,(function(e,t){let s=f(r,d,e,t);return 0===s&&(s=f(a,h,e,t)),0===s?e-t:s}),t,n,i,o)}}class A extends b{snapshot;constructor(e,t){const s=new l(e);super(new x(s,t),s),this.snapshot=e}nodePosition(e){this.createIterationOrder();const t=this.snapshot.createNode();let s=0;if(!this.iterationOrder)throw new Error("Iteration order not defined");for(;so?n:0}return function(e,d){t.nodeIndex=e,s.nodeIndex=d;let h=a(n,o);return 0===h&&(h=a(i,r)),h||e-d}}sort(e,t,n,i,o){if(!this.iterationOrder)throw new Error("Iteration order not defined");s.ArrayUtilities.sortRange(this.iterationOrder,this.buildCompareFunction(e),t,n,i,o)}}class v extends E{nodeFlags;flags;#ce;constructor(e,t){super(e,t),this.nodeFlags={canBeQueried:1,detachedDOMTreeNode:2,pageObject:4}}createNode(e){return new D(this,void 0===e?-1:e)}createEdge(e){return new z(this,e)}createRetainingEdge(e){return new R(this,e)}containmentEdgesFilter(){return e=>!e.isInvisible()}retainingEdgesFilter(){const e=this.containmentEdgesFilter();return function(t){return e(t)&&!t.node().isRoot()&&!t.isWeak()}}calculateFlags(){this.flags=new Uint8Array(this.nodeCount),this.markDetachedDOMTreeNodes(),this.markQueriableHeapObjects(),this.markPageOwnedNodes()}#ue(){for(let e=this.rootNode().edges();e.hasNext();e.next())if(this.isUserRoot(e.edge.node()))return!0;return!1}calculateShallowSizes(){if(!this.#ue())return;const{nodeCount:e,nodes:t,nodeFieldCount:s,nodeSelfSizeOffset:n}=this,i=4294967295,o=4294967294;if(e>=o)throw new Error("Too many nodes for calculateShallowSizes");const r=new Uint32Array(e),a=[],d=this.createNode(0);for(let t=0;t1&&i.length+o.length+e.length>100)break;d?(a-=t,o.length>1&&(o=", "+o),o=e+o):(r+=t,i.length>1&&(i+=", "),i+=e),d=!d}return r<=a&&(i+=", ..."),o.length>1&&(i+=", "),i+o}static formatPropertyName(e){return/[,'"{}]/.test(e)&&(e=(e=JSON.stringify({[e]:0})).substring(1,e.length-3)),e}id(){const e=this.snapshot;return e.nodes.getValue(this.nodeIndex+e.nodeIdOffset)}isHidden(){return this.rawType()===this.snapshot.nodeHiddenType}isArray(){return this.rawType()===this.snapshot.nodeArrayType}isSynthetic(){return this.rawType()===this.snapshot.nodeSyntheticType}isNative(){return this.rawType()===this.snapshot.nodeNativeType}isUserRoot(){return!this.isSynthetic()}isDocumentDOMTreesRoot(){return this.isSynthetic()&&"(Document DOM trees)"===this.rawName()}serialize(){const e=super.serialize(),t=this.snapshot,s=t.flagsOfNode(this);return s&t.nodeFlags.canBeQueried&&(e.canBeQueried=!0),s&t.nodeFlags.detachedDOMTreeNode&&(e.detachedDOMTreeNode=!0),e}}class z extends h{constructor(e,t){super(e,t)}clone(){const e=this.snapshot;return new z(e,this.edgeIndex)}hasStringName(){return this.isShortcut()?isNaN(parseInt(this.nameInternal(),10)):this.hasStringNameInternal()}isElement(){return this.rawType()===this.snapshot.edgeElementType}isHidden(){return this.rawType()===this.snapshot.edgeHiddenType}isWeak(){return this.rawType()===this.snapshot.edgeWeakType}isInternal(){return this.rawType()===this.snapshot.edgeInternalType}isInvisible(){return this.rawType()===this.snapshot.edgeInvisibleType}isShortcut(){return this.rawType()===this.snapshot.edgeShortcutType}name(){const e=this.nameInternal();if(!this.isShortcut())return String(e);const t=parseInt(e,10);return String(isNaN(t)?e:t)}toString(){const e=this.name();switch(this.type()){case"context":return"->"+e;case"element":return"["+e+"]";case"weak":return"[["+e+"]]";case"property":return-1===e.indexOf(" ")?"."+e:'["'+e+'"]';case"shortcut":return"string"==typeof e?-1===e.indexOf(" ")?"."+e:'["'+e+'"]':"["+e+"]";case"internal":case"hidden":case"invisible":return"{"+e+"}"}return"?"+e+"?"}hasStringNameInternal(){const e=this.rawType(),t=this.snapshot;return e!==t.edgeElementType&&e!==t.edgeHiddenType}nameInternal(){return this.hasStringNameInternal()?this.snapshot.strings[this.nameOrIndex()]:this.nameOrIndex()}nameOrIndex(){return this.edges.getValue(this.edgeIndex+this.snapshot.edgeNameOffset)}rawType(){return this.edges.getValue(this.edgeIndex+this.snapshot.edgeTypeOffset)}nameIndex(){if(!this.hasStringNameInternal())throw new Error("Edge does not have string name");return this.nameOrIndex()}}class R extends p{constructor(e,t){super(e,t)}clone(){const e=this.snapshot;return new R(e,this.retainerIndex())}isHidden(){return this.edge().isHidden()}isInvisible(){return this.edge().isInvisible()}isShortcut(){return this.edge().isShortcut()}isWeak(){return this.edge().isWeak()}}var _=Object.freeze({__proto__:null,HeapSnapshot:E,HeapSnapshotEdge:h,HeapSnapshotEdgeIndexProvider:c,HeapSnapshotEdgeIterator:g,HeapSnapshotEdgesProvider:F,HeapSnapshotFilteredIterator:y,HeapSnapshotIndexRangeIterator:x,HeapSnapshotItemProvider:b,HeapSnapshotNode:I,HeapSnapshotNodeIndexProvider:l,HeapSnapshotNodeIterator:m,HeapSnapshotNodesProvider:A,HeapSnapshotProgress:N,HeapSnapshotRetainerEdge:p,HeapSnapshotRetainerEdgeIndexProvider:u,HeapSnapshotRetainerEdgeIterator:f,JSHeapSnapshot:v,JSHeapSnapshotEdge:z,JSHeapSnapshotNode:D,JSHeapSnapshotRetainerEdge:R,SecondaryInitManager:T,createJSHeapSnapshotForTesting:async function(e){const t=new v(e,new N),s=new MessageChannel;return new T(s.port2),await t.initialize(s.port1),t}});class k{#P;#pe;#fe;#Ie;#me;#xe;#ye;#Ne="";parsingComplete;constructor(e){this.#Se(),this.#P=new N(e),this.#pe=[],this.#fe=null,this.#Ie=!1,this.parsingComplete=this.#we()}dispose(){this.#Se()}#Se(){this.#Ne="",this.#me=void 0}close(){this.#Ie=!0,this.#fe&&this.#fe("")}async buildSnapshot(e){await this.parsingComplete,this.#me=this.#me||{},this.#P.updateStatus("Processing snapshot…");const t=new v(this.#me,this.#P);return await t.initialize(e),this.#Se(),t}#Te(){let e=0;const t="0".charCodeAt(0),s="9".charCodeAt(0),n="]".charCodeAt(0),i=this.#Ne.length;for(;;){for(;en||n>s)break;o*=10,o+=n-t,++e}if(e===i)return this.#Ne=this.#Ne.slice(r),!0;if(!this.#xe)throw new Error("Array not instantiated");this.#xe.setValue(this.#ye++,o)}}#Ce(){this.#P.updateStatus("Parsing strings…");const e=this.#Ne.lastIndexOf("]");if(-1===e)throw new Error("Incomplete JSON");if(this.#Ne=this.#Ne.slice(0,e+1),!this.#me)throw new Error("No snapshot in parseStringsArray");this.#me.strings=JSON.parse(this.#Ne)}write(e){this.#pe.push(e),this.#fe&&(this.#fe(this.#pe.shift()),this.#fe=null)}#Oe(){if(this.#pe.length>0)return Promise.resolve(this.#pe.shift());const{promise:e,resolve:t}=Promise.withResolvers();return this.#fe=t,e}async#Ee(e,t){for(;;){const s=this.#Ne.indexOf(e,t||0);if(-1!==s)return s;t=this.#Ne.length-e.length+1,this.#Ne+=await this.#Oe()}}async#be(e,t,n){const i=await this.#Ee(e),o=await this.#Ee("[",i);for(this.#Ne=this.#Ne.slice(o+1),this.#xe=void 0===n?s.TypedArrayUtilities.createExpandableBigUint32Array():s.TypedArrayUtilities.createFixedBigUint32Array(n),this.#ye=0;this.#Te();)n?this.#P.updateProgress(t,this.#ye,this.#xe.length):this.#P.updateStatus(t),this.#Ne+=await this.#Oe();const r=this.#xe;return this.#xe=null,r}async#we(){const e='"snapshot"',t=await this.#Ee(e);if(-1===t)throw new Error("Snapshot token not found");this.#P.updateStatus("Loading snapshot info…");const s=this.#Ne.slice(t+10+1);let i=!1;const o=new n.TextUtils.BalancedJSONTokenizer((e=>{this.#Ne=o.remainder(),i=!0,this.#me=this.#me||{},this.#me.snapshot=JSON.parse(e)}));for(o.write(s);!i;)o.write(await this.#Oe());this.#me=this.#me||{};const r=await this.#be('"nodes"',"Loading nodes… {PH1}%",this.#me.snapshot.meta.node_fields.length*this.#me.snapshot.node_count);this.#me.nodes=r;const a=await this.#be('"edges"',"Loading edges… {PH1}%",this.#me.snapshot.meta.edge_fields.length*this.#me.snapshot.edge_count);if(this.#me.edges=a,this.#me.snapshot.trace_function_count){const e=await this.#be('"trace_function_infos"',"Loading allocation traces… {PH1}%",this.#me.snapshot.meta.trace_function_info_fields.length*this.#me.snapshot.trace_function_count);this.#me.trace_function_infos=e.asUint32ArrayOrFail();const t=await this.#Ee(":"),s=await this.#Ee('"',t),n=this.#Ne.indexOf("["),i=this.#Ne.lastIndexOf("]",s);this.#me.trace_tree=JSON.parse(this.#Ne.substring(n,i+1)),this.#Ne=this.#Ne.slice(i+1)}if(this.#me.snapshot.meta.sample_fields){const e=await this.#be('"samples"',"Loading samples…");this.#me.samples=e.asArrayOrFail()}if(this.#me.snapshot.meta.location_fields){const e=await this.#be('"locations"',"Loading locations…");this.#me.locations=e.asArrayOrFail()}else this.#me.locations=[];this.#P.updateStatus("Loading strings…");const d=await this.#Ee('"strings"'),h=await this.#Ee("[",d);for(this.#Ne=this.#Ne.slice(h);this.#pe.length>0||!this.#Ie;)this.#Ne+=await this.#Oe();this.#Ce()}}var V=Object.freeze({__proto__:null,HeapSnapshotLoader:k});var j=Object.freeze({__proto__:null,HeapSnapshotWorkerDispatcher:class{#Fe;#Ae;constructor(e){this.#Fe=[],this.#Ae=e}sendEvent(e,t){this.#Ae({eventName:e,data:t})}async dispatchMessage({data:t,ports:s}){const n={callId:t.callId,result:null,error:void 0,errorCallStack:void 0,errorMethodName:void 0};try{switch(t.disposition){case"createLoader":this.#Fe[t.objectId]=new k(this);break;case"dispose":delete this.#Fe[t.objectId];break;case"getter":{const e=this.#Fe[t.objectId][t.methodName];n.result=e;break}case"factory":{const e=this.#Fe[t.objectId],i=t.methodArguments.slice();i.push(...s);const o=await e[t.methodName].apply(e,i);o&&(this.#Fe[t.newObjectId]=o),n.result=Boolean(o);break}case"method":{const e=this.#Fe[t.objectId];n.result=e[t.methodName].apply(e,t.methodArguments);break}case"evaluateForTest":try{globalThis.HeapSnapshotWorker={AllocationProfile:d,HeapSnapshot:_,HeapSnapshotLoader:V},globalThis.HeapSnapshotModel=e,n.result=await self.eval(t.source)}catch(e){n.result=e.toString()}break;case"setupForSecondaryInit":this.#Fe[t.objectId]=new T(s[0])}}catch(e){n.error=e.toString(),n.errorCallStack=e.stack,t.methodName&&(n.errorMethodName=t.methodName)}this.#Ae(n)}}});export{d as AllocationProfile,_ as HeapSnapshot,V as HeapSnapshotLoader,j as HeapSnapshotWorkerDispatcher}; diff --git a/packages/debugger-frontend/dist/third-party/front_end/panels/network/network.js b/packages/debugger-frontend/dist/third-party/front_end/panels/network/network.js index 0b1f235f45c596..01d8630927e58a 100644 --- a/packages/debugger-frontend/dist/third-party/front_end/panels/network/network.js +++ b/packages/debugger-frontend/dist/third-party/front_end/panels/network/network.js @@ -1 +1 @@ -import*as e from"../../ui/legacy/legacy.js";import*as t from"../../core/common/common.js";import*as i from"../../core/host/host.js";import*as r from"../../core/i18n/i18n.js";import*as o from"../../ui/legacy/components/source_frame/source_frame.js";import*as s from"../../core/platform/platform.js";import*as n from"../../core/sdk/sdk.js";import*as a from"../../models/logs/logs.js";import*as l from"../../ui/components/buttons/buttons.js";import*as d from"../../ui/visual_logging/visual_logging.js";import*as c from"../../ui/legacy/components/data_grid/data_grid.js";import*as h from"../mobile_throttling/mobile_throttling.js";import*as u from"../settings/emulation/components/components.js";import*as p from"../../models/bindings/bindings.js";import*as g from"../../models/workspace/workspace.js";import*as m from"./forward/forward.js";import*as w from"../../ui/components/floating_button/floating_button.js";import*as k from"../../ui/components/icon_button/icon_button.js";import*as v from"../../ui/legacy/components/perf_ui/perf_ui.js";import*as b from"../../ui/legacy/components/utils/utils.js";import{PanelUtils as f}from"../utils/utils.js";import*as C from"../../core/root/root.js";import*as S from"../../ui/components/legacy_wrapper/legacy_wrapper.js";import*as y from"./components/components.js";import*as T from"../../ui/legacy/components/cookie_table/cookie_table.js";import*as x from"../../ui/legacy/components/object_ui/object_ui.js";import*as R from"../../models/text_utils/text_utils.js";import*as I from"../../models/har/har.js";import*as q from"../../models/persistence/persistence.js";import*as L from"../sources/sources.js";import*as F from"../../ui/components/adorners/adorners.js";import*as E from"../../ui/components/render_coordinator/render_coordinator.js";import*as H from"../../ui/legacy/theme_support/theme_support.js";import*as P from"../../models/trace/trace.js";import*as M from"../search/search.js";var A={cssText:`.panel.network devtools-toolbar.binary-view-toolbar{border-top:1px solid var(--sys-color-divider);border-bottom:0;padding-left:5px}.binary-view-copied-text{opacity:100%}.binary-view-copied-text.fadeout{opacity:0%;transition:opacity 1s}\n/*# sourceURL=${import.meta.resolve("./binaryResourceView.css")} */\n`};const N={copiedAsBase:"Copied as `Base64`",hexViewer:"`Hex` Viewer",copiedAsHex:"Copied as `Hex`",copiedAsUtf:"Copied as `UTF-8`",binaryViewType:"Binary view type",copyToClipboard:"Copy to clipboard",copyAsBase:"Copy as `Base64`",copyAsHex:"Copy as `Hex`",copyAsUtf:"Copy as `UTF-8`"},U=r.i18n.registerUIStrings("panels/network/BinaryResourceView.ts",N),B=r.i18n.getLocalizedString.bind(void 0,U);class V extends e.Widget.VBox{binaryResourceViewFactory;toolbar;binaryViewObjects;binaryViewTypeSetting;binaryViewTypeCombobox;copiedText;addFadeoutSettimeoutId;lastView;constructor(i,s,n){super(),this.registerRequiredCSS(A),this.binaryResourceViewFactory=new o.BinaryResourceViewFactory.BinaryResourceViewFactory(i,s,n),this.toolbar=this.element.createChild("devtools-toolbar","binary-view-toolbar"),this.binaryViewObjects=[new W("base64",r.i18n.lockedString("Base64"),B(N.copiedAsBase),this.binaryResourceViewFactory.createBase64View.bind(this.binaryResourceViewFactory),this.binaryResourceViewFactory.base64.bind(this.binaryResourceViewFactory)),new W("hex",B(N.hexViewer),B(N.copiedAsHex),this.binaryResourceViewFactory.createHexView.bind(this.binaryResourceViewFactory),this.binaryResourceViewFactory.hex.bind(this.binaryResourceViewFactory)),new W("utf8",r.i18n.lockedString("UTF-8"),B(N.copiedAsUtf),this.binaryResourceViewFactory.createUtf8View.bind(this.binaryResourceViewFactory),this.binaryResourceViewFactory.utf8.bind(this.binaryResourceViewFactory))],this.binaryViewTypeSetting=t.Settings.Settings.instance().createSetting("binary-view-type","hex"),this.binaryViewTypeCombobox=new e.Toolbar.ToolbarComboBox(this.binaryViewTypeChanged.bind(this),B(N.binaryViewType));for(const e of this.binaryViewObjects)this.binaryViewTypeCombobox.addOption(this.binaryViewTypeCombobox.createOption(e.label,e.type));this.toolbar.appendToolbarItem(this.binaryViewTypeCombobox);const a=new e.Toolbar.ToolbarButton(B(N.copyToClipboard),"copy");a.addEventListener("Click",(e=>{this.copySelectedViewToClipboard()}),this),this.toolbar.appendToolbarItem(a),this.copiedText=new e.Toolbar.ToolbarText,this.copiedText.element.classList.add("binary-view-copied-text"),this.toolbar.appendChild(this.copiedText.element),this.addFadeoutSettimeoutId=null,this.lastView=null,this.updateView()}getCurrentViewObject(){const e=this.binaryViewObjects.find((e=>e.type===this.binaryViewTypeSetting.get()));return console.assert(Boolean(e),`No binary view found for binary view type found in setting 'binary-view-type': ${this.binaryViewTypeSetting.get()}`),e||null}copySelectedViewToClipboard(){const e=this.getCurrentViewObject();e&&(i.InspectorFrontendHost.InspectorFrontendHostInstance.copyText(e.content()),this.copiedText.setText(e.copiedMessage),this.copiedText.element.classList.remove("fadeout"),this.addFadeoutSettimeoutId&&(clearTimeout(this.addFadeoutSettimeoutId),this.addFadeoutSettimeoutId=null),this.addFadeoutSettimeoutId=window.setTimeout(function(){this.copiedText.element.classList.add("fadeout")}.bind(this),2e3))}updateView(){const e=this.getCurrentViewObject();if(!e)return;const t=e.getView();t!==this.lastView&&(this.lastView&&this.lastView.detach(),this.lastView=t,t.show(this.element,this.toolbar),this.binaryViewTypeCombobox.element.value=this.binaryViewTypeSetting.get())}binaryViewTypeChanged(){const e=this.binaryViewTypeCombobox.selectedOption();if(!e)return;const t=e.value;this.binaryViewTypeSetting.get()!==t&&(this.binaryViewTypeSetting.set(t),this.updateView())}addCopyToContextMenu(e,t){const r=e.clipboardSection().appendSubMenuItem(t,!1,"copy").footerSection();r.appendItem(B(N.copyAsBase),(async()=>{const e=this.binaryResourceViewFactory.base64();i.InspectorFrontendHost.InspectorFrontendHostInstance.copyText(e)}),{jslogContext:"copy-as-base"}),r.appendItem(B(N.copyAsHex),(async()=>{const e=await this.binaryResourceViewFactory.hex();i.InspectorFrontendHost.InspectorFrontendHostInstance.copyText(e)}),{jslogContext:"copy-as-hex"}),r.appendItem(B(N.copyAsUtf),(async()=>{const e=await this.binaryResourceViewFactory.utf8();i.InspectorFrontendHost.InspectorFrontendHostInstance.copyText(e)}),{jslogContext:"copy-as-utf"})}}class W{type;label;copiedMessage;content;createViewFn;view;constructor(e,t,i,r,o){this.type=e,this.label=t,this.copiedMessage=i,this.content=o,this.createViewFn=r,this.view=null}getView(){return this.view||(this.view=this.createViewFn()),this.view}}var O=Object.freeze({__proto__:null,BinaryResourceView:V,BinaryViewObject:W}),D={cssText:`.list{border:none!important;border-top:1px solid var(--sys-color-divider)!important;display:flex;height:100%}.blocking-disabled{opacity:80%}.editor-container{padding:0 4px}.blocked-urls{overflow:hidden auto}.no-blocked-urls > span{white-space:pre}.blocked-url{display:flex;flex-direction:row;align-items:center;flex:auto}.blocked-url-count{flex:none;padding-right:9px}.blocked-url-checkbox{margin-left:8px;flex:none}.blocked-url-checkbox:focus{outline:auto 5px -webkit-focus-ring-color}.blocked-url-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;flex:auto;padding:0 3px}.blocked-url-edit-row{flex:none;display:flex;flex-direction:row;margin:7px 5px 0;align-items:center}.blocked-url-edit-value{user-select:none;flex:1 1 0}.blocked-url-edit-row input{width:100%;text-align:inherit;height:22px}\n/*# sourceURL=${import.meta.resolve("./blockedURLsPane.css")} */\n`};const G={enableNetworkRequestBlocking:"Enable network request blocking",addPattern:"Add pattern",addNetworkRequestBlockingPattern:"Add network request blocking pattern",noNetworkRequestsBlocked:"No blocked network requests",addPatternToBlock:'Add a pattern to block network requests by clicking on the "{PH1}" button.',dBlocked:"{PH1} blocked",textPatternToBlockMatching:"Text pattern to block matching requests; use * for wildcard",patternInputCannotBeEmpty:"Pattern input cannot be empty.",patternAlreadyExists:"Pattern already exists.",itemDeleted:"Item successfully deleted",learnMore:"Learn more"},j=r.i18n.registerUIStrings("panels/network/BlockedURLsPane.ts",G),z=r.i18n.getLocalizedString.bind(void 0,j);class _ extends e.Widget.VBox{manager;toolbar;enabledCheckbox;list;editor;blockedCountForUrl;constructor(){super(!0),this.registerRequiredCSS(D),this.element.setAttribute("jslog",`${d.panel("network.blocked-urls").track({resize:!0})}`),this.manager=n.NetworkManager.MultitargetNetworkManager.instance(),this.manager.addEventListener("BlockedPatternsChanged",this.update,this),this.toolbar=this.contentElement.createChild("devtools-toolbar"),this.enabledCheckbox=new e.Toolbar.ToolbarCheckbox(z(G.enableNetworkRequestBlocking),void 0,this.toggleEnabled.bind(this),"network.enable-request-blocking"),this.toolbar.appendToolbarItem(this.enabledCheckbox),this.toolbar.appendSeparator(),this.toolbar.appendToolbarItem(e.Toolbar.Toolbar.createActionButton("network.add-network-request-blocking-pattern")),this.toolbar.appendToolbarItem(e.Toolbar.Toolbar.createActionButton("network.remove-all-network-request-blocking-patterns")),this.toolbar.setAttribute("jslog",`${d.toolbar()}`),this.list=new e.ListWidget.ListWidget(this),this.list.registerRequiredCSS(D),this.list.element.classList.add("blocked-urls"),this.list.setEmptyPlaceholder(this.createEmptyPlaceholder()),this.list.show(this.contentElement),this.editor=null,this.blockedCountForUrl=new Map,n.TargetManager.TargetManager.instance().addModelListener(n.NetworkManager.NetworkManager,n.NetworkManager.Events.RequestFinished,this.onRequestFinished,this,{scoped:!0}),this.update(),a.NetworkLog.NetworkLog.instance().addEventListener(a.NetworkLog.Events.Reset,this.onNetworkLogReset,this)}createEmptyPlaceholder(){const t=this.contentElement.createChild("div","empty-state");t.createChild("span","empty-state-header").textContent=z(G.noNetworkRequestsBlocked);const i=t.createChild("div","empty-state-description");i.createChild("span").textContent=z(G.addPatternToBlock,{PH1:z(G.addPattern)});const r=e.XLink.XLink.create("https://developer.chrome.com/docs/devtools/network-request-blocking",z(G.learnMore),void 0,void 0,"learn-more");i.appendChild(r);const o=e.UIUtils.createTextButton(z(G.addPattern),this.addPattern.bind(this),{className:"add-button",jslogContext:"network.add-network-request-blocking-pattern",variant:"tonal"});return e.ARIAUtils.setLabel(o,z(G.addNetworkRequestBlockingPattern)),t.appendChild(o),t}addPattern(){this.manager.setBlockingEnabled(!0),this.list.addNewItem(0,{url:s.DevToolsPath.EmptyUrlString,enabled:!0})}removeAllPatterns(){this.manager.setBlockedPatterns([])}renderItem(e,t){const i=this.blockedRequestsCount(e.url),r=document.createElement("div");r.classList.add("blocked-url");const o=r.createChild("input","blocked-url-checkbox");return o.type="checkbox",o.checked=e.enabled,o.disabled=!t,o.setAttribute("jslog",`${d.toggle().track({change:!0})}`),r.createChild("div","blocked-url-label").textContent=e.url,r.createChild("div","blocked-url-count").textContent=z(G.dBlocked,{PH1:i}),t&&(r.addEventListener("click",(t=>this.togglePattern(e,t))),o.addEventListener("click",(t=>this.togglePattern(e,t)))),r}togglePattern(e,t){t.consume(!0);const i=this.manager.blockedPatterns();i.splice(i.indexOf(e),1,{enabled:!e.enabled,url:e.url}),this.manager.setBlockedPatterns(i)}toggleEnabled(){this.manager.setBlockingEnabled(!this.manager.blockingEnabled()),this.update()}removeItemRequested(t,i){const r=this.manager.blockedPatterns();r.splice(i,1),this.manager.setBlockedPatterns(r),e.ARIAUtils.alert(G.itemDeleted)}beginEdit(e){return this.editor=this.createEditor(),this.editor.control("url").value=e.url,this.editor}commitEdit(e,t,i){const r=t.control("url").value,o=this.manager.blockedPatterns();i?o.push({enabled:!0,url:r}):o.splice(o.indexOf(e),1,{enabled:!0,url:r}),this.manager.setBlockedPatterns(o)}createEditor(){if(this.editor)return this.editor;const t=new e.ListWidget.Editor,i=t.contentElement();i.createChild("div","blocked-url-edit-row").createChild("div").textContent=z(G.textPatternToBlockMatching);const r=i.createChild("div","blocked-url-edit-row"),o=t.createInput("url","text","",((e,t,i)=>{let r,o=!0;return i.value?this.manager.blockedPatterns().find((e=>e.url===i.value))&&(r=z(G.patternAlreadyExists),o=!1):(r=z(G.patternInputCannotBeEmpty),o=!1),{valid:o,errorMessage:r}}));return r.createChild("div","blocked-url-edit-value").appendChild(o),t}update(){const e=this.manager.blockingEnabled();this.list.element.classList.toggle("blocking-disabled",!e&&Boolean(this.manager.blockedPatterns().length)),this.enabledCheckbox.setChecked(e),this.list.clear();for(const t of this.manager.blockedPatterns())this.list.appendItem(t,e)}blockedRequestsCount(e){if(!e)return 0;let t=0;for(const i of this.blockedCountForUrl.keys())this.matches(e,i)&&(t+=this.blockedCountForUrl.get(i));return t}matches(e,t){let i=0;const r=e.split("*");for(let e=0;ethis.dataGrid.insertChild(new Z(e))))}}class Z extends c.SortableDataGrid.SortableDataGridNode{message;constructor(t){const i=new Date(1e3*t.time),r=("0"+i.getHours()).substr(-2)+":"+("0"+i.getMinutes()).substr(-2)+":"+("0"+i.getSeconds()).substr(-2)+"."+("00"+i.getMilliseconds()).substr(-3),o=document.createElement("div");e.UIUtils.createTextChild(o,r),e.Tooltip.Tooltip.install(o,i.toLocaleString()),super({id:t.eventId,type:t.eventName,data:t.data,time:o}),this.message=t}}function ee(e,t,i){const r=e(t.message),o=e(i.message);return ro?1:0}const te={id:ee.bind(null,(e=>e.eventId)),type:ee.bind(null,(e=>e.eventName)),time:ee.bind(null,(e=>e.time))},ie=new WeakMap;var re=Object.freeze({__proto__:null,Comparators:te,EventSourceMessageNode:Z,EventSourceMessagesView:Q}),oe={cssText:`.network-config{padding:12px;display:block}.network-config-group{display:flex;padding-bottom:10px;flex-wrap:wrap;flex:0 0 auto;min-height:30px}.network-config-title{margin-right:16px;width:130px}.network-config-fields{flex:2 0 200px}.network-config-fields span:first-of-type,\n.network-config-fields .network-config-accepted-encoding-custom{padding:3px 0}.panel-section-separator{height:1px;margin-bottom:10px;background:var(--sys-color-divider)}.network-config-disable-cache{line-height:28px;border-top:none;padding-top:0}.network-config-input-validation-error{color:var(--sys-color-error);margin:5px 0}.network-config-input-validation-error:empty{display:none}.network-config-throttling select{width:100%;max-width:250px}.network-config-throttling > .network-config-title{line-height:24px}.network-config-ua > .network-config-title{line-height:20px}.network-config-ua input{display:block;width:calc(100% - 20px)}.network-config-ua input[type="text"],\n.network-config-ua select{margin-top:8px}.network-config-ua select{width:calc(100% - 20px);max-width:250px}.network-config-ua-custom{padding-bottom:8px;input,\n devtools-user-agent-client-hints-form{opacity:38%;pointer-events:none}&.checked input,\n &.checked devtools-user-agent-client-hints-form{opacity:revert;pointer-events:revert}}devtools-user-agent-client-hints-form{display:block;margin-top:14px;width:min(100%,400px)}.status-text{padding:10px;color:var(--sys-color-tertiary)}\n/*# sourceURL=${import.meta.resolve("./networkConfigView.css")} */\n`};const se={custom:"Custom...",enterACustomUserAgent:"Enter a custom user agent",customUserAgentFieldIsRequired:"Custom user agent field is required",caching:"Caching",disableCache:"Disable cache",networkThrottling:"Network throttling",userAgent:"User agent",selectAutomatically:"Use browser default",acceptedEncoding:"Accepted `Content-Encoding`s",clientHintsStatusText:"User agent updated.",networkConditionsPanelShown:"Network conditions shown"},ne=r.i18n.registerUIStrings("panels/network/NetworkConfigView.ts",se),ae=r.i18n.getLocalizedString.bind(void 0,ne);let le;class de extends e.Widget.VBox{constructor(){super(!0),this.registerRequiredCSS(oe),this.element.setAttribute("jslog",`${d.panel("network-conditions").track({resize:!0})}`),this.contentElement.classList.add("network-config"),this.createCacheSection(),this.contentElement.createChild("div").classList.add("panel-section-separator"),this.createNetworkThrottlingSection(),this.contentElement.createChild("div").classList.add("panel-section-separator"),this.createUserAgentSection(),this.contentElement.createChild("div").classList.add("panel-section-separator"),this.createAcceptedEncodingSection()}static instance(e={forceNew:null}){const{forceNew:t}=e;return le&&!t||(le=new de),le}static createUserAgentSelectAndInput(i){const r=t.Settings.Settings.instance().createSetting("custom-user-agent",""),o=t.Settings.Settings.instance().createSetting("custom-user-agent-metadata",null),a=document.createElement("select");a.setAttribute("jslog",`${d.dropDown().track({change:!0}).context(r.name)}`),e.ARIAUtils.setLabel(a,i);const l={title:ae(se.custom),value:"custom"};a.appendChild(e.UIUtils.createOption(l.title,l.value,"custom"));for(const t of he){const i=a.createChild("optgroup");i.label=t.title;for(const r of t.values){const t=n.NetworkManager.MultitargetNetworkManager.patchUserAgentWithChromeVersion(r.value);i.appendChild(e.UIUtils.createOption(r.title,t,s.StringUtilities.toKebabCase(r.title)))}}a.selectedIndex=0;const c=e.UIUtils.createInput("","text");c.setAttribute("jslog",`${d.textField().track({change:!0}).context(r.name)}`),c.value=r.get(),e.Tooltip.Tooltip.install(c,r.get()),c.placeholder=ae(se.enterACustomUserAgent),c.required=!0,e.ARIAUtils.setLabel(c,c.placeholder);const h=document.createElement("div");function u(){const e=r.get(),t=a.options;let i=!1;for(let r=0;r{if(l.checked)return;const e=r.get(),t=ce(e);n.NetworkManager.MultitargetNetworkManager.instance().setCustomUserAgentOverride(e,t)}));const d=s.createChild("div","network-config-ua-custom");l.addEventListener("change",w);const c=de.createUserAgentSelectAndInput(o);d.appendChild(c.select),d.appendChild(c.input),d.appendChild(c.error);const h=new u.UserAgentClientHintsForm.UserAgentClientHintsForm,p=i.get(),g=ce(c.select.value);h.value={showMobileCheckbox:!0,showSubmitButton:!0,metaData:p||g||void 0},d.appendChild(h),c.select.addEventListener("user-agent-change",(e=>{const t=e.detail.value,i=t?ce(t):null;h.value={metaData:i||void 0,showMobileCheckbox:!0,showSubmitButton:!0},m.textContent=""})),h.addEventListener("clienthintschange",(()=>{c.select.value="custom",m.textContent=""})),h.addEventListener("clienthintssubmit",(e=>{const t=e.detail.value,o=r.get();i.set(t),n.NetworkManager.MultitargetNetworkManager.instance().setCustomUserAgentOverride(o,t),m.textContent=ae(se.clientHintsStatusText)}));const m=s.createChild("span","status-text");function w(){const e=!l.checked;d.classList.toggle("checked",e),c.select.disabled=!e,c.input.disabled=!e,c.error.hidden=!e,h.disabled=!e;const t=e?r.get():"",i=e?ce(t):null;n.NetworkManager.MultitargetNetworkManager.instance().setCustomUserAgentOverride(t,i)}m.textContent="",w()}createAcceptedEncodingSection(){const i=t.Settings.Settings.instance().createSetting("use-custom-accepted-encodings",!1),r=t.Settings.Settings.instance().createSetting("custom-accepted-encodings","gzip,br,deflate"),o=ae(se.acceptedEncoding),s=this.createSection(o,"network-config-accepted-encoding"),a=e.UIUtils.CheckboxLabel.create(ae(se.selectAutomatically),!0,void 0,i.name);s.appendChild(a);const l=a.checkboxElement;function c(){i.get()?n.NetworkManager.MultitargetNetworkManager.instance().setCustomAcceptedEncodingsOverride(""===r.get()?[]:r.get().split(",")):n.NetworkManager.MultitargetNetworkManager.instance().clearCustomAcceptedEncodingsOverride()}r.addChangeListener(c),i.addChangeListener(c);const h=s.createChild("div","network-config-accepted-encoding-custom");h.setAttribute("jslog",`${d.section().context(r.name)}`),l.checked=!i.get(),l.addEventListener("change",g);const u=new Map,p={Deflate:"deflate",Gzip:"gzip",Br:"br",Zstd:"zstd"};for(const t of Object.values(p)){const i=e.UIUtils.CheckboxLabel.createWithStringLiteral(t,!0,void 0,t);h.appendChild(i),u.set(t,i.checkboxElement)}for(const[e,t]of u)t.checked=r.get().includes(e),t.addEventListener("change",g);function g(){i.set(!l.checked);const e=[];for(const[t,i]of u)i.disabled=l.checked,i.checked&&e.push(t);r.set(e.join(","))}g()}wasShown(){super.wasShown(),e.ARIAUtils.alert(ae(se.networkConditionsPanelShown))}}function ce(e){for(const t of he)for(const i of t.values)if(e===n.NetworkManager.MultitargetNetworkManager.patchUserAgentWithChromeVersion(i.value))return i.metadata?(n.NetworkManager.MultitargetNetworkManager.patchUserAgentMetadataWithChromeVersion(i.metadata),i.metadata):null;return null}const he=[{title:"Android",values:[{title:"Android (4.0.2) Browser — Galaxy Nexus",value:"Mozilla/5.0 (Linux; U; Android 4.0.2; en-us; Galaxy Nexus Build/ICL53F) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Google Chrome",version:"%s"}],fullVersion:"%s",platform:"Android",platformVersion:"4.0.2",architecture:"",model:"Galaxy Nexus",mobile:!0}},{title:"Android (2.3) Browser — Nexus S",value:"Mozilla/5.0 (Linux; U; Android 2.3.6; en-us; Nexus S Build/GRK39F) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Google Chrome",version:"%s"}],fullVersion:"%s",platform:"Android",platformVersion:"2.3.6",architecture:"",model:"Nexus S",mobile:!0}}]},{title:"BlackBerry",values:[{title:"BlackBerry — BB10",value:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.1+ (KHTML, like Gecko) Version/10.0.0.1337 Mobile Safari/537.1+",metadata:null},{title:"BlackBerry — PlayBook 2.1",value:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML, like Gecko) Version/7.2.1.0 Safari/536.2+",metadata:null},{title:"BlackBerry — 9900",value:"Mozilla/5.0 (BlackBerry; U; BlackBerry 9900; en-US) AppleWebKit/534.11+ (KHTML, like Gecko) Version/7.0.0.187 Mobile Safari/534.11+",metadata:null}]},{title:"Chrome",values:[{title:"Chrome — Android Mobile",value:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Mobile Safari/537.36",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Google Chrome",version:"%s"}],fullVersion:"%s",platform:"Android",platformVersion:"6.0",architecture:"",model:"Nexus 5",mobile:!0}},{title:"Chrome — Android Mobile (high-end)",value:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Mobile Safari/537.36",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Google Chrome",version:"%s"}],fullVersion:"%s",platform:"Android",platformVersion:"10",architecture:"",model:"Pixel 4",mobile:!0}},{title:"Chrome — Android Tablet",value:"Mozilla/5.0 (Linux; Android 4.3; Nexus 7 Build/JSS15Q) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Google Chrome",version:"%s"}],fullVersion:"%s",platform:"Android",platformVersion:"4.3",architecture:"",model:"Nexus 7",mobile:!0}},{title:"Chrome — iPhone",value:"Mozilla/5.0 (iPhone; CPU iPhone OS 13_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) CriOS/%s Mobile/15E148 Safari/604.1",metadata:null},{title:"Chrome — iPad",value:"Mozilla/5.0 (iPad; CPU OS 13_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) CriOS/%s Mobile/15E148 Safari/604.1",metadata:null},{title:"Chrome — Chrome OS",value:"Mozilla/5.0 (X11; CrOS x86_64 10066.0.0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Google Chrome",version:"%s"}],fullVersion:"%s",platform:"Chrome OS",platformVersion:"10066.0.0",architecture:"x86",model:"",mobile:!1}},{title:"Chrome — Mac",value:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Google Chrome",version:"%s"}],fullVersion:"%s",platform:"macOS",platformVersion:"10_14_6",architecture:"x86",model:"",mobile:!1}},{title:"Chrome — Windows",value:"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Google Chrome",version:"%s"}],fullVersion:"%s",platform:"Windows",platformVersion:"10.0",architecture:"x86",model:"",mobile:!1}}]},{title:"Firefox",values:[{title:"Firefox — Android Mobile",value:"Mozilla/5.0 (Android 4.4; Mobile; rv:70.0) Gecko/70.0 Firefox/70.0",metadata:null},{title:"Firefox — Android Tablet",value:"Mozilla/5.0 (Android 4.4; Tablet; rv:70.0) Gecko/70.0 Firefox/70.0",metadata:null},{title:"Firefox — iPhone",value:"Mozilla/5.0 (iPhone; CPU iPhone OS 8_3 like Mac OS X) AppleWebKit/600.1.4 (KHTML, like Gecko) FxiOS/1.0 Mobile/12F69 Safari/600.1.4",metadata:null},{title:"Firefox — iPad",value:"Mozilla/5.0 (iPad; CPU iPhone OS 8_3 like Mac OS X) AppleWebKit/600.1.4 (KHTML, like Gecko) FxiOS/1.0 Mobile/12F69 Safari/600.1.4",metadata:null},{title:"Firefox — Mac",value:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10.14; rv:70.0) Gecko/20100101 Firefox/70.0",metadata:null},{title:"Firefox — Windows",value:"Mozilla/5.0 (Windows NT 10.0; WOW64; rv:70.0) Gecko/20100101 Firefox/70.0",metadata:null}]},{title:"Googlebot",values:[{title:"Googlebot",value:"Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)",metadata:null},{title:"Googlebot Desktop",value:"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; Googlebot/2.1; +http://www.google.com/bot.html) Chrome/%s Safari/537.36",metadata:null},{title:"Googlebot Smartphone",value:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 5X Build/MMB29P) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Mobile Safari/537.36 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)",metadata:null}]},{title:"Internet Explorer",values:[{title:"Internet Explorer 11",value:"Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko",metadata:null},{title:"Internet Explorer 10",value:"Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)",metadata:null},{title:"Internet Explorer 9",value:"Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0)",metadata:null},{title:"Internet Explorer 8",value:"Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.0; Trident/4.0)",metadata:null},{title:"Internet Explorer 7",value:"Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)",metadata:null}]},{title:"Microsoft Edge",values:[{title:"Microsoft Edge (Chromium) — Windows",value:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36 Edg/%s",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Microsoft Edge",version:"%s"}],fullVersion:"%s",platform:"Windows",platformVersion:"10.0",architecture:"x86",model:"",mobile:!1}},{title:"Microsoft Edge (Chromium) — Mac",value:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Chrome/%s Safari/604.1 Edg/%s",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Microsoft Edge",version:"%s"}],fullVersion:"%s",platform:"macOS",platformVersion:"10_14_6",architecture:"x86",model:"",mobile:!1}},{title:"Microsoft Edge — iPhone",value:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_3_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.1.1 EdgiOS/44.5.0.10 Mobile/15E148 Safari/604.1",metadata:null},{title:"Microsoft Edge — iPad",value:"Mozilla/5.0 (iPad; CPU OS 12_3_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0 EdgiOS/44.5.2 Mobile/15E148 Safari/605.1.15",metadata:null},{title:"Microsoft Edge — Android Mobile",value:"Mozilla/5.0 (Linux; Android 8.1.0; Pixel Build/OPM4.171019.021.D1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Mobile Safari/537.36 EdgA/42.0.0.2057",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Microsoft Edge",version:"%s"}],fullVersion:"%s",platform:"Android",platformVersion:"8.1.0",architecture:"",model:"Pixel",mobile:!0}},{title:"Microsoft Edge — Android Tablet",value:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36 EdgA/42.0.0.2057",metadata:{brands:[{brand:"Not A;Brand",version:"99"},{brand:"Chromium",version:"%s"},{brand:"Microsoft Edge",version:"%s"}],fullVersion:"%s",platform:"Android",platformVersion:"6.0.1",architecture:"",model:"Nexus 7",mobile:!0}},{title:"Microsoft Edge (EdgeHTML) — Windows",value:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36 Edge/18.19042",metadata:null},{title:"Microsoft Edge (EdgeHTML) — XBox",value:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; Xbox; Xbox One) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36 Edge/18.19041",metadata:null}]},{title:"Opera",values:[{title:"Opera — Mac",value:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36 OPR/65.0.3467.48",metadata:null},{title:"Opera — Windows",value:"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/%s Safari/537.36 OPR/65.0.3467.48",metadata:null},{title:"Opera (Presto) — Mac",value:"Opera/9.80 (Macintosh; Intel Mac OS X 10.9.1) Presto/2.12.388 Version/12.16",metadata:null},{title:"Opera (Presto) — Windows",value:"Opera/9.80 (Windows NT 6.1) Presto/2.12.388 Version/12.16",metadata:null},{title:"Opera Mobile — Android Mobile",value:"Opera/12.02 (Android 4.1; Linux; Opera Mobi/ADR-1111101157; U; en-US) Presto/2.9.201 Version/12.02",metadata:null},{title:"Opera Mini — iOS",value:"Opera/9.80 (iPhone; Opera Mini/8.0.0/34.2336; U; en) Presto/2.8.119 Version/11.10",metadata:null}]},{title:"Safari",values:[{title:"Safari — iPad iOS 13.2",value:"Mozilla/5.0 (iPad; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1",metadata:null},{title:"Safari — iPhone iOS 13.2",value:"Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1",metadata:null},{title:"Safari — Mac",value:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Safari/605.1.15",metadata:null}]},{title:"UC Browser",values:[{title:"UC Browser — Android Mobile",value:"Mozilla/5.0 (Linux; U; Android 8.1.0; en-US; Nexus 6P Build/OPM7.181205.001) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/%s UCBrowser/12.11.1.1197 Mobile Safari/537.36",metadata:null},{title:"UC Browser — iOS",value:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_1 like Mac OS X; zh-CN) AppleWebKit/537.51.1 (KHTML, like Gecko) Mobile/16B92 UCBrowser/12.1.7.1109 Mobile AliApp(TUnionSDK/0.1.20.3)",metadata:null},{title:"UC Browser — Windows Phone",value:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 920) UCBrowser/10.1.0.563 Mobile",metadata:null}]}];var ue=Object.freeze({__proto__:null,NetworkConfigView:de,userAgentGroups:he});const pe={redirect:"Redirect",sPreflight:"{PH1} + Preflight",preflight:"Preflight",selectPreflightRequest:"Select preflight request",failed:"(failed)",data:"(data)",canceled:"(canceled)",other:"other",csp:"csp",origin:"origin",integrity:"integrity",devtools:"devtools",blockeds:"(blocked:{PH1})",blockedTooltip:"This request was blocked due to misconfigured response headers, click to view the headers",corsError:"CORS error",crossoriginResourceSharingErrorS:"Cross-Origin Resource Sharing error: {PH1}",finished:"Finished",pendingq:"(pending)",unknown:"(unknown)",unknownExplanation:"The request status cannot be shown here because the page that issued it unloaded while the request was in flight. You can use chrome://net-export to capture a network log and see all request details.",push:"Push / ",parser:"Parser",script:"Script",preload:"Preload",earlyHints:"early-hints",signedexchange:"signed-exchange",selectTheRequestThatTriggered:"Select the request that triggered this preflight",otherC:"Other",memoryCache:"(memory cache)",servedFromMemoryCacheResource:"Served from memory cache, resource size: {PH1}",serviceWorker:"(`ServiceWorker`)",servedFromServiceWorkerResource:"Served from `ServiceWorker`, resource size: {PH1}",servedFromSignedHttpExchange:"Served from Signed HTTP Exchange, resource size: {PH1}",servedFromWebBundle:"Served from Web Bundle, resource size: {PH1}",prefetchCache:"(prefetch cache)",servedFromPrefetchCacheResource:"Served from prefetch cache, resource size: {PH1}",diskCache:"(disk cache)",servedFromDiskCacheResourceSizeS:"Served from disk cache, resource size: {PH1}",matchedToServiceWorkerRouter:"Matched to `ServiceWorker router`#{PH1}, resource size: {PH2}",matchedToServiceWorkerRouterWithNetworkSource:"Matched to `ServiceWorker router`#{PH1}, {PH2} transferred over network, resource size: {PH3}",pending:"Pending",level:"level 1",webBundleError:"Web Bundle error",webBundleInnerRequest:"Served from Web Bundle",webBundle:"(Web Bundle)",timeSubtitleTooltipText:"Latency (response received time - start time)",alternativeJobWonWithoutRace:"`Chrome` used a `HTTP/3` connection induced by an '`Alt-Svc`' header without racing against establishing a connection using a different `HTTP` version.",alternativeJobWonRace:"`Chrome` used a `HTTP/3` connection induced by an '`Alt-Svc`' header because it won a race against establishing a connection using a different `HTTP` version.",mainJobWonRace:"`Chrome` used this protocol because it won a race against establishing a `HTTP/3` connection.",mappingMissing:"`Chrome` did not use an alternative `HTTP` version because no alternative protocol information was available when the request was issued, but an '`Alt-Svc`' header was present in the response.",broken:"`Chrome` did not try to establish a `HTTP/3` connection because it was marked as broken.",dnsAlpnH3JobWonWithoutRace:"`Chrome` used a `HTTP/3` connection due to the `DNS record` indicating `HTTP/3` support. There was no race against establishing a connection using a different `HTTP` version.",dnsAlpnH3JobWonRace:"`Chrome` used a `HTTP/3` connection due to the `DNS record` indicating `HTTP/3` support, which won a race against establishing a connection using a different `HTTP` version.",initialPriorityToolTip:"{PH1}, Initial priority: {PH2}"},ge=r.i18n.registerUIStrings("panels/network/NetworkDataGridNode.ts",pe),me=r.i18n.getLocalizedString.bind(void 0,ge);class we extends c.SortableDataGrid.SortableDataGridNode{parentViewInternal;isHovered;showingInitiatorChainInternal;requestOrFirstKnownChildRequestInternal;constructor(e){super({}),this.parentViewInternal=e,this.isHovered=!1,this.showingInitiatorChainInternal=!1,this.requestOrFirstKnownChildRequestInternal=null}displayName(){return""}displayType(){return""}createCell(e){const t=this.createTD(e);return this.renderCell(t,e),t}renderCell(e,t){}isError(){return!1}isWarning(){return!1}backgroundColor(){const e=ke,t=document.hasFocus(),i=this.dataGrid&&this.dataGrid.element===document.activeElement,r=this.isWarning(),o=this.isError();return this.selected&&t&&i&&o?e.FocusSelectedHasError:this.selected&&t&&i&&r?e.FocusSelectedHasWarning:this.selected&&t&&i?e.FocusSelected:this.selected?e.Selected:this.hovered()?e.Hovered:this.isOnInitiatorPath()?e.InitiatorPath:this.isOnInitiatedPath()?e.InitiatedPath:this.isStriped()?e.Stripe:e.Default}updateBackgroundColor(){const e=this.existingElement();e&&(e.style.backgroundColor=`var(${this.backgroundColor()})`,this.parentViewInternal.stylesChanged())}setStriped(e){super.setStriped(e),this.updateBackgroundColor()}select(e){super.select(e),this.updateBackgroundColor(),this.parentViewInternal.updateNodeSelectedClass(!0)}deselect(e){super.deselect(e),this.updateBackgroundColor(),this.parentViewInternal.updateNodeSelectedClass(!1)}parentView(){return this.parentViewInternal}hovered(){return this.isHovered}showingInitiatorChain(){return this.showingInitiatorChainInternal}nodeSelfHeight(){return this.parentViewInternal.rowHeight()}setHovered(e,t){this.isHovered===e&&this.showingInitiatorChainInternal===t||(this.isHovered!==e&&(this.isHovered=e,this.attached()&&this.element().classList.toggle("hover",e)),this.showingInitiatorChainInternal!==t&&(this.showingInitiatorChainInternal=t,this.showingInitiatorChainChanged()),this.parentViewInternal.stylesChanged(),this.updateBackgroundColor())}showingInitiatorChainChanged(){}isOnInitiatorPath(){return!1}isOnInitiatedPath(){return!1}request(){return null}isNavigationRequest(){return!1}clearFlatNodes(){super.clearFlatNodes(),this.requestOrFirstKnownChildRequestInternal=null}requestOrFirstKnownChildRequest(){if(this.requestOrFirstKnownChildRequestInternal)return this.requestOrFirstKnownChildRequestInternal;let e=this.request();if(e||!this.hasChildren())return this.requestOrFirstKnownChildRequestInternal=e,this.requestOrFirstKnownChildRequestInternal;let t=null;const i=this.flatChildren();for(let r=0;rs?1:s>o?-1:i.identityCompare(r)}static SizeComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();return i&&r?r.cached()&&!i.cached()?1:i.cached()&&!r.cached()?-1:i.transferSize-r.transferSize||i.resourceSize-r.resourceSize||i.identityCompare(r):i?1:-1}static TypeComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();if(!i||!r)return i?1:-1;const o=e.displayType(),s=t.displayType();return o>s?1:s>o?-1:i.identityCompare(r)}static InitiatorComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();if(!i||!r)return i?1:-1;const o=e instanceof ve&&e.initiatorCell,s=t instanceof ve&&t.initiatorCell;if(!o||!s)return o?1:-1;const n=e,a=t,l=n.linkifiedInitiatorAnchor?n.linkifiedInitiatorAnchor.textContent||"":n.initiatorCell.title,d=a.linkifiedInitiatorAnchor?a.linkifiedInitiatorAnchor.textContent||"":a.initiatorCell.title;return l.localeCompare(d)}static InitiatorAddressSpaceComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();if(!i||!r)return i?1:-1;const o=i.clientSecurityState(),s=r.clientSecurityState();return o&&s?o.initiatorIPAddressSpace.localeCompare(s.initiatorIPAddressSpace):o?1:-1}static RemoteAddressSpaceComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();return i&&r?i.remoteAddressSpace().localeCompare(r.remoteAddressSpace()):i?1:-1}static RequestCookiesCountComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();if(!i||!r)return i?1:-1;return i.includedRequestCookies().length-r.includedRequestCookies().length||i.identityCompare(r)}static ResponseCookiesCountComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();if(!i||!r)return i?1:-1;return(i.responseCookies?i.responseCookies.length:0)-(r.responseCookies?r.responseCookies.length:0)||i.identityCompare(r)}static PriorityComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();if(!i||!r)return i?1:-1;const o=i.priority();let s=o?v.NetworkPriorities.networkPriorityWeight(o):0;s=s||0;const n=r.priority();let a=n?v.NetworkPriorities.networkPriorityWeight(n):0;return a=a||0,s-a||i.identityCompare(r)}static RequestPropertyComparator(e,t,i){const r=t.requestOrFirstKnownChildRequest(),o=i.requestOrFirstKnownChildRequest();if(!r||!o)return r?1:-1;const s=r[e],n=o[e];return s===n?r.identityCompare(o):s>n?1:-1}static RequestURLComparator(e,t){const i=e.requestOrFirstKnownChildRequest(),r=t.requestOrFirstKnownChildRequest();if(!i||!r)return i?1:-1;const o=i.url(),s=r.url();return o===s?i.identityCompare(r):o>s?1:-1}static ResponseHeaderStringComparator(e,t,i){const r=t.requestOrFirstKnownChildRequest(),o=i.requestOrFirstKnownChildRequest();if(!r||!o)return r?1:-1;const s=String(r.responseHeaderValue(e)||""),n=String(o.responseHeaderValue(e)||"");return s.localeCompare(n)||r.identityCompare(o)}static ResponseHeaderNumberComparator(e,t,i){const r=t.requestOrFirstKnownChildRequest(),o=i.requestOrFirstKnownChildRequest();if(!r||!o)return r?1:-1;const s=r.responseHeaderValue(e),n=void 0!==s?parseFloat(s):-1/0,a=o.responseHeaderValue(e),l=void 0!==a?parseFloat(a):-1/0;return n===l?r.identityCompare(o):n>l?1:-1}static ResponseHeaderDateComparator(e,t,i){const r=t.requestOrFirstKnownChildRequest(),o=i.requestOrFirstKnownChildRequest();if(!r||!o)return r?1:-1;const s=r.responseHeaderValue(e),n=o.responseHeaderValue(e),a=s?new Date(s).getTime():-1/0,l=n?new Date(n).getTime():-1/0;return a===l?r.identityCompare(o):a>l?1:-1}showingInitiatorChainChanged(){const e=this.showingInitiatorChain(),t=a.NetworkLog.NetworkLog.instance().initiatorGraphForRequest(this.requestInternal);for(const i of t.initiators){if(i===this.requestInternal)continue;const t=this.parentView().nodeForRequest(i);t&&t.setIsOnInitiatorPath(e)}for(const i of t.initiated.keys()){if(i===this.requestInternal)continue;const t=this.parentView().nodeForRequest(i);t&&t.setIsOnInitiatedPath(e)}}setIsOnInitiatorPath(e){this.isOnInitiatorPathInternal!==e&&this.attached()&&(this.isOnInitiatorPathInternal=e,this.updateBackgroundColor())}isOnInitiatorPath(){return this.isOnInitiatorPathInternal}setIsOnInitiatedPath(e){this.isOnInitiatedPathInternal!==e&&this.attached()&&(this.isOnInitiatedPathInternal=e,this.updateBackgroundColor())}isOnInitiatedPath(){return this.isOnInitiatedPathInternal}displayType(){const e=this.requestInternal.mimeType||this.requestInternal.requestContentType()||"",i=this.requestInternal.resourceType();let r=i.name();return this.requestInternal.fromEarlyHints()?me(pe.earlyHints):(i!==t.ResourceType.resourceTypes.Other&&i!==t.ResourceType.resourceTypes.Image||(r=e.replace(/^(application|image)\//,"")),this.requestInternal.isRedirect()&&(r+=" / "+me(pe.redirect)),r)}displayName(){return this.requestInternal.name()}request(){return this.requestInternal}isNavigationRequest(){const e=n.PageLoad.PageLoad.forRequest(this.requestInternal);return!!e&&e.mainRequest===this.requestInternal}nodeSelfHeight(){return this.parentView().rowHeight()}isPrefetch(){return this.requestInternal.resourceType()===t.ResourceType.resourceTypes.Prefetch}isWarning(){return this.isFailed()&&this.isPrefetch()}isError(){return this.isFailed()&&!this.isPrefetch()}createCells(e){this.nameCell=null,this.initiatorCell=null,e.classList.toggle("network-warning-row",this.isWarning()),e.classList.toggle("network-error-row",this.isError()),e.classList.toggle("network-navigation-row",this.isNavigationRequestInternal),super.createCells(e),this.updateBackgroundColor()}setTextAndTitle(t,i,r){e.UIUtils.createTextChild(t,i),e.Tooltip.Tooltip.install(t,r||i)}setTextAndTitleAsLink(t,i,r,o){const s=document.createElement("span");s.classList.add("devtools-link"),s.textContent=i,s.addEventListener("click",o),t.appendChild(s),e.Tooltip.Tooltip.install(t,r)}renderCell(e,t){const i=e;switch(t){case"name":this.renderPrimaryCell(i,t);break;case"path":this.renderPrimaryCell(i,t,this.requestInternal.pathname);break;case"url":this.renderPrimaryCell(i,t,this.requestInternal.url());break;case"method":{const e=this.requestInternal.preflightRequest();e?(this.setTextAndTitle(i,`${this.requestInternal.requestMethod} + `,me(pe.sPreflight,{PH1:this.requestInternal.requestMethod})),i.appendChild(b.Linkifier.Linkifier.linkifyRevealable(e,me(pe.preflight),void 0,me(pe.selectPreflightRequest),void 0,"preflight-request"))):this.setTextAndTitle(i,this.requestInternal.requestMethod);break}case"status":this.renderStatusCell(i);break;case"protocol":this.renderProtocolCell(i);break;case"scheme":this.setTextAndTitle(i,this.requestInternal.scheme);break;case"domain":this.setTextAndTitle(i,this.requestInternal.domain);break;case"remote-address":this.setTextAndTitle(i,this.requestInternal.remoteAddress());break;case"remote-address-space":this.renderAddressSpaceCell(i,this.requestInternal.remoteAddressSpace());break;case"cookies":this.setTextAndTitle(i,this.arrayLength(this.requestInternal.includedRequestCookies()));break;case"set-cookies":this.setTextAndTitle(i,this.arrayLength(this.requestInternal.nonBlockedResponseCookies()));break;case"priority":{const e=this.requestInternal.priority(),t=this.requestInternal.initialPriority();e&&t?this.setTextAndTitle(i,v.NetworkPriorities.uiLabelForNetworkPriority(e),me(pe.initialPriorityToolTip,{PH1:v.NetworkPriorities.uiLabelForNetworkPriority(e),PH2:v.NetworkPriorities.uiLabelForNetworkPriority(t)})):this.setTextAndTitle(i,e?v.NetworkPriorities.uiLabelForNetworkPriority(e):""),this.appendSubtitle(i,t?v.NetworkPriorities.uiLabelForNetworkPriority(t):"");break}case"connection-id":this.setTextAndTitle(i,"0"===this.requestInternal.connectionId?"":this.requestInternal.connectionId);break;case"type":this.setTextAndTitle(i,this.displayType());break;case"initiator":this.renderInitiatorCell(i);break;case"initiator-address-space":{const e=this.requestInternal.clientSecurityState();this.renderAddressSpaceCell(i,e?e.initiatorIPAddressSpace:"Unknown");break}case"size":this.renderSizeCell(i);break;case"time":this.renderTimeCell(i);break;case"timeline":this.setTextAndTitle(i,"");break;case"has-overrides":this.setTextAndTitle(i,this.requestInternal.overrideTypes.join(", "));break;default:this.setTextAndTitle(i,this.requestInternal.responseHeaderValue(t)||"")}}arrayLength(e){return e?String(e.length):""}select(e){super.select(e),this.parentView().dispatchEventToListeners("RequestSelected",this.requestInternal)}openInNewTab(){i.InspectorFrontendHost.InspectorFrontendHostInstance.openInNewTab(this.requestInternal.url())}isFailed(){return f.isFailedNetworkRequest(this.requestInternal)}renderPrimaryCell(t,i,r){if(0===(0|this.dataGrid?.indexOfVisibleColumn(i))){const e=this.leftPadding?this.leftPadding+"px":"";t.style.setProperty("padding-left",e),t.tabIndex=-1,this.nameCell=t,t.addEventListener("dblclick",this.openInNewTab.bind(this),!1),t.addEventListener("mousedown",(()=>{this.select(),this.parentView().dispatchEventToListeners("RequestActivated",{showPanel:!0})})),t.addEventListener("focus",(()=>this.parentView().resetFocus()));const i=f.getIconForNetworkRequest(this.requestInternal);t.appendChild(i);const r=this.createAiButtonIfAvailable();r&&t.appendChild(r)}if("name"===i){const i=this.requestInternal.webBundleInnerRequestInfo();if(i){const e={iconName:"bundle",color:"var(--icon-info)"},r=f.createIconElement(e,me(pe.webBundleInnerRequest));r.classList.add("icon");const o=n.NetworkManager.NetworkManager.forRequest(this.requestInternal);i.bundleRequestId&&o?t.appendChild(b.Linkifier.Linkifier.linkifyRevealable(new m.NetworkRequestId.NetworkRequestId(i.bundleRequestId,o),r,void 0,void 0,void 0,"webbundle-request")):t.appendChild(r)}const r=s.StringUtilities.trimMiddle(this.requestInternal.name(),100),o=n.NetworkManager.NetworkManager.forRequest(this.requestInternal);e.UIUtils.createTextChild(t,o?o.target().decorateLabel(r):r),this.appendSubtitle(t,this.requestInternal.path()),this.requestInternal.url().startsWith("data")||e.Tooltip.Tooltip.install(t,this.requestInternal.url())}else r&&e.UIUtils.createTextChild(t,r)}renderStatusCell(t){t.classList.toggle("network-dim-cell",!this.isFailed()&&(this.requestInternal.cached()||!this.requestInternal.statusCode));const i=this.requestInternal.corsErrorStatus(),o=this.requestInternal.webBundleInfo()?.errorMessage||this.requestInternal.webBundleInnerRequestInfo()?.errorMessage;if(o)this.setTextAndTitle(t,me(pe.webBundleError),o);else if(!this.requestInternal.failed||this.requestInternal.canceled||this.requestInternal.wasBlocked()||i)if(this.requestInternal.statusCode&&this.requestInternal.statusCode>=400){const i=this.requestInternal.getInferredStatusText();e.UIUtils.createTextChild(t,String(this.requestInternal.statusCode)),this.appendSubtitle(t,i),e.Tooltip.Tooltip.install(t,this.requestInternal.statusCode+" "+i)}else if(!this.requestInternal.statusCode&&this.requestInternal.parsedURL.isDataURL())this.setTextAndTitle(t,me(pe.data));else if(!this.requestInternal.statusCode&&this.requestInternal.canceled)this.setTextAndTitle(t,me(pe.canceled));else if(this.requestInternal.wasBlocked()){let e=me(pe.other),i=!1;switch(this.requestInternal.blockedReason()){case"other":e=me(pe.other);break;case"csp":e=me(pe.csp);break;case"mixed-content":e=r.i18n.lockedString("mixed-content");break;case"origin":e=me(pe.origin);break;case"inspector":e=me(pe.devtools);break;case"subresource-filter":e=r.i18n.lockedString("subresource-filter");break;case"content-type":e=r.i18n.lockedString("content-type");break;case"coep-frame-resource-needs-coep-header":i=!0,e=r.i18n.lockedString("CoepFrameResourceNeedsCoepHeader");break;case"coop-sandboxed-iframe-cannot-navigate-to-coop-page":i=!0,e=r.i18n.lockedString("CoopSandboxedIframeCannotNavigateToCoopPage");break;case"corp-not-same-origin":i=!0,e=r.i18n.lockedString("NotSameOrigin");break;case"corp-not-same-site":i=!0,e=r.i18n.lockedString("NotSameSite");break;case"corp-not-same-origin-after-defaulted-to-same-origin-by-coep":i=!0,e=r.i18n.lockedString("NotSameOriginAfterDefaultedToSameOriginByCoep");break;case"sri-message-signature-mismatch":i=!0,e=me(pe.integrity)}i?this.setTextAndTitleAsLink(t,me(pe.blockeds,{PH1:e}),me(pe.blockedTooltip),(()=>{this.parentView().dispatchEventToListeners("RequestActivated",{showPanel:!0,tab:"headers-component"})})):this.setTextAndTitle(t,me(pe.blockeds,{PH1:e}))}else if(i)this.setTextAndTitle(t,me(pe.corsError),me(pe.crossoriginResourceSharingErrorS,{PH1:i.corsError}));else if(this.requestInternal.statusCode){e.UIUtils.createTextChild(t,String(this.requestInternal.statusCode));const i=this.requestInternal.getInferredStatusText();this.appendSubtitle(t,i),e.Tooltip.Tooltip.install(t,this.requestInternal.statusCode+" "+i)}else this.requestInternal.finished?this.setTextAndTitle(t,me(pe.finished)):this.requestInternal.preserved?this.setTextAndTitle(t,me(pe.unknown),me(pe.unknownExplanation)):this.setTextAndTitle(t,me(pe.pendingq));else{const i=me(pe.failed);this.requestInternal.localizedFailDescription?(e.UIUtils.createTextChild(t,i),this.appendSubtitle(t,this.requestInternal.localizedFailDescription,!0),e.Tooltip.Tooltip.install(t,i+" "+this.requestInternal.localizedFailDescription)):this.setTextAndTitle(t,i)}}renderProtocolCell(t){switch(e.UIUtils.createTextChild(t,this.requestInternal.protocol),this.requestInternal.alternateProtocolUsage){case"alternativeJobWonWithoutRace":e.Tooltip.Tooltip.install(t,pe.alternativeJobWonWithoutRace);break;case"alternativeJobWonRace":e.Tooltip.Tooltip.install(t,pe.alternativeJobWonRace);break;case"mainJobWonRace":e.Tooltip.Tooltip.install(t,pe.mainJobWonRace);break;case"mappingMissing":e.Tooltip.Tooltip.install(t,pe.mappingMissing);break;case"broken":e.Tooltip.Tooltip.install(t,pe.broken);break;case"dnsAlpnH3JobWonWithoutRace":e.Tooltip.Tooltip.install(t,pe.dnsAlpnH3JobWonWithoutRace);break;case"dnsAlpnH3JobWonRace":e.Tooltip.Tooltip.install(t,pe.dnsAlpnH3JobWonRace);break;default:e.Tooltip.Tooltip.install(t,this.requestInternal.protocol)}}#e(){if(this.requestInternal.resourceType().isStyleSheet())return i.UserMetrics.Action.StyleSheetInitiatorLinkClicked}renderInitiatorCell(t){this.initiatorCell=t;const i=this.requestInternal,r=a.NetworkLog.NetworkLog.instance().initiatorInfoForRequest(i),o=i.timing;switch(o?.pushStart&&t.appendChild(document.createTextNode(me(pe.push))),r.type){case"parser":{const e=g.Workspace.WorkspaceImpl.instance().uiSourceCodeForURL(r.url),i=e?.displayName(),o=void 0!==i&&void 0!==r.lineNumber?`${i}:${r.lineNumber}`:void 0;t.appendChild(b.Linkifier.Linkifier.linkifyURL(r.url,{text:o,lineNumber:r.lineNumber,columnNumber:r.columnNumber,userMetric:this.#e()})),this.appendSubtitle(t,me(pe.parser));break}case"redirect":{e.Tooltip.Tooltip.install(t,r.url);const o=i.redirectSource();console.assert(null!==o),this.parentView().nodeForRequest(o)?t.appendChild(b.Linkifier.Linkifier.linkifyRevealable(o,p.ResourceUtils.displayNameForURL(o.url()),void 0,void 0,void 0,"redirect-source-request")):t.appendChild(b.Linkifier.Linkifier.linkifyURL(o.url(),{jslogContext:"redirect-source-request-url"})),this.appendSubtitle(t,me(pe.redirect));break}case"script":{const o=n.NetworkManager.NetworkManager.forRequest(i)?.target()||null,s=this.parentView().linkifier();r.stack?this.linkifiedInitiatorAnchor=s.linkifyStackTraceTopFrame(o,r.stack):this.linkifiedInitiatorAnchor=s.linkifyScriptLocation(o,r.scriptId,r.url,r.lineNumber,{columnNumber:r.columnNumber,inlineFrameIndex:0}),e.Tooltip.Tooltip.install(this.linkifiedInitiatorAnchor,""),t.appendChild(this.linkifiedInitiatorAnchor),this.appendSubtitle(t,me(pe.script)),t.classList.add("network-script-initiated");break}case"preload":e.Tooltip.Tooltip.install(t,me(pe.preload)),t.classList.add("network-dim-cell"),t.appendChild(document.createTextNode(me(pe.preload)));break;case"signedExchange":t.appendChild(b.Linkifier.Linkifier.linkifyURL(r.url)),this.appendSubtitle(t,me(pe.signedexchange));break;case"preflight":if(t.appendChild(document.createTextNode(me(pe.preflight))),r.initiatorRequest){const i=k.Icon.create("arrow-up-down-circle"),o=b.Linkifier.Linkifier.linkifyRevealable(r.initiatorRequest,i,void 0,me(pe.selectTheRequestThatTriggered),"trailing-link-icon","initator-request");e.ARIAUtils.setLabel(o,me(pe.selectTheRequestThatTriggered)),t.appendChild(o)}break;default:e.Tooltip.Tooltip.install(t,me(pe.otherC)),t.classList.add("network-dim-cell"),t.appendChild(document.createTextNode(me(pe.otherC)))}}renderAddressSpaceCell(t,i){"Unknown"!==i&&e.UIUtils.createTextChild(t,i)}renderSizeCell(t){const i=r.ByteUtilities.formatBytesToKb(this.requestInternal.resourceSize);if(this.requestInternal.cachedInMemory())e.UIUtils.createTextChild(t,me(pe.memoryCache)),e.Tooltip.Tooltip.install(t,me(pe.servedFromMemoryCacheResource,{PH1:i})),t.classList.add("network-dim-cell");else if(this.requestInternal.serviceWorkerRouterInfo){const{serviceWorkerRouterInfo:o}=this.requestInternal,s=o.ruleIdMatched??0;let n;if(e.UIUtils.createTextChild(t,r.i18n.lockedString("(ServiceWorker router)")),"network"===o.matchedSourceType){const e=r.ByteUtilities.formatBytesToKb(this.requestInternal.transferSize);n=me(pe.matchedToServiceWorkerRouterWithNetworkSource,{PH1:s,PH2:e,PH3:i})}else n=me(pe.matchedToServiceWorkerRouter,{PH1:s,PH2:i});e.Tooltip.Tooltip.install(t,n),t.classList.add("network-dim-cell")}else if(this.requestInternal.fetchedViaServiceWorker)e.UIUtils.createTextChild(t,me(pe.serviceWorker)),e.Tooltip.Tooltip.install(t,me(pe.servedFromServiceWorkerResource,{PH1:i})),t.classList.add("network-dim-cell");else if(this.requestInternal.redirectSourceSignedExchangeInfoHasNoErrors())e.UIUtils.createTextChild(t,r.i18n.lockedString("(signed-exchange)")),e.Tooltip.Tooltip.install(t,me(pe.servedFromSignedHttpExchange,{PH1:i})),t.classList.add("network-dim-cell");else if(this.requestInternal.webBundleInnerRequestInfo())e.UIUtils.createTextChild(t,me(pe.webBundle)),e.Tooltip.Tooltip.install(t,me(pe.servedFromWebBundle,{PH1:i})),t.classList.add("network-dim-cell");else if(this.requestInternal.fromPrefetchCache())e.UIUtils.createTextChild(t,me(pe.prefetchCache)),e.Tooltip.Tooltip.install(t,me(pe.servedFromPrefetchCacheResource,{PH1:i})),t.classList.add("network-dim-cell");else if(this.requestInternal.cached())e.UIUtils.createTextChild(t,me(pe.diskCache)),e.Tooltip.Tooltip.install(t,me(pe.servedFromDiskCacheResourceSizeS,{PH1:i})),t.classList.add("network-dim-cell");else{const o=r.ByteUtilities.formatBytesToKb(this.requestInternal.transferSize);e.UIUtils.createTextChild(t,o),e.Tooltip.Tooltip.install(t,`${o} transferred over network, resource size: ${i}`)}this.appendSubtitle(t,i)}renderTimeCell(e){this.requestInternal.duration>0?(this.setTextAndTitle(e,r.TimeUtilities.secondsToString(this.requestInternal.duration)),this.appendSubtitle(e,r.TimeUtilities.secondsToString(this.requestInternal.latency),!1,me(pe.timeSubtitleTooltipText))):this.requestInternal.preserved?this.setTextAndTitle(e,me(pe.unknown),me(pe.unknownExplanation)):(e.classList.add("network-dim-cell"),this.setTextAndTitle(e,me(pe.pending)))}appendSubtitle(t,i,r=!1,o=""){const s=document.createElement("div");s.classList.add("network-cell-subtitle"),r&&s.classList.add("always-visible"),s.textContent=i,o&&e.Tooltip.Tooltip.install(s,o),t.appendChild(s)}createAiButtonIfAvailable(){if(e.ActionRegistry.ActionRegistry.instance().hasAction("drjones.network-floating-button")){const t=e.ActionRegistry.ActionRegistry.instance().getAction("drjones.network-floating-button"),i=document.createElement("span");i.classList.add("ai-button-container");const r=new w.FloatingButton.FloatingButton({title:t.title(),iconName:"smart-assistant"});return r.addEventListener("click",(e=>{e.stopPropagation(),this.select(),t.execute()}),{capture:!0}),r.addEventListener("mousedown",(e=>{e.stopPropagation()}),{capture:!0}),i.appendChild(r),i}}}class be extends we{createCells(e){super.createCells(e);const t=this.dataGrid.visibleColumnsArray[0],i=`${t.title}`,r=me(pe.level);this.nodeAccessibleText=`${r} ${i}: ${this.cellAccessibleTextMap.get(t.id)}`}renderCell(e,t){if(0===this.dataGrid.indexOfVisibleColumn(t)){const i=e,r=this.leftPadding?this.leftPadding+"px":"";i.style.setProperty("padding-left",r),i.classList.add("disclosure"),this.setCellAccessibleName(i.textContent||"",i,t)}}select(e){super.select(e);const t=this.traverseNextNode(!1,void 0,!0),i=t?.request();i&&this.parentView().dispatchEventToListeners("RequestSelected",i)}}var fe=Object.freeze({__proto__:null,NetworkGroupNode:be,NetworkNode:we,NetworkRequestNode:ve,_backgroundColors:ke}),Ce={cssText:`.request-cookies-view{overflow:auto;padding:12px;height:100%;background-color:var(--sys-color-cdt-base-container)}.request-cookies-view .request-cookies-title{font-size:12px;font-weight:bold;margin-right:30px;color:var(--sys-color-on-surface)}.request-cookies-view .cookie-line{margin-top:6px;display:flex}.request-cookies-view .cookies-panel-item{margin-top:6px;margin-bottom:16px;flex:none}\n/*# sourceURL=${import.meta.resolve("./requestCookiesView.css")} */\n`};const Se={thisRequestHasNoCookies:"This request has no cookies.",requestCookies:"Request Cookies",cookiesThatWereSentToTheServerIn:"Cookies that were sent to the server in the 'cookie' header of the request",showFilteredOutRequestCookies:"show filtered out request cookies",noRequestCookiesWereSent:"No request cookies were sent.",responseCookies:"Response Cookies",cookiesThatWereReceivedFromThe:"Cookies that were received from the server in the '`set-cookie`' header of the response",malformedResponseCookies:"Malformed Response Cookies",cookiesThatWereReceivedFromTheServer:"Cookies that were received from the server in the '`set-cookie`' header of the response but were malformed",siteHasCookieInOtherPartition:"This site has cookies in another partition, that were not sent with this request. {PH1}",learnMore:"Learn more"},ye=r.i18n.registerUIStrings("panels/network/RequestCookiesView.ts",Se),Te=r.i18n.getLocalizedString.bind(void 0,ye);class xe extends e.Widget.Widget{request;showFilteredOutCookiesSetting;emptyWidget;requestCookiesTitle;requestCookiesEmpty;requestCookiesTable;responseCookiesTitle;responseCookiesTable;siteHasCookieInOtherPartition;malformedResponseCookiesTitle;malformedResponseCookiesList;constructor(i){super(),this.registerRequiredCSS(Ce),this.element.classList.add("request-cookies-view"),this.element.setAttribute("jslog",`${d.pane("cookies").track({resize:!0})}`),this.request=i,this.showFilteredOutCookiesSetting=t.Settings.Settings.instance().createSetting("show-filtered-out-request-cookies",!1),this.emptyWidget=new e.EmptyWidget.EmptyWidget(Te(Se.thisRequestHasNoCookies),""),this.emptyWidget.show(this.element),this.requestCookiesTitle=this.element.createChild("div");const o=this.requestCookiesTitle.createChild("span","request-cookies-title");o.textContent=Te(Se.requestCookies),e.Tooltip.Tooltip.install(o,Te(Se.cookiesThatWereSentToTheServerIn));const s=e.SettingsUI.createSettingCheckbox(Te(Se.showFilteredOutRequestCookies),this.showFilteredOutCookiesSetting);s.checkboxElement.addEventListener("change",(()=>{this.refreshRequestCookiesView()})),this.requestCookiesTitle.appendChild(s),this.requestCookiesEmpty=this.element.createChild("div","cookies-panel-item"),this.requestCookiesEmpty.textContent=Te(Se.noRequestCookiesWereSent),this.requestCookiesTable=new T.CookiesTable.CookiesTable(!0),this.requestCookiesTable.contentElement.classList.add("cookie-table","cookies-panel-item"),this.requestCookiesTable.show(this.element),this.siteHasCookieInOtherPartition=this.element.createChild("div","cookies-panel-item site-has-cookies-in-other-partition"),this.siteHasCookieInOtherPartition.appendChild(r.i18n.getFormatLocalizedString(ye,Se.siteHasCookieInOtherPartition,{PH1:e.XLink.XLink.create("https://developer.chrome.com/en/docs/privacy-sandbox/chips/",Te(Se.learnMore),void 0,void 0,"learn-more")})),this.responseCookiesTitle=this.element.createChild("div","request-cookies-title"),this.responseCookiesTitle.textContent=Te(Se.responseCookies),this.responseCookiesTitle.title=Te(Se.cookiesThatWereReceivedFromThe),this.responseCookiesTable=new T.CookiesTable.CookiesTable(!0),this.responseCookiesTable.contentElement.classList.add("cookie-table","cookies-panel-item"),this.responseCookiesTable.show(this.element),this.malformedResponseCookiesTitle=this.element.createChild("div","request-cookies-title"),this.malformedResponseCookiesTitle.textContent=Te(Se.malformedResponseCookies),e.Tooltip.Tooltip.install(this.malformedResponseCookiesTitle,Te(Se.cookiesThatWereReceivedFromTheServer)),this.malformedResponseCookiesList=this.element.createChild("div")}getRequestCookies(){const e=new Map,t=new Map,i=this.request.includedRequestCookies().map((e=>e.cookie));if(this.showFilteredOutCookiesSetting.get())for(const t of this.request.blockedRequestCookies())e.set(t.cookie,t.blockedReasons.map((e=>({attribute:n.NetworkRequest.cookieBlockedReasonToAttribute(e),uiString:n.NetworkRequest.cookieBlockedReasonToUiString(e)})))),i.push(t.cookie);for(const e of this.request.includedRequestCookies())e.exemptionReason&&t.set(e.cookie,{uiString:n.NetworkRequest.cookieExemptionReasonToUiString(e.exemptionReason)});return{requestCookies:i,requestCookieToBlockedReasons:e,requestCookieToExemptionReason:t}}getResponseCookies(){let e=[];const t=new Map,i=new Map,r=[];if(this.request.responseCookies.length){e=this.request.nonBlockedResponseCookies();for(const i of this.request.blockedResponseCookies()){const o=n.CookieParser.CookieParser.parseSetCookie(i.cookieLine);if(o&&!o.length||i.blockedReasons.includes("SyntaxError")||i.blockedReasons.includes("NameValuePairExceedsMaxSize")){r.push(i);continue}let s=i.cookie;!s&&o&&(s=o[0]),s&&(t.set(s,i.blockedReasons.map((e=>({attribute:n.NetworkRequest.setCookieBlockedReasonToAttribute(e),uiString:n.NetworkRequest.setCookieBlockedReasonToUiString(e)})))),e.push(s))}for(const t of this.request.exemptedResponseCookies()){const r=e.find((e=>t.cookieLine===e.getCookieLine()));r&&i.set(r,{uiString:n.NetworkRequest.cookieExemptionReasonToUiString(t.exemptionReason)})}}return{responseCookies:e,responseCookieToBlockedReasons:t,responseCookieToExemptionReason:i,malformedResponseCookies:r}}refreshRequestCookiesView(){if(!this.isShowing())return;this.request.hasRequestCookies()||this.request.responseCookies.length?this.emptyWidget.hideWidget():this.emptyWidget.showWidget();const{requestCookies:t,requestCookieToBlockedReasons:i,requestCookieToExemptionReason:r}=this.getRequestCookies(),{responseCookies:o,responseCookieToBlockedReasons:s,responseCookieToExemptionReason:a,malformedResponseCookies:l}=this.getResponseCookies();if(t.length?(this.requestCookiesTitle.classList.remove("hidden"),this.requestCookiesEmpty.classList.add("hidden"),this.requestCookiesTable.showWidget(),this.requestCookiesTable.setCookies(t,i,r)):this.request.blockedRequestCookies().length?(this.requestCookiesTitle.classList.remove("hidden"),this.requestCookiesEmpty.classList.remove("hidden"),this.requestCookiesTable.hideWidget()):(this.requestCookiesTitle.classList.add("hidden"),this.requestCookiesEmpty.classList.add("hidden"),this.requestCookiesTable.hideWidget()),o.length?(this.responseCookiesTitle.classList.remove("hidden"),this.responseCookiesTable.showWidget(),this.responseCookiesTable.setCookies(o,s,a)):(this.responseCookiesTitle.classList.add("hidden"),this.responseCookiesTable.hideWidget()),l.length){this.malformedResponseCookiesTitle.classList.remove("hidden"),this.malformedResponseCookiesList.classList.remove("hidden"),this.malformedResponseCookiesList.removeChildren();for(const t of l){const i=this.malformedResponseCookiesList.createChild("span","cookie-line source-code"),r=new k.Icon.Icon;r.data={iconName:"cross-circle-filled",color:"var(--icon-error)",width:"14px",height:"14px"},r.classList.add("cookie-warning-icon"),i.appendChild(r),e.UIUtils.createTextChild(i,t.cookieLine),t.blockedReasons.includes("NameValuePairExceedsMaxSize")?i.title=n.NetworkRequest.setCookieBlockedReasonToUiString("NameValuePairExceedsMaxSize"):i.title=n.NetworkRequest.setCookieBlockedReasonToUiString("SyntaxError")}}else this.malformedResponseCookiesTitle.classList.add("hidden"),this.malformedResponseCookiesList.classList.add("hidden");this.request.siteHasCookieInOtherPartition()?this.siteHasCookieInOtherPartition.classList.remove("hidden"):this.siteHasCookieInOtherPartition.classList.add("hidden")}wasShown(){super.wasShown(),this.request.addEventListener(n.NetworkRequest.Events.REQUEST_HEADERS_CHANGED,this.refreshRequestCookiesView,this),this.request.addEventListener(n.NetworkRequest.Events.RESPONSE_HEADERS_CHANGED,this.refreshRequestCookiesView,this),this.refreshRequestCookiesView()}willHide(){this.request.removeEventListener(n.NetworkRequest.Events.REQUEST_HEADERS_CHANGED,this.refreshRequestCookiesView,this),this.request.removeEventListener(n.NetworkRequest.Events.RESPONSE_HEADERS_CHANGED,this.refreshRequestCookiesView,this)}}var Re=Object.freeze({__proto__:null,RequestCookiesView:xe}),Ie={cssText:`.request-initiator-view{display:flex;margin:6px}\n/*# sourceURL=${import.meta.resolve("./requestInitiatorView.css")} */\n`},qe={cssText:`.request-initiator-view-tree{user-select:text;& .fill{right:-6px}}.request-initiator-view-section-title{font-weight:bold;padding:4px}.request-initiator-view-section-title:focus-visible{background-color:var(--sys-color-state-focus-highlight)}@media (forced-colors: active){.request-initiator-view-section-title:focus-visible{forced-color-adjust:none;background-color:Highlight;color:HighlightText}}\n/*# sourceURL=${import.meta.resolve("./requestInitiatorViewTree.css")} */\n`};const Le={noInitiator:"No initiator data",requestCallStack:"Request call stack",requestInitiatorChain:"Request initiator chain"},Fe=r.i18n.registerUIStrings("panels/network/RequestInitiatorView.ts",Le),Ee=r.i18n.getLocalizedString.bind(void 0,Fe);class He extends e.Widget.VBox{linkifier;request;emptyWidget;hasShown;constructor(t){super(),this.element.classList.add("request-initiator-view"),this.element.setAttribute("jslog",`${d.pane("initiator").track({resize:!0})}`),this.linkifier=new b.Linkifier.Linkifier,this.request=t,this.emptyWidget=new e.EmptyWidget.EmptyWidget(Ee(Le.noInitiator),""),this.emptyWidget.show(this.element),this.hasShown=!1}static createStackTracePreview(e,t,i){const r=e.initiator();if(!r?.stack)return null;const o=n.NetworkManager.NetworkManager.forRequest(e),s=o?o.target():null;return b.JSPresentationUtils.buildStackTracePreviewContents(s,t,{stackTrace:r.stack,tabStops:i})}createTree(){const t=new e.TreeOutline.TreeOutlineInShadow;return t.registerRequiredCSS(qe),t.contentElement.classList.add("request-initiator-view-tree"),t.contentElement.setAttribute("jslog",`${d.tree("initiator-tree")}`),t}buildRequestChainTree(t,i,r){const o=new e.TreeOutline.TreeElement(i);r.appendChild(o),o.titleElement instanceof HTMLElement&&o.titleElement.classList.add("request-initiator-view-section-title");const s=t.initiators;let n=o;for(const t of Array.from(s).reverse()){const i=new e.TreeOutline.TreeElement(t.url());n.appendChild(i),n.expand(),n=i}o.expand(),n.select();const a=n.titleElement;a instanceof HTMLElement&&(a.style.fontWeight="bold");const l=t.initiated;return this.depthFirstSearchTreeBuilder(l,n,this.request),o}depthFirstSearchTreeBuilder(t,i,r){const o=new Set;o.add(this.request);for(const s of t.keys())if(t.get(s)===r){const r=new e.TreeOutline.TreeElement(s.url());i.appendChild(r),i.expand(),o.has(s)||(o.add(s),this.depthFirstSearchTreeBuilder(t,r,s))}}buildStackTraceSection(t,i,r){const o=new e.TreeOutline.TreeElement(i);r.appendChild(o),o.titleElement instanceof HTMLElement&&o.titleElement.classList.add("request-initiator-view-section-title");const s=new e.TreeOutline.TreeElement(t,!1);s.selectable=!1,o.appendChild(s),o.expand()}wasShown(){if(this.hasShown)return;this.registerRequiredCSS(Ie);let e=!1;const t=this.createTree(),i=He.createStackTracePreview(this.request,this.linkifier,!0);i&&(e=!0,this.buildStackTraceSection(i.element,Ee(Le.requestCallStack),t));const r=a.NetworkLog.NetworkLog.instance().initiatorGraphForRequest(this.request);(r.initiators.size>1||r.initiated.size>1)&&(e=!0,this.buildRequestChainTree(r,Ee(Le.requestInitiatorChain),t));const o=t.firstChild();o&&o.select(!0),e&&(this.element.appendChild(t.element),this.emptyWidget.hideWidget()),this.hasShown=!0}}var Pe=Object.freeze({__proto__:null,RequestInitiatorView:He}),Me={cssText:`.object-properties-section-dimmed{opacity:60%}.object-properties-section{padding:0;color:var(--sys-color-on-surface);display:flex;flex-direction:column}.object-properties-section li{user-select:text;&::before{margin-right:2px}}.object-properties-section li.editing-sub-part{padding:3px 12px 8px 6px;margin:-1px -6px -8px;text-overflow:clip}.object-properties-section li.editing{margin-left:10px;text-overflow:clip}.tree-outline ol.title-less-mode{padding-left:0}.object-properties-section .own-property{font-weight:bold}.object-properties-section .synthetic-property{color:var(--sys-color-token-subtle)}.object-properties-section .private-property-hash{color:var(--sys-color-on-surface)}.object-properties-section-root-element{display:flex;flex-direction:row}.object-properties-section .editable-div{overflow:hidden}.name-and-value{overflow:hidden;line-height:16px;display:flex;white-space:nowrap}.name-and-value .separator{white-space:pre;flex-shrink:0}.editing-sub-part .name-and-value{overflow:visible;display:inline-flex}.property-prompt{margin-left:4px}.tree-outline.hide-selection-when-blurred .selected:focus-visible{background:none}.tree-outline.hide-selection-when-blurred .selected:focus-visible ::slotted(*),\n.tree-outline.hide-selection-when-blurred .selected:focus-visible .tree-element-title,\n.tree-outline.hide-selection-when-blurred .selected:focus-visible .name-and-value,\n.tree-outline.hide-selection-when-blurred .selected:focus-visible .gray-info-message{background:var(--sys-color-state-focus-highlight);border-radius:2px}@media (forced-colors: active){.object-properties-section-dimmed{opacity:100%}.tree-outline.hide-selection-when-blurred .selected:focus-visible{background:Highlight}.tree-outline li:hover .tree-element-title,\n .tree-outline li.selected .tree-element-title{color:ButtonText}.tree-outline.hide-selection-when-blurred .selected:focus-visible .tree-element-title,\n .tree-outline.hide-selection-when-blurred .selected:focus-visible .name-and-value{background:transparent;box-shadow:none}.tree-outline.hide-selection-when-blurred .selected:focus-visible span,\n .tree-outline.hide-selection-when-blurred .selected:focus-visible .gray-info-message{color:HighlightText}.tree-outline-disclosure:hover li.parent::before{background-color:ButtonText}}\n/*# sourceURL=${import.meta.resolve("./objectPropertiesSection.css")} */\n`},Ae={cssText:`.value.object-value-node:hover{background-color:var(--sys-color-state-hover-on-subtle)}.object-value-function-prefix,\n.object-value-boolean{color:var(--sys-color-token-attribute-value)}.object-value-function{font-style:italic}.object-value-function.linkified:hover{--override-linkified-hover-background:rgb(0 0 0/10%);background-color:var(--override-linkified-hover-background);cursor:pointer}.theme-with-dark-background .object-value-function.linkified:hover,\n:host-context(.theme-with-dark-background) .object-value-function.linkified:hover{--override-linkified-hover-background:rgb(230 230 230/10%)}.object-value-number{color:var(--sys-color-token-attribute-value)}.object-value-bigint{color:var(--sys-color-token-comment)}.object-value-string,\n.object-value-regexp,\n.object-value-symbol{white-space:pre;unicode-bidi:-webkit-isolate;color:var(--sys-color-token-property-special)}.object-value-node{position:relative;vertical-align:baseline;color:var(--sys-color-token-variable);white-space:nowrap}.object-value-null,\n.object-value-undefined{color:var(--sys-color-state-disabled)}.object-value-unavailable{color:var(--sys-color-token-tag)}.object-value-calculate-value-button:hover{text-decoration:underline}.object-properties-section-custom-section{display:inline-flex;flex-direction:column}.theme-with-dark-background .object-value-number,\n:host-context(.theme-with-dark-background) .object-value-number,\n.theme-with-dark-background .object-value-boolean,\n:host-context(.theme-with-dark-background) .object-value-boolean{--override-primitive-dark-mode-color:hsl(252deg 100% 75%);color:var(--override-primitive-dark-mode-color)}.object-properties-section .object-description{color:var(--sys-color-token-subtle)}.value .object-properties-preview{white-space:nowrap}.name{color:var(--sys-color-token-tag);flex-shrink:0}.object-properties-preview .name{color:var(--sys-color-token-subtle)}@media (forced-colors: active){.object-value-calculate-value-button:hover{forced-color-adjust:none;color:Highlight}}\n/*# sourceURL=${import.meta.resolve("./objectValue.css")} */\n`},Ne={cssText:`.tree-outline{padding-left:0}.tree-outline > ol{padding-bottom:5px;border-bottom:solid 1px var(--sys-color-divider)}.tree-outline > .parent{user-select:none;font-weight:bold;color:var(--sys-color-on-surface);margin-top:-1px;display:flex;align-items:center;height:var(--sys-size-13)}.tree-outline li{padding-left:5px;line-height:20px}.tree-outline li:not(.parent){margin-left:10px;display:block;&:has(.payload-name){margin:var(--sys-size-3) 0;display:grid;grid-template-columns:min-content 1fr;gap:var(--sys-size-6)}}.tree-outline li:not(.parent)::before{display:none}.tree-outline li.expanded .payload-count{display:none}.tree-outline li .payload-toggle{display:none}.tree-outline li.expanded .payload-toggle{display:inline;margin-left:30px;font-weight:normal}.tree-outline li.expanded .payload-toggle:focus-visible{border:2px solid var(--sys-color-state-focus-ring);border-radius:5px}.tree-outline li .header-toggle:hover{color:var(--sys-color-token-subtle)}.tree-outline .payload-name{color:var(--sys-color-on-surface-subtle);font:var(--sys-typescale-body5-medium);white-space:pre-wrap;align-self:start;min-width:150px;line-height:18px}.tree-outline .payload-value{display:inline;white-space:pre-wrap;word-break:break-all;font:var(--sys-typescale-body4-regular);line-height:18px}.tree-outline .empty-request-payload{color:var(--sys-color-state-disabled)}.request-payload-show-more-button{margin:0 4px}@media (forced-colors: active){:host-context(.request-payload-tree) ol.tree-outline:not(.hide-selection-when-blurred) li.selected:focus{background:Highlight}:host-context(.request-payload-tree) ol.tree-outline:not(.hide-selection-when-blurred) li::before{background-color:ButtonText}:host-context(.request-payload-tree) ol.tree-outline:not(.hide-selection-when-blurred) li.selected.parent::before{background-color:HighlightText}:host-context(.request-payload-tree) ol.tree-outline:not(.hide-selection-when-blurred) li.selected *,\n :host-context(.request-payload-tree) ol.tree-outline:not(.hide-selection-when-blurred) li.selected.parent,\n :host-context(.request-payload-tree) ol.tree-outline:not(.hide-selection-when-blurred) li.selected.parent span{color:HighlightText}}.payload-decode-error{color:var(--sys-color-error)}\n/*# sourceURL=${import.meta.resolve("./requestPayloadTree.css")} */\n`},Ue={cssText:`.request-payload-view{user-select:text;overflow:auto}.request-payload-tree{flex-grow:1;overflow-y:auto;margin:0}\n/*# sourceURL=${import.meta.resolve("./requestPayloadView.css")} */\n`};const Be={copyValue:"Copy value",copyPayload:"Copy",requestPayload:"Request Payload",unableToDecodeValue:"(unable to decode value)",queryStringParameters:"Query String Parameters",formData:"Form Data",showMore:"Show more",viewParsed:"View parsed",empty:"(empty)",viewSource:"View source",viewUrlEncoded:"View URL-encoded",viewDecoded:"View decoded"},Ve=r.i18n.registerUIStrings("panels/network/RequestPayloadView.ts",Be),We=r.i18n.getLocalizedString.bind(void 0,Ve);class Oe extends e.Widget.VBox{request;decodeRequestParameters;queryStringCategory;formDataCategory;requestPayloadCategory;constructor(t){super(),this.registerRequiredCSS(Ue),this.element.classList.add("request-payload-view"),this.element.setAttribute("jslog",`${d.pane("payload").track({resize:!0})}`),this.request=t,this.decodeRequestParameters=!0;const i=t.requestContentType();i&&(this.decodeRequestParameters=Boolean(i.match(/^application\/x-www-form-urlencoded\s*(;.*)?$/i)));const r=new e.TreeOutline.TreeOutlineInShadow;r.registerRequiredCSS(Ae,Me,Ne),r.element.classList.add("request-payload-tree"),r.makeDense(),this.element.appendChild(r.element),this.queryStringCategory=new Ge(r,"query-string"),this.formDataCategory=new Ge(r,"form-data"),this.requestPayloadCategory=new Ge(r,"request-payload",We(Be.requestPayload))}wasShown(){super.wasShown(),this.request.addEventListener(n.NetworkRequest.Events.REQUEST_HEADERS_CHANGED,this.refreshFormData,this),this.refreshQueryString(),this.refreshFormData()}willHide(){this.request.removeEventListener(n.NetworkRequest.Events.REQUEST_HEADERS_CHANGED,this.refreshFormData,this)}addEntryContextMenuHandler(t,r,o,s){t.listItemElement.addEventListener("contextmenu",(t=>{t.consume(!0);const n=new e.ContextMenu.ContextMenu(t);n.clipboardSection().appendItem(r,(()=>{i.userMetrics.actionTaken(i.UserMetrics.Action.NetworkPanelCopyValue),i.InspectorFrontendHost.InspectorFrontendHostInstance.copyText(s())}),{jslogContext:o}),n.show()}))}static formatParameter(e,t,i){let r=!1;if(i&&(e=e.replace(/\+/g," ")).indexOf("%")>=0)try{e=decodeURIComponent(e)}catch{r=!0}const o=document.createElement("div");return t&&(o.className=t),""===e&&o.classList.add("empty-value"),r?o.createChild("span","payload-decode-error").textContent=We(Be.unableToDecodeValue):o.textContent=e,o}refreshQueryString(){const e=this.request.queryString(),t=this.request.queryParameters;this.queryStringCategory.hidden=!t,t&&this.refreshParams(We(Be.queryStringParameters),t,e,this.queryStringCategory)}async refreshFormData(){const e=await this.request.requestFormData();if(!e)return this.formDataCategory.hidden=!0,void(this.requestPayloadCategory.hidden=!0);const t=await this.request.formParameters();if(t)this.formDataCategory.hidden=!1,this.requestPayloadCategory.hidden=!0,this.refreshParams(We(Be.formData),t,e,this.formDataCategory);else{this.requestPayloadCategory.hidden=!1,this.formDataCategory.hidden=!0;try{const t=JSON.parse(e);this.refreshRequestJSONPayload(t,e)}catch{this.populateTreeElementWithSourceText(this.requestPayloadCategory,e)}}}populateTreeElementWithSourceText(t,i){const r=(i||"").trim(),o=r.length>3e3,s=document.createElement("span");s.classList.add("payload-value"),s.classList.add("source-code"),s.textContent=o?r.substr(0,3e3):r;const n=new e.TreeOutline.TreeElement(s);if(t.removeChildren(),t.appendChild(n),this.addEntryContextMenuHandler(n,We(Be.copyPayload),"copy-payload",(()=>r)),!o)return;const a=new l.Button.Button;function d(){a.remove(),s.textContent=r,n.listItemElement.removeEventListener("contextmenu",c)}function c(t){const i=new e.ContextMenu.ContextMenu(t);i.newSection().appendItem(We(Be.showMore),d,{jslogContext:"show-more"}),i.show()}a.data={variant:"outlined",jslogContext:"show-more"},a.innerText=We(Be.showMore),a.classList.add("request-payload-show-more-button"),a.addEventListener("click",d),n.listItemElement.addEventListener("contextmenu",c),s.appendChild(a)}refreshParams(t,i,r,o){o.removeChildren(),o.listItemElement.removeChildren(),o.listItemElement.createChild("div","selection fill"),e.UIUtils.createTextChild(o.listItemElement,t);const s=document.createElement("span");s.classList.add("payload-count");const n=i?i.length:0;s.textContent=` (${n})`,o.listItemElement.appendChild(s);De.has(o)?this.appendParamsSource(t,i,r,o):this.appendParamsParsed(t,i,r,o)}appendParamsSource(t,i,r,o){this.populateTreeElementWithSourceText(o,r);const s=o.listItemElement,n=function(e){s.removeEventListener("contextmenu",a),De.delete(o),this.refreshParams(t,i,r,o),e.consume()},a=t=>{if(!o.expanded)return;const i=new e.ContextMenu.ContextMenu(t);i.newSection().appendItem(We(Be.viewParsed),n.bind(this,t),{jslogContext:"view-parsed"}),i.show()},l=this.createViewSourceToggle(!0,n.bind(this));s.appendChild(l),s.addEventListener("contextmenu",a)}appendParamsParsed(t,i,r,o){for(const t of i||[]){const i=document.createDocumentFragment();if(""!==t.name){const e=Oe.formatParameter(t.name,"payload-name",this.decodeRequestParameters),r=Oe.formatParameter(t.value,"payload-value source-code",this.decodeRequestParameters);i.appendChild(e),i.appendChild(r)}else i.appendChild(Oe.formatParameter(We(Be.empty),"empty-request-payload",this.decodeRequestParameters));const r=new e.TreeOutline.TreeElement(i);this.addEntryContextMenuHandler(r,We(Be.copyValue),"copy-value",(()=>decodeURIComponent(t.value))),o.appendChild(r)}const s=o.listItemElement,n=function(e){s.removeEventListener("contextmenu",l),De.add(o),this.refreshParams(t,i,r,o),e.consume()},a=function(e){s.removeEventListener("contextmenu",l),this.toggleURLDecoding(e)},l=t=>{if(!o.expanded)return;const i=new e.ContextMenu.ContextMenu(t),r=i.newSection();r.appendItem(We(Be.viewSource),n.bind(this,t),{jslogContext:"view-source"});const s=this.decodeRequestParameters?We(Be.viewUrlEncoded):We(Be.viewDecoded);r.appendItem(s,a.bind(this,t),{jslogContext:"toggle-url-decoding"}),i.show()},d=this.createViewSourceToggle(!1,n.bind(this));s.appendChild(d);const c=this.decodeRequestParameters?We(Be.viewUrlEncoded):We(Be.viewDecoded),h=e.UIUtils.createTextButton(c,a.bind(this),{jslogContext:"decode-encode",className:"payload-toggle"});s.appendChild(h),s.addEventListener("contextmenu",l)}refreshRequestJSONPayload(t,i){const r=this.requestPayloadCategory;r.removeChildren();const o=r.listItemElement;o.removeChildren(),o.createChild("div","selection fill"),e.UIUtils.createTextChild(o,this.requestPayloadCategory.title.toString()),De.has(r)?this.appendJSONPayloadSource(r,t,i):this.appendJSONPayloadParsed(r,t,i)}appendJSONPayloadSource(t,i,r){const o=t.listItemElement;this.populateTreeElementWithSourceText(t,r);const s=function(e){o.removeEventListener("contextmenu",a),De.delete(t),this.refreshRequestJSONPayload(i,r),e.consume()},n=this.createViewSourceToggle(!0,s.bind(this));o.appendChild(n);const a=i=>{if(!t.expanded)return;const r=new e.ContextMenu.ContextMenu(i);r.newSection().appendItem(We(Be.viewParsed),s.bind(this,i),{jslogContext:"view-parsed"}),r.show()};o.addEventListener("contextmenu",a)}appendJSONPayloadParsed(t,i,r){const o=n.RemoteObject.RemoteObject.fromLocalObject(i),s=new x.ObjectPropertiesSection.RootElement(o);s.title=o.description,s.expand(),s.editable=!1,t.childrenListElement.classList.add("source-code","object-properties-section"),t.appendChild(s);const a=t.listItemElement,l=function(e){a.removeEventListener("contextmenu",d),De.add(t),this.refreshRequestJSONPayload(i,r),e.consume()},d=i=>{if(!t.expanded)return;const r=new e.ContextMenu.ContextMenu(i);r.newSection().appendItem(We(Be.viewSource),l.bind(this,i),{jslogContext:"view-source"}),r.show()},c=this.createViewSourceToggle(!1,l.bind(this));a.appendChild(c),a.addEventListener("contextmenu",d)}createViewSourceToggle(t,i){const r=We(t?Be.viewParsed:Be.viewSource);return e.UIUtils.createTextButton(r,i,{jslogContext:"source-parse",className:"payload-toggle"})}toggleURLDecoding(e){this.decodeRequestParameters=!this.decodeRequestParameters,this.refreshQueryString(),this.refreshFormData(),e.consume()}}const De=new WeakSet;let Ge=class extends e.TreeOutline.TreeElement{toggleOnClick;expandedSetting;expanded;constructor(e,i,r){super(r||"",!0),this.toggleOnClick=!0,this.hidden=!0,this.expandedSetting=t.Settings.Settings.instance().createSetting("request-info-"+i+"-category-expanded",!0),this.expanded=this.expandedSetting.get(),this.listItemElement.setAttribute("jslog",`${d.section().context(i)}`),e.appendChild(this)}createLeaf(){const t=new e.TreeOutline.TreeElement;return this.appendChild(t),t}onexpand(){this.expandedSetting.set(!0)}oncollapse(){this.expandedSetting.set(!1)}};var je=Object.freeze({__proto__:null,Category:Ge,RequestPayloadView:Oe}),ze={cssText:`.html-preview-frame{box-shadow:var(--drop-shadow);background:var(--ref-palette-neutral100);color-scheme:light;flex-grow:1;margin:20px}\n/*# sourceURL=${import.meta.resolve("./requestHTMLView.css")} */\n`};class _e extends e.Widget.VBox{dataURL;constructor(e){super(!0),this.registerRequiredCSS(ze),this.dataURL=e,this.contentElement.classList.add("html","request-view")}static create(e){const t=e.asDataUrl();return t?new _e(t):null}wasShown(){super.wasShown(),this.createIFrame()}willHide(){this.contentElement.removeChildren()}createIFrame(){this.contentElement.removeChildren();const t=document.createElement("iframe");t.className="html-preview-frame",t.setAttribute("sandbox",""),t.setAttribute("csp","default-src 'none';img-src data:;style-src 'unsafe-inline'"),t.setAttribute("src",this.dataURL),t.tabIndex=-1,e.ARIAUtils.markAsPresentation(t),this.contentElement.appendChild(t)}}var Ke=Object.freeze({__proto__:null,RequestHTMLView:_e});const $e={noPreview:"Nothing to preview",thisRequestHasNoResponseData:"This request has no response data available",failedToLoadResponseData:"Failed to load response data"},Xe=r.i18n.registerUIStrings("panels/network/RequestResponseView.ts",$e),Je=r.i18n.getLocalizedString.bind(void 0,Xe);class Ye extends e.Widget.VBox{request;contentViewPromise;constructor(e){super(),this.element.classList.add("request-view"),this.element.setAttribute("jslog",`${d.pane("response").track({resize:!0})}`),this.request=e,this.contentViewPromise=null}static#t(e,r){let s,n=Qe.get(e);if(void 0!==n)return n;s="application/json"===t.ResourceType.ResourceType.simplifyContentType(e.mimeType)?e.mimeType:e.resourceType().canonicalMimeType()||e.mimeType;const a="application/wasm"===r.mimeType,l=!(a||!r.isTextContent)&&R.TextUtils.isMinified(r.content().text),d=t.ResourceType.ResourceType.mediaTypeForMetrics(s,e.resourceType().isFromSourceMap(),l,!1,!1);return i.userMetrics.networkPanelResponsePreviewOpened(d),n=r.isTextContent||a?o.ResourceSourceFrame.ResourceSourceFrame.createSearchableView(e,s):new V(r,e.url(),e.resourceType()),Qe.set(e,n),n}wasShown(){this.doShowPreview()}doShowPreview(){return this.contentViewPromise||(this.contentViewPromise=this.showPreview()),this.contentViewPromise}async showPreview(){const e=await this.createPreview();return e.show(this.element),e}async createPreview(){const t=await this.request.requestStreamingContent();if(R.StreamingContentData.isError(t))return new e.EmptyWidget.EmptyWidget(Je($e.failedToLoadResponseData),t.error);const i=Ye.#t(this.request,t);return i&&204!==this.request.statusCode?i:new e.EmptyWidget.EmptyWidget(Je($e.noPreview),Je($e.thisRequestHasNoResponseData))}async revealPosition(e){const t=await this.doShowPreview();t instanceof o.ResourceSourceFrame.SearchableContainer&&t.revealPosition(e)}}const Qe=new WeakMap;var Ze=Object.freeze({__proto__:null,RequestResponseView:Ye}),et={cssText:`.tree-outline{padding-left:0}.tree-outline > ol{padding-bottom:5px;border-bottom:solid 1px var(--sys-color-divider)}.tree-outline > .parent{user-select:none;font-weight:bold;color:var(--sys-color-on-surface);margin-top:-1px;display:flex;align-items:center;height:26px}.tree-outline li{padding-left:5px;line-height:20px}.tree-outline li:not(.parent){display:block;margin-left:10px}.tree-outline li:not(.parent)::before{display:none}.tree-outline .header-name{color:var(--sys-color-token-subtle);display:inline-block;margin-right:0.25em;font-weight:bold;vertical-align:top;white-space:pre-wrap}.tree-outline .header-separator{user-select:none}.tree-outline .header-value{display:inline;margin-right:1em;white-space:pre-wrap;word-break:break-all;margin-top:1px}.tree-outline .header-toggle{display:inline;margin-left:30px;font-weight:normal;color:var(--sys-color-state-disabled)}.tree-outline .header-toggle:hover{color:var(--sys-color-state-hover-on-subtle)}.tree-outline .error-log{color:var(--sys-color-error);display:inline-block;margin-right:0.25em;margin-left:0.25em;font-weight:bold;vertical-align:top;white-space:pre-wrap}.tree-outline .hex-data{display:block;word-break:normal;overflow-wrap:anywhere;margin-left:20px}.tree-outline .error-field{color:var(--sys-color-error)}.prompt-icon{margin-top:2px}\n/*# sourceURL=${import.meta.resolve("./signedExchangeInfoTree.css")} */\n`},tt={cssText:`.signed-exchange-info-view{user-select:text;overflow:auto}.signed-exchange-info-tree{flex-grow:1;overflow-y:auto;margin:0}\n/*# sourceURL=${import.meta.resolve("./signedExchangeInfoView.css")} */\n`};const it={errors:"Errors",signedHttpExchange:"Signed HTTP exchange",learnmore:"Learn more",requestUrl:"Request URL",responseCode:"Response code",headerIntegrityHash:"Header integrity hash",responseHeaders:"Response headers",signature:"Signature",label:"Label",certificateUrl:"Certificate URL",viewCertificate:"View certificate",integrity:"Integrity",certificateSha:"Certificate SHA256",validityUrl:"Validity URL",date:"Date",expires:"Expires",certificate:"Certificate",subject:"Subject",validFrom:"Valid from",validUntil:"Valid until",issuer:"Issuer"},rt=r.i18n.registerUIStrings("panels/network/SignedExchangeInfoView.ts",it),ot=r.i18n.getLocalizedString.bind(void 0,rt);class st extends e.Widget.VBox{responseHeadersItem;constructor(t){super(),this.registerRequiredCSS(tt),console.assert(null!==t.signedExchangeInfo());const r=t.signedExchangeInfo();this.element.classList.add("signed-exchange-info-view");const o=new e.TreeOutline.TreeOutlineInShadow;o.registerRequiredCSS(et),o.element.classList.add("signed-exchange-info-tree"),o.setFocusable(!1),o.makeDense(),o.expandTreeElementsWhenArrowing=!0,this.element.appendChild(o.element);const s=new Map;if(r.errors?.length){const e=new nt(o,ot(it.errors));for(const t of r.errors){const i=document.createDocumentFragment(),r=new k.Icon.Icon;if(r.data={iconName:"cross-circle-filled",color:"var(--icon-error)",width:"14px",height:"14px"},r.classList.add("prompt-icon"),i.appendChild(r),i.createChild("div","error-log").textContent=t.message,e.createLeaf(i),t.errorField){let e=s.get(t.signatureIndex);e||(e=new Set,s.set(t.signatureIndex,e)),e.add(t.errorField)}}}const n=document.createDocumentFragment();n.createChild("div","header-name").textContent=ot(it.signedHttpExchange);const a=e.XLink.XLink.create("https://github.com/WICG/webpackage",ot(it.learnmore),"header-toggle",void 0,"learn-more");n.appendChild(a);const l=new nt(o,n);if(r.header){const n=r.header,a=t.redirectDestination(),d=this.formatHeader(ot(it.requestUrl),n.requestUrl);if(a){const e=b.Linkifier.Linkifier.linkifyRevealable(a,"View request",void 0,void 0,void 0,"redirect-destination-request");e.classList.add("header-toggle"),d.appendChild(e)}l.createLeaf(d),l.createLeaf(this.formatHeader(ot(it.responseCode),String(n.responseCode))),l.createLeaf(this.formatHeader(ot(it.headerIntegrityHash),n.headerIntegrity)),this.responseHeadersItem=l.createLeaf(this.formatHeader(ot(it.responseHeaders),""));const c=n.responseHeaders;for(const t in c){const i=new e.TreeOutline.TreeElement(this.formatHeader(t,c[t]));i.selectable=!1,this.responseHeadersItem.appendChild(i)}this.responseHeadersItem.expand();for(let e=0;e{e.map((e=>i.appendToolbarItem(e)))})),t}async htmlPreview(){const t=await this.request.requestContentData();if(R.ContentData.ContentData.isError(t))return new e.EmptyWidget.EmptyWidget(ct(lt.failedToLoadResponseData),t.error);if(!new Set(["text/html","text/plain","application/xhtml+xml"]).has(this.request.mimeType))return null;const i=await o.JSONView.JSONView.createView(t.text);return i||_e.create(t)}async createPreview(){if(this.request.signedExchangeInfo())return new st(this.request);if(this.request.webBundleInfo())return S.LegacyWrapper.legacyWrapper(e.Widget.VBox,new y.WebBundleInfoView.WebBundleInfoView(this.request));const t=await this.htmlPreview();if(t)return t;const i=await o.PreviewFactory.PreviewFactory.createPreview(this.request,this.request.mimeType);return i||new e.EmptyWidget.EmptyWidget(ct(lt.previewNotAvailable),"")}}var ut=Object.freeze({__proto__:null,RequestPreviewView:ht}),pt={cssText:`.network-timing-table{width:380px;border-spacing:0;padding-left:10px;padding-right:10px;line-height:initial;table-layout:fixed}.network-timing-start{border-top:5px solid transparent}.network-timing-start th span.network-timing-hidden-header{height:1px;width:1px;position:absolute;overflow:hidden}.network-timing-table-header td,\n.network-timing-footer td{border-top:10px solid transparent}.network-timing-table-header td{color:var(--sys-color-token-subtle)}.network-timing-table td{padding:4px 0}.network-timing-table-header td:last-child{text-align:right}.network-timing-footer td:last-child{font-weight:bold;text-align:right}table.network-timing-table > tr:not(.network-timing-table-header, .network-timing-footer) > td:first-child{padding-left:12px}.network-timing-table col.labels{width:156px}.network-timing-table col.duration{width:80px}.network-timing-table td.caution{font-weight:bold;color:var(--issue-color-yellow);padding:2px 0}.network-timing-table hr.break{background-color:var(--sys-color-divider);border:none;height:1px}.network-timing-row{position:relative;height:15px}.network-timing-bar{position:absolute;min-width:1px;top:0;bottom:0}.network-timing-bar-title{color:var(--sys-color-on-surface);white-space:nowrap;text-align:right}.network-timing-bar.queueing,\n.network-timing-bar.total{border:1px solid var(--sys-color-token-subtle)}.network-timing-bar.blocking,\n.-theme-preserve{background-color:var(--network-overview-blocking)}.network-timing-bar.proxy,\n.-theme-preserve{background-color:var(--override-network-overview-proxy)}.network-timing-bar.dns,\n.-theme-preserve{background-color:var(--sys-color-cyan)}.network-timing-bar.connecting,\n.network-timing-bar.serviceworker,\n.network-timing-bar.serviceworker-preparation,\n.network-timing-bar.serviceworker-routerevaluation,\n.network-timing-bar.serviceworker-cachelookup,\n.-theme-preserve{background-color:var(--network-overview-service-worker)}.network-timing-bar.ssl,\n.-theme-preserve{background-color:var(--network-overview-ssl)}.network-timing-bar.serviceworker-respondwith,\n.-theme-preserve{background-color:var(--network-overview-service-worker-respond-with)}.network-fetch-timing-bar-clickable::before{user-select:none;mask-image:var(--image-file-triangle-right);float:left;width:14px;height:14px;margin-right:2px;content:"";position:relative;background-color:var(--icon-default);transition:transform 200ms}.network-fetch-timing-bar-clickable{position:relative;left:-12px}.network-fetch-timing-bar-clickable:focus-visible{background-color:var(--sys-color-state-focus-highlight)}.network-fetch-timing-bar-clickable[aria-checked="true"]::before{transform:rotate(90deg)}.network-fetch-timing-bar-details-collapsed{display:none}.network-fetch-timing-bar-details-expanded{display:block}.network-fetch-timing-bar-details,\n.router-evaluation-timing-bar-details{padding-left:11px;width:fit-content}.network-fetch-details-treeitem{width:max-content}.network-timing-bar.sending,\n.-theme-preserve{background-color:var(--override-network-overview-sending)}.network-timing-bar.waiting,\n.-theme-preserve{background-color:var(--network-overview-waiting)}.network-timing-bar.receiving,\n.network-timing-bar.receiving-push,\n.-theme-preserve{background-color:var(--network-overview-receiving)}.network-timing-bar.push,\n.-theme-preserve{background-color:var(--network-overview-push)}.server-timing-row:nth-child(even){background:var(--sys-color-surface1)}.network-timing-bar.server-timing,\n.-theme-preserve{background-color:var(--sys-color-neutral-container)}.network-timing-table td.network-timing-metric{white-space:nowrap;max-width:150px;overflow-x:hidden;text-overflow:ellipsis}.network-timing-bar.proxy,\n.network-timing-bar.dns,\n.network-timing-bar.ssl,\n.network-timing-bar.connecting,\n.network-timing-bar.blocking{height:10px;margin:auto}@media (forced-colors: active){.network-timing-bar.blocking,\n .network-timing-bar.proxy,\n .network-timing-bar.dns,\n .network-timing-bar.connecting,\n .network-timing-bar.serviceworker,\n .network-timing-bar.serviceworker-preparation,\n .network-timing-bar.ssl,\n .network-timing-bar.sending,\n .network-timing-bar.waiting,\n .network-timing-bar.receiving,\n .network-timing-bar.receiving-push,\n .network-timing-bar.push,\n .network-timing-bar.server-timing,\n .-theme-preserve{forced-color-adjust:none}.network-timing-table-header td,\n .network-timing-footer td{forced-color-adjust:none;color:ButtonText}}\n/*# sourceURL=${import.meta.resolve("./networkTimingTable.css")} */\n`};const gt={receivingPush:"Receiving `Push`",queueing:"Queueing",stalled:"Stalled",initialConnection:"Initial connection",dnsLookup:"DNS Lookup",proxyNegotiation:"Proxy negotiation",readingPush:"Reading `Push`",contentDownload:"Content Download",requestSent:"Request sent",requestToServiceworker:"Request to `ServiceWorker`",startup:"Startup",respondwith:"respondWith",ssl:"SSL",total:"Total",waitingTtfb:"Waiting for server response",label:"Label",routerEvaluation:"Router Evaluation",routerCacheLookup:"Cache Lookup",waterfall:"Waterfall",duration:"Duration",queuedAtS:"Queued at {PH1}",startedAtS:"Started at {PH1}",serverPush:"Server Push",resourceScheduling:"Resource Scheduling",connectionStart:"Connection Start",requestresponse:"Request/Response",cautionRequestIsNotFinishedYet:"CAUTION: request is not finished yet!",explanation:"Explanation",serverTiming:"Server Timing",time:"TIME",theServerTimingApi:"the Server Timing API",duringDevelopmentYouCanUseSToAdd:"During development, you can use {PH1} to add insights into the server-side timing of this request.",durationC:"DURATION",originalRequest:"Original Request",responseReceived:"Response Received",unknown:"Unknown",sourceOfResponseS:"Source of response: {PH1}",cacheStorageCacheNameS:"Cache storage cache name: {PH1}",cacheStorageCacheNameUnknown:"Cache storage cache name: Unknown",retrievalTimeS:"Retrieval Time: {PH1}",serviceworkerCacheStorage:"`ServiceWorker` cache storage",fromHttpCache:"From HTTP cache",networkFetch:"Network fetch",fallbackCode:"Fallback code",routerMatchedSource:"Matched source: {PH1}",routerActualSource:"Actual source: {PH1}"},mt=r.i18n.registerUIStrings("panels/network/RequestTimingView.ts",gt),wt=r.i18n.getLocalizedString.bind(void 0,mt);class kt extends e.Widget.VBox{request;calculator;lastMinimumBoundary;tableElement;constructor(e,t){super(),this.registerRequiredCSS(pt),this.element.classList.add("resource-timing-view"),this.request=e,this.calculator=t,this.lastMinimumBoundary=-1}static timeRangeTitle(e){switch(e){case"push":return wt(gt.receivingPush);case"queueing":return wt(gt.queueing);case"blocking":return wt(gt.stalled);case"connecting":return wt(gt.initialConnection);case"dns":return wt(gt.dnsLookup);case"proxy":return wt(gt.proxyNegotiation);case"receiving-push":return wt(gt.readingPush);case"receiving":return wt(gt.contentDownload);case"sending":return wt(gt.requestSent);case"serviceworker":return wt(gt.requestToServiceworker);case"serviceworker-preparation":return wt(gt.startup);case"serviceworker-routerevaluation":return wt(gt.routerEvaluation);case"serviceworker-cachelookup":return wt(gt.routerCacheLookup);case"serviceworker-respondwith":return wt(gt.respondwith);case"ssl":return wt(gt.ssl);case"total":return wt(gt.total);case"waiting":return wt(gt.waitingTtfb);default:return e}}static calculateRequestTimeRanges(e,t){const i=[];function r(e,t,r){t0)return e[t]}function s(e,t,i){t>=0&&i>=0&&r(e,d+t/1e3,d+i/1e3)}function n(e,t,i){r(e,d+t/1e3,d+i/1e3)}const a=e.timing;if(!a){const t=-1!==e.issueTime()?e.issueTime():-1!==e.startTime?e.startTime:0,o=-1!==e.issueTime()&&-1!==e.startTime&&e.issueTime()!==e.startTime,s=-1===e.responseReceivedTime?o?e.startTime:Number.MAX_VALUE:e.responseReceivedTime,n=-1===e.endTime?Number.MAX_VALUE:e.endTime;r("total",t,n),r("blocking",t,s);return r(-1===e.responseReceivedTime?"connecting":"receiving",s,n),i}const l=e.issueTime(),d=a.requestTime,c=o([e.endTime,e.responseReceivedTime])||d;if(r("total",lt&&r("push",Math.max(a.pushStart,t),e)}le.start)).reduce(((e,t)=>Math.min(e,t))),c=a.map((e=>e.end)).reduce(((e,t)=>Math.max(e,t))),h=100/(c-l);let u,p,g,m,w=0;const k=s.createChild("thead","network-timing-start"),v=k.createChild("tr"),b=v.createChild("th");b.createChild("span","network-timing-hidden-header").textContent=wt(gt.label),b.scope="col";const f=v.createChild("th");f.createChild("span","network-timing-hidden-header").textContent=wt(gt.waterfall),f.scope="col";const C=v.createChild("th");C.createChild("span","network-timing-hidden-header").textContent=wt(gt.duration),C.scope="col";const S=k.createChild("tr").createChild("td"),y=k.createChild("tr").createChild("td");let T;S.colSpan=y.colSpan=3,e.UIUtils.createTextChild(S,wt(gt.queuedAtS,{PH1:o.formatValue(i.issueTime(),2)})),e.UIUtils.createTextChild(y,wt(gt.startedAtS,{PH1:o.formatValue(i.startTime,2)}));for(let t=0;t"total"!==e.metric.toLowerCase())).forEach((e=>H(e,L))),q.filter((e=>"total"===e.metric.toLowerCase())).forEach((e=>H(e,L))),s;function H(i,o){const n=new t.Color.Generator({min:0,max:360,count:36},{min:50,max:80,count:void 0},80),a="total"===i.metric.toLowerCase(),d=s.createChild("tr",a?"network-timing-footer":"server-timing-row"),u=d.createChild("td","network-timing-metric"),p=i.description||i.metric;e.UIUtils.createTextChild(u,p),e.Tooltip.Tooltip.install(u,p);const g=d.createChild("td").createChild("div","network-timing-row");if(null===i.value)return;const m=h*(c-l-i.value/1e3);if(m>=0){const e=g.createChild("span","network-timing-bar server-timing");e.style.left=m+"%",e.style.right=o+"%",e.textContent="​",a||(e.style.backgroundColor=n.colorForID(i.metric))}d.createChild("td").createChild("div","network-timing-bar-title").textContent=r.TimeUtilities.millisToString(i.value,!0)}function P(t){const i=s.createChild("tr","network-timing-table-header"),r=i.createChild("td");return e.UIUtils.createTextChild(r,t),e.ARIAUtils.markAsHeading(r,2),e.UIUtils.createTextChild(i.createChild("td"),""),e.UIUtils.createTextChild(i.createChild("td"),wt(gt.durationC)),i}}constructFetchDetailsView(){if(!this.tableElement)return;const t=this.tableElement.ownerDocument,i=t.querySelector(".network-fetch-timing-bar-details");if(!i)return;i.classList.add("network-fetch-timing-bar-details-collapsed"),self.onInvokeElement(this.tableElement,this.onToggleFetchDetails.bind(this,i));const r=new e.TreeOutline.TreeOutlineInShadow;i.appendChild(r.element);const o=a.NetworkLog.NetworkLog.instance().originalRequestForURL(this.request.url());if(o){const e=n.RemoteObject.RemoteObject.fromLocalObject(o),t=new x.ObjectPropertiesSection.RootElement(e);t.title=wt(gt.originalRequest),r.appendChild(t)}const s=a.NetworkLog.NetworkLog.instance().originalResponseForURL(this.request.url());if(s){const e=n.RemoteObject.RemoteObject.fromLocalObject(s),t=new x.ObjectPropertiesSection.RootElement(e);t.title=wt(gt.responseReceived),r.appendChild(t)}const l=t.createElement("div");l.classList.add("network-fetch-details-treeitem");let d=wt(gt.unknown);const c=this.request.serviceWorkerResponseSource();c&&(d=this.getLocalizedResponseSourceForCode(c)),l.textContent=wt(gt.sourceOfResponseS,{PH1:d});const h=new e.TreeOutline.TreeElement(l);r.appendChild(h);const u=t.createElement("div");u.classList.add("network-fetch-details-treeitem");const p=this.request.getResponseCacheStorageCacheName();u.textContent=p?wt(gt.cacheStorageCacheNameS,{PH1:p}):wt(gt.cacheStorageCacheNameUnknown);const g=new e.TreeOutline.TreeElement(u);r.appendChild(g);const m=this.request.getResponseRetrievalTime();if(m){const i=t.createElement("div");i.classList.add("network-fetch-details-treeitem"),i.textContent=wt(gt.retrievalTimeS,{PH1:m.toString()});const o=new e.TreeOutline.TreeElement(i);r.appendChild(o)}}getLocalizedResponseSourceForCode(e){switch(e){case"cache-storage":return wt(gt.serviceworkerCacheStorage);case"http-cache":return wt(gt.fromHttpCache);case"network":return wt(gt.networkFetch);default:return wt(gt.fallbackCode)}}onToggleFetchDetails(e,t){if(!t.target)return;const r=t.target;if(r.classList.contains("network-fetch-timing-bar-clickable")){e.classList.contains("network-fetch-timing-bar-details-collapsed")&&i.userMetrics.actionTaken(i.UserMetrics.Action.NetworkPanelServiceWorkerRespondWith);const t="true"===r.getAttribute("aria-checked");r.setAttribute("aria-checked",String(!t)),e.classList.toggle("network-fetch-timing-bar-details-collapsed"),e.classList.toggle("network-fetch-timing-bar-details-expanded")}}constructRouterEvaluationView(){if(!this.tableElement)return;const t=this.tableElement.querySelector(".router-evaluation-timing-bar-details");if(!t)return;t.classList.add("network-fetch-timing-bar-details-collapsed"),self.onInvokeElement(this.tableElement,this.onToggleRouterEvaluationDetails.bind(this,t));const i=new e.TreeOutline.TreeOutlineInShadow;t.appendChild(i.element);const{serviceWorkerRouterInfo:r}=this.request;if(!r)return;const o=this.tableElement.ownerDocument,s=o.createElement("div");s.classList.add("network-fetch-details-treeitem");const n=r.matchedSourceType,a=String(n)||wt(gt.unknown);s.textContent=wt(gt.routerMatchedSource,{PH1:a});const l=new e.TreeOutline.TreeElement(s);i.appendChild(l);const d=o.createElement("div");d.classList.add("network-fetch-details-treeitem");const c=r.actualSourceType,h=String(c)||wt(gt.unknown);d.textContent=wt(gt.routerActualSource,{PH1:h});const u=new e.TreeOutline.TreeElement(d);i.appendChild(u)}onToggleRouterEvaluationDetails(e,t){if(!t.target)return;const i=t.target;if(i.classList.contains("network-fetch-timing-bar-clickable")){const t="true"===i.getAttribute("aria-checked");i.setAttribute("aria-checked",String(!t)),e.classList.toggle("network-fetch-timing-bar-details-collapsed"),e.classList.toggle("network-fetch-timing-bar-details-expanded")}}wasShown(){this.request.addEventListener(n.NetworkRequest.Events.TIMING_CHANGED,this.refresh,this),this.request.addEventListener(n.NetworkRequest.Events.FINISHED_LOADING,this.refresh,this),this.calculator.addEventListener("BoundariesChanged",this.boundaryChanged,this),this.refresh()}willHide(){this.request.removeEventListener(n.NetworkRequest.Events.TIMING_CHANGED,this.refresh,this),this.request.removeEventListener(n.NetworkRequest.Events.FINISHED_LOADING,this.refresh,this),this.calculator.removeEventListener("BoundariesChanged",this.boundaryChanged,this)}refresh(){this.tableElement&&this.tableElement.remove(),this.tableElement=kt.createTimingTable(this.request,this.calculator),this.tableElement.classList.add("resource-timing-table"),this.element.appendChild(this.tableElement),this.request.fetchedViaServiceWorker&&this.constructFetchDetailsView(),this.request.serviceWorkerRouterInfo&&this.constructRouterEvaluationView()}boundaryChanged(){const e=this.calculator.minimumBoundary();e!==this.lastMinimumBoundary&&(this.lastMinimumBoundary=e,this.refresh())}}const vt=new Set(["serviceworker","serviceworker-preparation","serviceworker-respondwith","serviceworker-routerevaluation","serviceworker-cachelookup"]),bt=new Set(["queueing","blocking","connecting","dns","proxy","ssl"]);var ft=Object.freeze({__proto__:null,ConnectionSetupRangeNames:bt,RequestTimingView:kt,ServiceWorkerRangeNames:vt}),Ct={cssText:`.websocket-frame-view{user-select:text}.websocket-frame-view .data-grid{flex:auto;border:none}.websocket-frame-view .data-grid .data{background-image:none}.websocket-frame-view-td{border-bottom:1px solid var(--sys-color-divider)}.websocket-frame-view .data-grid td,\n.websocket-frame-view .data-grid th{border-left-color:1px solid var(--sys-color-divider)}.websocket-frame-view-row-send td:first-child::before{content:"\\2B06";color:var(--sys-color-tertiary);padding-right:4px}.websocket-frame-view-row-receive td:first-child::before{content:"\\2B07";color:var(--sys-color-error);padding-right:4px}.websocket-frame-view-row-send{background-color:color-mix(in srgb,var(--sys-color-tertiary-container),transparent 50%)}.websocket-frame-view-row-error{background-color:var(--sys-color-surface-error);color:var(--sys-color-on-surface-error)}.websocket-frame-view devtools-toolbar{border-bottom:1px solid var(--sys-color-divider)}\n/*# sourceURL=${import.meta.resolve("./webSocketFrameView.css")} */\n`};const St={data:"Data",length:"Length",time:"Time",webSocketFrame:"Web Socket Frame",clearAll:"Clear All",filter:"Filter",noMessageSelected:"No message selected",selectMessageToBrowseItsContent:"Select message to browse its content.",copyMessageD:"Copy message...",copyMessage:"Copy message",clearAllL:"Clear all",sOpcodeSMask:"{PH1} (Opcode {PH2}, mask)",sOpcodeS:"{PH1} (Opcode {PH2})",continuationFrame:"Continuation Frame",textMessage:"Text Message",binaryMessage:"Binary Message",connectionCloseMessage:"Connection Close Message",pingMessage:"Ping Message",pongMessage:"Pong Message",all:"All",send:"Send",receive:"Receive",na:"N/A",filterUsingRegex:"Filter using regex (example: (web)?socket)"},yt=r.i18n.registerUIStrings("panels/network/ResourceWebSocketFrameView.ts",St),Tt=r.i18n.getLocalizedString.bind(void 0,yt),xt=r.i18n.getLazilyComputedLocalizedString.bind(void 0,yt);class Rt extends e.Widget.VBox{request;splitWidget;dataGrid;timeComparator;mainToolbar;clearAllButton;filterTypeCombobox;filterType;filterTextInput;filterRegex;frameEmptyWidget;selectedNode;currentSelectedNode;messageFilterSetting=t.Settings.Settings.instance().createSetting("network-web-socket-message-filter","");constructor(t){super(),this.registerRequiredCSS(Ct),this.element.classList.add("websocket-frame-view"),this.element.setAttribute("jslog",`${d.pane("web-socket-messages").track({resize:!0})}`),this.request=t,this.splitWidget=new e.SplitWidget.SplitWidget(!1,!0,"resource-web-socket-frame-split-view-state"),this.splitWidget.show(this.element);const r=[{id:"data",title:Tt(St.data),sortable:!1,weight:88},{id:"length",title:Tt(St.length),sortable:!1,align:"right",weight:5},{id:"time",title:Tt(St.time),sortable:!0,weight:7}];this.dataGrid=new c.SortableDataGrid.SortableDataGrid({displayName:Tt(St.webSocketFrame),columns:r,deleteCallback:void 0,refreshCallback:void 0}),this.dataGrid.setRowContextMenuCallback(function(e,t){const r=t,o=r.binaryView();o?o.addCopyToContextMenu(e,Tt(St.copyMessageD)):e.clipboardSection().appendItem(Tt(St.copyMessage),i.InspectorFrontendHost.InspectorFrontendHostInstance.copyText.bind(i.InspectorFrontendHost.InspectorFrontendHostInstance,r.data.data),{jslogContext:"copy"});e.footerSection().appendItem(Tt(St.clearAllL),this.clearFrames.bind(this),{jslogContext:"clear-all"})}.bind(this)),this.dataGrid.setEnableAutoScrollToBottom(!0),this.dataGrid.setCellClass("websocket-frame-view-td"),this.timeComparator=Ft,this.dataGrid.sortNodes(this.timeComparator,!1),this.dataGrid.markColumnAsSortedBy("time",c.DataGrid.Order.Ascending),this.dataGrid.addEventListener("SortingChanged",this.sortItems,this),this.dataGrid.setName("resource-web-socket-frame-view"),this.dataGrid.addEventListener("SelectedNode",(e=>{this.onFrameSelected(e)}),this),this.dataGrid.addEventListener("DeselectedNode",this.onFrameDeselected,this),this.mainToolbar=document.createElement("devtools-toolbar"),this.clearAllButton=new e.Toolbar.ToolbarButton(Tt(St.clearAll),"clear"),this.clearAllButton.addEventListener("Click",this.clearFrames,this),this.mainToolbar.appendToolbarItem(this.clearAllButton),this.filterTypeCombobox=new e.Toolbar.ToolbarComboBox(this.updateFilterSetting.bind(this),Tt(St.filter));for(const e of qt){const t=this.filterTypeCombobox.createOption(e.label(),e.name);this.filterTypeCombobox.addOption(t)}this.mainToolbar.appendToolbarItem(this.filterTypeCombobox),this.filterType=null;const o=Tt(St.filterUsingRegex);this.filterTextInput=new e.Toolbar.ToolbarFilter(o,.4),this.filterTextInput.addEventListener("TextChanged",this.updateFilterSetting,this);const s=this.messageFilterSetting.get();s&&this.filterTextInput.setValue(s),this.filterRegex=null,this.mainToolbar.appendToolbarItem(this.filterTextInput);const n=new e.Widget.VBox;n.element.appendChild(this.mainToolbar),this.dataGrid.asWidget().show(n.element),n.setMinimumSize(0,72),this.splitWidget.setMainWidget(n),this.frameEmptyWidget=new e.EmptyWidget.EmptyWidget(Tt(St.noMessageSelected),Tt(St.selectMessageToBrowseItsContent)),this.splitWidget.setSidebarWidget(this.frameEmptyWidget),this.selectedNode=null,s&&this.applyFilter(s)}static opCodeDescription(e,t){const i=It[e]||(()=>"");return Tt(t?St.sOpcodeSMask:St.sOpcodeS,{PH1:i(),PH2:e})}wasShown(){super.wasShown(),this.refresh(),this.request.addEventListener(n.NetworkRequest.Events.WEBSOCKET_FRAME_ADDED,this.frameAdded,this)}willHide(){this.request.removeEventListener(n.NetworkRequest.Events.WEBSOCKET_FRAME_ADDED,this.frameAdded,this)}frameAdded(e){const t=e.data;this.frameFilter(t)&&this.dataGrid.insertChild(new Lt(this.request.url(),t))}frameFilter(e){return(!this.filterType||e.type===this.filterType)&&(!this.filterRegex||this.filterRegex.test(e.text))}clearFrames(){Et.set(this.request,this.request.frames().length),this.refresh()}updateFilterSetting(){const e=this.filterTextInput.value();this.messageFilterSetting.set(e),this.applyFilter(e)}applyFilter(e){const t=this.filterTypeCombobox.selectedOption().value;if(e)try{this.filterRegex=new RegExp(e,"i")}catch{this.filterRegex=new RegExp(s.StringUtilities.escapeForRegExp(e),"i")}else this.filterRegex=null;this.filterType="all"===t?null:t,this.refresh()}async onFrameSelected(e){this.currentSelectedNode=e.data;const i=this.currentSelectedNode.dataText(),r=this.currentSelectedNode.binaryView();if(r)return void this.splitWidget.setSidebarWidget(r);const s=await o.JSONView.JSONView.createView(i);s?this.splitWidget.setSidebarWidget(s):this.splitWidget.setSidebarWidget(new o.ResourceSourceFrame.ResourceSourceFrame(R.StaticContentProvider.StaticContentProvider.fromString(this.request.url(),t.ResourceType.resourceTypes.WebSocket,i),""))}onFrameDeselected(){this.currentSelectedNode=null,this.splitWidget.setSidebarWidget(this.frameEmptyWidget)}refresh(){this.dataGrid.rootNode().removeChildren();const e=this.request.url();let t=this.request.frames();const i=Et.get(this.request)||0;t=t.slice(i),t=t.filter(this.frameFilter.bind(this)),t.forEach((t=>this.dataGrid.insertChild(new Lt(e,t))))}sortItems(){this.dataGrid.sortNodes(this.timeComparator,!this.dataGrid.isSortOrderAscending())}}const It=function(){const e=[];return e[0]=xt(St.continuationFrame),e[1]=xt(St.textMessage),e[2]=xt(St.binaryMessage),e[8]=xt(St.connectionCloseMessage),e[9]=xt(St.pingMessage),e[10]=xt(St.pongMessage),e}(),qt=[{name:"all",label:xt(St.all),jslogContext:"all"},{name:"send",label:xt(St.send),jslogContext:"send"},{name:"receive",label:xt(St.receive),jslogContext:"receive"}];class Lt extends c.SortableDataGrid.SortableDataGridNode{url;frame;isTextFrame;dataTextInternal;binaryViewInternal;constructor(t,i){let o=String(i.text.length);const a=new Date(1e3*i.time),l=("0"+a.getHours()).substr(-2)+":"+("0"+a.getMinutes()).substr(-2)+":"+("0"+a.getSeconds()).substr(-2)+"."+("00"+a.getMilliseconds()).substr(-3),d=document.createElement("div");e.UIUtils.createTextChild(d,l),e.Tooltip.Tooltip.install(d,a.toLocaleString());let c=i.text,h=Rt.opCodeDescription(i.opCode,i.mask);const u=1===i.opCode;i.type===n.NetworkRequest.WebSocketFrameType.Error?(h=c,o=Tt(St.na)):u?h=c:2===i.opCode?(o=r.ByteUtilities.bytesToString(s.StringUtilities.base64ToSize(i.text)),h=It[i.opCode]()):c=h,super({data:h,length:o,time:d}),this.url=t,this.frame=i,this.isTextFrame=u,this.dataTextInternal=c,this.binaryViewInternal=null}createCells(e){e.classList.toggle("websocket-frame-view-row-error",this.frame.type===n.NetworkRequest.WebSocketFrameType.Error),e.classList.toggle("websocket-frame-view-row-send",this.frame.type===n.NetworkRequest.WebSocketFrameType.Send),e.classList.toggle("websocket-frame-view-row-receive",this.frame.type===n.NetworkRequest.WebSocketFrameType.Receive),super.createCells(e)}nodeSelfHeight(){return 21}dataText(){return this.dataTextInternal}opCode(){return this.frame.opCode}binaryView(){return this.isTextFrame||this.frame.type===n.NetworkRequest.WebSocketFrameType.Error?null:(this.binaryViewInternal||this.dataTextInternal.length>0&&(this.binaryViewInternal=new V(R.StreamingContentData.StreamingContentData.from(new R.ContentData.ContentData(this.dataTextInternal,!0,"applicaiton/octet-stream")),s.DevToolsPath.EmptyUrlString,t.ResourceType.resourceTypes.WebSocket)),this.binaryViewInternal)}}function Ft(e,t){return e.frame.time-t.frame.time}const Et=new WeakMap;var Ht=Object.freeze({__proto__:null,ResourceWebSocketFrameNode:Lt,ResourceWebSocketFrameView:Rt,opCodeDescriptions:It});const Pt={headers:"Headers",payload:"Payload",messages:"Messages",websocketMessages:"WebSocket messages",eventstream:"EventStream",preview:"Preview",responsePreview:"Response preview",signedexchangeError:"SignedExchange error",response:"Response",rawResponseData:"Raw response data",initiator:"Initiator",requestInitiatorCallStack:"Request initiator call stack",timing:"Timing",requestAndResponseTimeline:"Request and response timeline",thirdPartyPhaseout:"Cookies blocked due to third-party cookie phaseout.",trustTokens:"Private state tokens",trustTokenOperationDetails:"Private State Token operation details",cookies:"Cookies",requestAndResponseCookies:"Request and response cookies",containsOverriddenHeaders:"This response contains headers which are overridden by DevTools",responseIsOverridden:"This response is overridden by DevTools"},Mt=r.i18n.registerUIStrings("panels/network/NetworkItemView.ts",Pt),At=r.i18n.getLocalizedString.bind(void 0,Mt);class Nt extends e.TabbedPane.TabbedPane{requestInternal;resourceViewTabSetting;headersViewComponent;payloadView;responseView;cookiesView;initialTab;isReactNative=!1;constructor(i,r,o){super(),this.isReactNative=C.Runtime.experiments.isEnabled("react-native-specific-ui"),this.requestInternal=i,this.element.classList.add("network-item-view"),this.headerElement().setAttribute("jslog",`${d.toolbar("request-details").track({keydown:"ArrowUp|ArrowLeft|ArrowDown|ArrowRight|Enter|Space"})}`);if(this.resourceViewTabSetting=t.Settings.Settings.instance().createSetting("resource-view-tab","headers-component"),this.headersViewComponent=new y.RequestHeadersView.RequestHeadersView(i),this.appendTab("headers-component",At(Pt.headers),S.LegacyWrapper.legacyWrapper(e.Widget.VBox,this.headersViewComponent),At(Pt.headers)),this.requestInternal.hasOverriddenHeaders()){const e=document.createElement("div");e.className="status-dot",e.title=At(Pt.containsOverriddenHeaders),this.setSuffixElement("headers-component",e)}if(this.payloadView=null,this.maybeAppendPayloadPanel(),this.addEventListener(e.TabbedPane.Events.TabSelected,this.tabSelected,this),i.resourceType()===t.ResourceType.resourceTypes.WebSocket){const e=new Rt(i);this.appendTab("web-socket-frames",At(Pt.messages),e,At(Pt.websocketMessages))}else if("text/event-stream"===i.mimeType)this.appendTab("eventSource",At(Pt.eventstream),new Q(i)),this.responseView=new Ye(i),this.appendTab("response",At(Pt.response),this.responseView,At(Pt.rawResponseData));else{this.responseView=new Ye(i);const t=new ht(i);this.appendTab("preview",At(Pt.preview),t,At(Pt.responsePreview));const r=i.signedExchangeInfo();if(r?.errors?.length){const t=new k.Icon.Icon;t.data={iconName:"cross-circle-filled",color:"var(--icon-error)",width:"14px",height:"14px"},e.Tooltip.Tooltip.install(t,At(Pt.signedexchangeError)),this.setTabIcon("preview",t)}if(this.appendTab("response",At(Pt.response),this.responseView,At(Pt.rawResponseData)),this.requestInternal.hasOverriddenContent){const e=document.createElement("div");e.className="status-dot",e.title=At(Pt.responseIsOverridden),this.setSuffixElement("response",e)}}this.isReactNative||this.appendTab("initiator",At(Pt.initiator),new He(i),At(Pt.requestInitiatorCallStack)),this.appendTab("timing",At(Pt.timing),new kt(i,r),At(Pt.requestAndResponseTimeline)),i.trustTokenParams()&&this.appendTab("trust-tokens",At(Pt.trustTokens),S.LegacyWrapper.legacyWrapper(e.Widget.VBox,new y.RequestTrustTokensView.RequestTrustTokensView(i)),At(Pt.trustTokenOperationDetails)),this.cookiesView=null,this.initialTab=o||this.resourceViewTabSetting.get(),this.setAutoSelectFirstItemOnShow(!1)}wasShown(){super.wasShown(),this.requestInternal.addEventListener(n.NetworkRequest.Events.REQUEST_HEADERS_CHANGED,this.requestHeadersChanged,this),this.requestInternal.addEventListener(n.NetworkRequest.Events.RESPONSE_HEADERS_CHANGED,this.maybeAppendCookiesPanel,this),this.requestInternal.addEventListener(n.NetworkRequest.Events.TRUST_TOKEN_RESULT_ADDED,this.maybeShowErrorIconInTrustTokenTabHeader,this),this.maybeAppendCookiesPanel(),this.maybeShowErrorIconInTrustTokenTabHeader(),this.initialTab&&(this.selectTabInternal(this.initialTab),this.initialTab=void 0)}willHide(){this.requestInternal.removeEventListener(n.NetworkRequest.Events.REQUEST_HEADERS_CHANGED,this.requestHeadersChanged,this),this.requestInternal.removeEventListener(n.NetworkRequest.Events.RESPONSE_HEADERS_CHANGED,this.maybeAppendCookiesPanel,this),this.requestInternal.removeEventListener(n.NetworkRequest.Events.TRUST_TOKEN_RESULT_ADDED,this.maybeShowErrorIconInTrustTokenTabHeader,this)}async requestHeadersChanged(){this.maybeAppendCookiesPanel(),this.maybeAppendPayloadPanel()}maybeAppendCookiesPanel(){const e=this.requestInternal.hasRequestCookies()||this.requestInternal.responseCookies.length>0;if(console.assert(e||!this.cookiesView,"Cookies were introduced in headers and then removed!"),e&&!this.cookiesView&&(this.cookiesView=new xe(this.requestInternal),this.appendTab("cookies",At(Pt.cookies),this.cookiesView,At(Pt.requestAndResponseCookies))),this.requestInternal.hasThirdPartyCookiePhaseoutIssue()){const e=new k.Icon.Icon;e.data={iconName:"warning-filled",color:"var(--icon-warning)",width:"14px",height:"14px"},e.title=At(Pt.thirdPartyPhaseout),this.setTrailingTabIcon("cookies",e)}}async maybeAppendPayloadPanel(){this.hasTab("payload")||(this.requestInternal.queryParameters||await this.requestInternal.requestFormData())&&(this.payloadView=new Oe(this.requestInternal),this.appendTab("payload",At(Pt.payload),this.payloadView,At(Pt.payload),void 0,void 0,void 0,1))}maybeShowErrorIconInTrustTokenTabHeader(){const e=this.requestInternal.trustTokenOperationDoneEvent();if(e&&!y.RequestTrustTokensView.statusConsideredSuccess(e.status)){const e=new k.Icon.Icon;e.data={iconName:"cross-circle-filled",color:"var(--icon-error)",width:"14px",height:"14px"},this.setTabIcon("trust-tokens",e)}}selectTabInternal(e){this.selectTab(e)||window.setTimeout((()=>{this.selectTab(e)||this.selectTab("headers-component")}),0)}tabSelected(e){e.data.isUserGesture&&this.resourceViewTabSetting.set(e.data.tabId)}request(){return this.requestInternal}async revealResponseBody(e){this.selectTabInternal("response"),await(this.responseView?.revealPosition(e))}revealHeader(e,t){this.selectTabInternal("headers-component"),this.headersViewComponent.revealHeader(e,t)}getHeadersViewComponent(){return this.headersViewComponent}}var Ut=Object.freeze({__proto__:null,NetworkItemView:Nt});const Bt={sLatencySDownloadSTotal:"{PH1} latency, {PH2} download ({PH3} total)",sLatency:"{PH1} latency",sDownload:"{PH1} download",sFromServiceworker:"{PH1} (from `ServiceWorker`)",sFromCache:"{PH1} (from cache)"},Vt=r.i18n.registerUIStrings("panels/network/NetworkTimeCalculator.ts",Bt),Wt=r.i18n.getLocalizedString.bind(void 0,Vt);class Ot{minimum;maximum;constructor(e,t){this.minimum=e,this.maximum=t}equals(e){return this.minimum===e.minimum&&this.maximum===e.maximum}}class Dt extends t.ObjectWrapper.ObjectWrapper{startAtZero;minimumBoundaryInternal;maximumBoundaryInternal;boundryChangedEventThrottler;window;workingArea;constructor(e){super(),this.startAtZero=e,this.minimumBoundaryInternal=-1,this.maximumBoundaryInternal=-1,this.boundryChangedEventThrottler=new t.Throttler.Throttler(0),this.window=null}setWindow(e){this.window=e,this.boundaryChanged()}computePosition(e){return(e-this.minimumBoundary())/this.boundarySpan()*(this.workingArea||0)}formatValue(e,t){return r.TimeUtilities.secondsToString(e,Boolean(t))}minimumBoundary(){return this.window?this.window.minimum:this.minimumBoundaryInternal}zeroTime(){return this.minimumBoundaryInternal}maximumBoundary(){return this.window?this.window.maximum:this.maximumBoundaryInternal}boundary(){return new Ot(this.minimumBoundary(),this.maximumBoundary())}boundarySpan(){return this.maximumBoundary()-this.minimumBoundary()}reset(){this.minimumBoundaryInternal=-1,this.maximumBoundaryInternal=-1,this.boundaryChanged()}value(){return 0}setDisplayWidth(e){this.workingArea=e}computeBarGraphPercentages(e){let t,i,r;return t=-1!==e.startTime?(e.startTime-this.minimumBoundary())/this.boundarySpan()*100:0,i=-1!==e.responseReceivedTime?(e.responseReceivedTime-this.minimumBoundary())/this.boundarySpan()*100:this.startAtZero?t:100,r=-1!==e.endTime?(e.endTime-this.minimumBoundary())/this.boundarySpan()*100:this.startAtZero?i:100,this.startAtZero&&(r-=t,i-=t,t=0),{start:t,middle:i,end:r}}boundaryChanged(){this.boundryChangedEventThrottler.schedule((async()=>{this.dispatchEventToListeners("BoundariesChanged")}))}updateBoundariesForEventTime(e){-1===e||this.startAtZero||(void 0===this.maximumBoundaryInternal||e>this.maximumBoundaryInternal)&&(this.maximumBoundaryInternal=e,this.boundaryChanged())}computeBarGraphLabels(e){let t="";-1!==e.responseReceivedTime&&-1!==e.endTime&&(t=r.TimeUtilities.secondsToString(e.endTime-e.responseReceivedTime));const i=e.latency>0,o=i?r.TimeUtilities.secondsToString(e.latency):t;if(e.timing)return{left:o,right:t,tooltip:void 0};let s;if(i&&t){const i=r.TimeUtilities.secondsToString(e.duration);s=Wt(Bt.sLatencySDownloadSTotal,{PH1:o,PH2:t,PH3:i})}else i?s=Wt(Bt.sLatency,{PH1:o}):t&&(s=Wt(Bt.sDownload,{PH1:t}));return e.fetchedViaServiceWorker?s=Wt(Bt.sFromServiceworker,{PH1:String(s)}):e.cached()&&(s=Wt(Bt.sFromCache,{PH1:String(s)})),{left:o,right:t,tooltip:s}}updateBoundaries(e){const t=this.lowerBound(e),i=this.upperBound(e);let r=!1;(-1!==t||this.startAtZero)&&(r=this.extendBoundariesToIncludeTimestamp(this.startAtZero?0:t)),-1!==i&&(r=this.extendBoundariesToIncludeTimestamp(i)||r),r&&this.boundaryChanged()}extendBoundariesToIncludeTimestamp(e){const t=this.minimumBoundaryInternal,i=this.maximumBoundaryInternal,r=Gt;return-1===this.minimumBoundaryInternal||-1===this.maximumBoundaryInternal?(this.minimumBoundaryInternal=e,this.maximumBoundaryInternal=e+r):(this.minimumBoundaryInternal=Math.min(e,this.minimumBoundaryInternal),this.maximumBoundaryInternal=Math.max(e,this.minimumBoundaryInternal+r,this.maximumBoundaryInternal)),t!==this.minimumBoundaryInternal||i!==this.maximumBoundaryInternal}lowerBound(e){return 0}upperBound(e){return 0}}const Gt=.1;class jt extends Dt{constructor(){super(!1)}formatValue(e,t){return r.TimeUtilities.secondsToString(e-this.zeroTime(),Boolean(t))}lowerBound(e){return e.issueTime()}upperBound(e){return e.endTime}}class zt extends Dt{constructor(){super(!0)}formatValue(e,t){return r.TimeUtilities.secondsToString(e,Boolean(t))}upperBound(e){return e.duration}}var _t=Object.freeze({__proto__:null,NetworkTimeBoundary:Ot,NetworkTimeCalculator:Dt,NetworkTransferDurationCalculator:zt,NetworkTransferTimeCalculator:jt});class Kt{parentView;activeGroups;constructor(e){this.parentView=e,this.activeGroups=new Map}groupNodeForRequest(e){const t=n.ResourceTreeModel.ResourceTreeModel.frameForRequest(e);if(!t||t.isOutermostFrame())return null;let i=this.activeGroups.get(t);return i||(i=new $t(this.parentView,t),this.activeGroups.set(t,i),i)}reset(){this.activeGroups.clear()}}class $t extends be{frame;constructor(e,t){super(e),this.frame=t}displayName(){return new t.ParsedURL.ParsedURL(this.frame.url).domain()||this.frame.name||"