Skip to content

Commit

Permalink
feat(trace): Trace view synchronization. Allow trace.enable(...string)
Browse files Browse the repository at this point in the history
- Allow trace.enable(...number)
  • Loading branch information
christopherthielen authored and wawyed committed Mar 3, 2018
1 parent f36c326 commit a4f5bbf
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 14 deletions.
40 changes: 28 additions & 12 deletions src/common/trace.ts
Original file line number Diff line number Diff line change
Expand Up @@ -46,17 +46,18 @@ import {HookResult} from "../transition/interface";
import {StateObject} from "../state/stateObject";

/** @hidden */
function uiViewString (viewData: ActiveUIView) {
if (!viewData) return 'ui-view (defunct)';
return `[ui-view#${viewData.id} tag ` +
`in template from '${viewData.creationContext && viewData.creationContext.name || '(root)'}' state]: ` +
`fqn: '${viewData.fqn}', ` +
`name: '${viewData.name}@${viewData.creationContext}')`;
function uiViewString (uiview: ActiveUIView) {
if (!uiview) return 'ui-view (defunct)';
const state = uiview.creationContext ? uiview.creationContext.name || '(root)' : '(none)';
return `[ui-view#${uiview.id} ${uiview.$type}:${uiview.fqn} (${uiview.name}@${state})]`;
}

/** @hidden */
const viewConfigString = (viewConfig: ViewConfig) =>
`[ViewConfig#${viewConfig.$id} from '${viewConfig.viewDecl.$context.name || '(root)'}' state]: target ui-view: '${viewConfig.viewDecl.$uiViewName}@${viewConfig.viewDecl.$uiViewContextAnchor}'`;
const viewConfigString = (viewConfig: ViewConfig) => {
let view = viewConfig.viewDecl;
const state = view.$context.name || '(root)';
return `[View#${viewConfig.$id} from '${state}' state]: target ui-view: '${view.$uiViewName}@${view.$uiViewContextAnchor}'`;
};

/** @hidden */
function normalizedCat(input: Category|string): string {
Expand All @@ -78,7 +79,7 @@ function normalizedCat(input: Category|string): string {
* `trace.enable(1)`
*/
export enum Category {
RESOLVE, TRANSITION, HOOK, UIVIEW, VIEWCONFIG
RESOLVE, TRANSITION, HOOK, UIVIEW, VIEWCONFIG,
}

/** @hidden */ const _tid = parse("$id");
Expand Down Expand Up @@ -121,7 +122,8 @@ export class Trace {
* @param categories categories to enable. If `categories` is omitted, all categories are enabled.
* Also takes strings (category name) or ordinal (category position)
*/
enable(...categories: Category[]) { this._set(true, categories) }
enable(...categories: (Category|string|number)[]);
enable(...categories: any[]) { this._set(true, categories); }
/**
* Disables a trace [[Category]]
*
Expand All @@ -132,7 +134,8 @@ export class Trace {
* @param categories categories to disable. If `categories` is omitted, all categories are disabled.
* Also takes strings (category name) or ordinal (category position)
*/
disable(...categories: Category[]) { this._set(false, categories) }
disable(...categories: (Category|string|number)[]);
disable(...categories: any[]) { this._set(false, categories); }

/**
* Retrieves the enabled stateus of a [[Category]]
Expand All @@ -143,7 +146,7 @@ export class Trace {
*
* @returns boolean true if the category is enabled
*/
enabled(category: Category): boolean {
enabled(category: (Category|string|number)): boolean {
return !!this._enabled[normalizedCat(category)];
}

Expand Down Expand Up @@ -216,6 +219,19 @@ export class Trace {
this.traceUIViewEvent("Fill", viewData, ` with: ${maxLength(200, html)}`);
}

/** @internalapi called by ui-router code */
traceViewSync(pairs: any[]) {
if (!this.enabled(Category.VIEWCONFIG)) return;
const mapping = pairs.map(([ uiViewData, config ]) => {
const uiView = `${uiViewData.$type}:${uiViewData.fqn}`;
const view = config && `${config.viewDecl.$context.name}: ${config.viewDecl.$name} (${config.viewDecl.$type})`;

return { 'ui-view fqn': uiView, 'state: view name': view };
}).sort((a, b) => a['ui-view fqn'].localeCompare(b['ui-view fqn']));

console.table(mapping);
}

/** @internalapi called by ui-router code */
traceViewServiceEvent(event: string, viewConfig: ViewConfig) {
if (!this.enabled(Category.VIEWCONFIG)) return;
Expand Down
8 changes: 6 additions & 2 deletions src/view/view.ts
Original file line number Diff line number Diff line change
Expand Up @@ -161,7 +161,7 @@ export class ViewService {
let fqnToFirstSegment = uivSegments.slice(0, negOffset).join(".");
let uiViewContext = uiViewsByFqn[fqnToFirstSegment].creationContext;
return vc.$uiViewContextAnchor === (uiViewContext && uiViewContext.name);
};
}

sync() {
let uiViewsByFqn: TypedMap<ActiveUIView> =
Expand Down Expand Up @@ -205,7 +205,11 @@ export class ViewService {
};

// Sort views by FQN and state depth. Process uiviews nearest the root first.
this._uiViews.sort(depthCompare(uiViewDepth, 1)).map(matchingConfigPair).forEach(configureUIView);
const pairs = this._uiViews.sort(depthCompare(uiViewDepth, 1)).map(matchingConfigPair);

trace.traceViewSync(pairs);

pairs.forEach(configureUIView);
};

/**
Expand Down

0 comments on commit a4f5bbf

Please sign in to comment.