Skip to content

Commit

Permalink
Issue #386 [Enhancement][WIP] Add tooltips to dependency-graph nodes
Browse files Browse the repository at this point in the history
  • Loading branch information
t2ym committed Oct 3, 2020
1 parent 1fa4e46 commit e8eebee
Show file tree
Hide file tree
Showing 3 changed files with 14,260 additions and 426 deletions.
144 changes: 141 additions & 3 deletions demo-config/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,17 +47,155 @@ class TargetConfig extends Traceable(Configurable(GulpDefaultRegistry, 'thin-hoo
' edge [fontsize=10]\n' +
' \n',
footer: '\n}\n',
tooltip: (type, name) => {
let tooltip = '';
switch (type) {
case 'plugin':
tooltip = name + '\\n' + [...this.trace.log[name]].map(log => {
log = log.replace(/"/g, '\\"');
let match;
if (match = log.match(/^(.*) r$/)) {
return `-> ${match[1]}`;
}
else if (match = log.match(/^(.*) w$/)) {
return `<- ${match[1]}`;
}
else if (match = log.match(/^(.*) set$/)) {
return `<- ${match[1]}`;
}
else {
return `-> ${log}`;
}
})
.sort((a, b) => {
if (a.startsWith('<-') && b.startsWith('->')) {
return -1;
}
else if (a.startsWith('->') && b.startsWith('<-')) {
return 1;
}
else {
return a.localeCompare(b);
}
})
.join('\\n')
break;
case 'file':
{
tooltip = name + '\\n';
let plugins = [];
for (let plugin in this.trace.log) {
let traceLog = this.trace.log[plugin];
for (let log of traceLog) {
//console.log(plugin, log, name)
let match = log.match(/^(.*)( r| w| set)$/);
let key = log;
let type = '';
if (match) {
key = match[1];
type = match[2];
}
key = key.replace(/"/g, '\\"');
if (name === key) {
switch (type) {
default:
case '':
plugins.push(`<- ${plugin}`);
break;
case ' set':
plugins.push(`-> ${plugin}`);
break;
case ' r':
plugins.push(`<- ${plugin}`);
break;
case ' w':
plugins.push(`-> ${plugin}`);
break;
}
}
}
}
tooltip += plugins
.sort((a, b) => {
if (a.startsWith('<-') && b.startsWith('->')) {
return -1;
}
else if (a.startsWith('->') && b.startsWith('<-')) {
return 1;
}
else {
return a.localeCompare(b);
}
})
.join('\\n')
}
break;
case 'property':
{
tooltip = name + '\\n';
let plugins = [];
for (let plugin in this.trace.log) {
let traceLog = this.trace.log[plugin];
for (let log of traceLog) {
//console.log(plugin, log, name)
let match = log.match(/^(.*)( r| w| set)$/);
let key = log;
let type = '';
if (match) {
key = match[1];
type = match[2];
}
key = key.replace(/"/g, '\\"');
if (name === key) {
switch (type) {
default:
case '':
plugins.push(`<- ${plugin}`);
break;
case ' set':
plugins.push(`-> ${plugin}`);
break;
case ' r':
plugins.push(`<- ${plugin}`);
break;
case ' w':
plugins.push(`-> ${plugin}`);
break;
}
}
}
}
tooltip += plugins
.sort((a, b) => {
if (a.startsWith('<-') && b.startsWith('->')) {
return -1;
}
else if (a.startsWith('->') && b.startsWith('<-')) {
return 1;
}
else {
return a.localeCompare(b);
}
})
.join('\\n')
}
break;
}
return tooltip;
},
focus: (pluginName, propertyName, fileName) =>
!(pluginName === 'dependency-graph' ||
(fileName && fileName.indexOf("dependency-graph") >= 0) ||
(propertyName && propertyName.indexOf("dependency-graph") >= 0)),
plugin: (pluginName) => this.trace.dot.focus(pluginName, null, null)
? `\n "${pluginName}"[color="0.590 0.273 1.000"]\n`
? `\n "${pluginName}"[color="0.590 0.273 1.000",tooltip="${this.trace.dot.tooltip('plugin', pluginName)}"]\n`
: '',
file: (fileName) => this.trace.dot.focus(null, null, fileName)
? ` "${fileName}"[color="0.408 0.498 1.000"]\n`
? ` "${fileName}"[color="0.408 0.498 1.000",tooltip="${this.trace.dot.tooltip('file', fileName)}"]\n`
: '',
property: (propertyName) => this.trace.dot.focus(null, propertyName, null)
? ` "${propertyName}"[tooltip="${this.trace.dot.tooltip('property', propertyName)}"]\n`
: '',
property: (propertyName) => ``,
writeProperty: (propertyName, pluginName) => this.trace.dot.focus(pluginName, propertyName, null)
? ` "${propertyName}" -> "${pluginName}"[color="0.002 0.999 0.999"]\n`
: '',
Expand Down
Loading

0 comments on commit e8eebee

Please sign in to comment.