parent
cdea23d1bb
commit
801fc5a352
@ -44,6 +44,10 @@
|
||||
{
|
||||
"command": "xmlTools.executeXQuery",
|
||||
"title": "XML Tools: Execute XQuery"
|
||||
},
|
||||
{
|
||||
"command": "xmlTools.viewXmlTree",
|
||||
"title": "XML Tools: View XML Tree"
|
||||
}
|
||||
],
|
||||
"configuration": {
|
||||
@ -113,7 +117,8 @@
|
||||
"onLanguage:xquery",
|
||||
"onCommand:xmlTools.minifyXml",
|
||||
"onCommand:xmlTools.evaluateXPath",
|
||||
"onCommand:xmlTools.executeXQuery"
|
||||
"onCommand:xmlTools.executeXQuery",
|
||||
"onCommand:xmlTools.viewXmlTree"
|
||||
],
|
||||
"devDependencies": {
|
||||
"vscode": "^0.11.x",
|
||||
|
@ -7,6 +7,7 @@ import { RangeUtil } from './utils/RangeUtil';
|
||||
import { XmlFormatter } from './services/XmlFormatter';
|
||||
import { XPathFeatureProvider } from './providers/XPath';
|
||||
import { XQueryExecutionProvider } from './providers/Execution';
|
||||
import { XmlTreeDocumentContentProvider } from './providers/Content';
|
||||
|
||||
const CFG_SECTION: string = 'xmlTools';
|
||||
const CFG_REMOVE_COMMENTS: string = 'removeCommentsOnMinify';
|
||||
@ -30,4 +31,17 @@ export class TextEditorCommands {
|
||||
static executeXQuery(editor: vsc.TextEditor, edit: vsc.TextEditorEdit): void {
|
||||
XQueryExecutionProvider.executeXQueryAsync(editor);
|
||||
}
|
||||
|
||||
static async viewXmlTree(editor: vsc.TextEditor, edit: vsc.TextEditorEdit): Promise<void> {
|
||||
try {
|
||||
await vsc.commands.executeCommand(
|
||||
'vscode.previewHtml',
|
||||
XmlTreeDocumentContentProvider.buildUri(editor.document.uri),
|
||||
vsc.ViewColumn.Three);
|
||||
}
|
||||
|
||||
catch (error) {
|
||||
vsc.window.showErrorMessage(`The XML Tree could not be created: ${error}`);
|
||||
}
|
||||
}
|
||||
}
|
@ -5,6 +5,7 @@ import { TextEditorCommands } from './Commands';
|
||||
import { XmlFormattingEditProvider } from './providers/Formatting';
|
||||
import { XQueryLintingFeatureProvider } from './providers/Linting';
|
||||
import { XQueryCompletionItemProvider } from './providers/Completion';
|
||||
import { XmlTreeDocumentContentProvider } from './providers/Content';
|
||||
|
||||
export var GlobalState: vsc.Memento;
|
||||
export var WorkspaceState: vsc.Memento;
|
||||
@ -23,8 +24,8 @@ export function activate(ctx: vsc.ExtensionContext) {
|
||||
ctx.subscriptions.push(
|
||||
vsc.commands.registerTextEditorCommand('xmlTools.minifyXml', TextEditorCommands.minifyXml),
|
||||
vsc.commands.registerTextEditorCommand('xmlTools.evaluateXPath', TextEditorCommands.evaluateXPath),
|
||||
|
||||
vsc.commands.registerTextEditorCommand('xmlTools.executeXQuery', TextEditorCommands.executeXQuery)
|
||||
vsc.commands.registerTextEditorCommand('xmlTools.executeXQuery', TextEditorCommands.executeXQuery),
|
||||
vsc.commands.registerTextEditorCommand('xmlTools.viewXmlTree', TextEditorCommands.viewXmlAsTree)
|
||||
);
|
||||
|
||||
// register language feature providers
|
||||
@ -35,6 +36,11 @@ export function activate(ctx: vsc.ExtensionContext) {
|
||||
vsc.languages.registerCompletionItemProvider(LANG_XQUERY, new XQueryCompletionItemProvider(), ':', '$')
|
||||
);
|
||||
|
||||
// register workspace feature providers
|
||||
ctx.subscriptions.push(
|
||||
vsc.workspace.registerTextDocumentContentProvider(XmlTreeDocumentContentProvider.SCHEME, new XmlTreeDocumentContentProvider())
|
||||
);
|
||||
|
||||
// listen to editor events (for linting)
|
||||
ctx.subscriptions.push(
|
||||
vsc.window.onDidChangeActiveTextEditor(_handleChangeActiveTextEditor),
|
||||
|
28
src/providers/Content.ts
Normal file
28
src/providers/Content.ts
Normal file
@ -0,0 +1,28 @@
|
||||
'use strict';
|
||||
|
||||
import * as vsc from 'vscode';
|
||||
import { XmlTreeService } from '../services/XmlTreeService';
|
||||
|
||||
export class XmlTreeDocumentContentProvider implements vsc.TextDocumentContentProvider {
|
||||
|
||||
static get SCHEME(): string {
|
||||
return "xmltree";
|
||||
}
|
||||
|
||||
static buildUri(sourceUri: vsc.Uri): vsc.Uri {
|
||||
let uriStr: string = `xmltree://${encodeURIComponent(sourceUri.toString())}`;
|
||||
|
||||
let uri: vsc.Uri = vsc.Uri.parse(uriStr);
|
||||
|
||||
return uri;
|
||||
}
|
||||
|
||||
async provideTextDocumentContent(uri: vsc.Uri): Promise<string> {
|
||||
let sourceUri: vsc.Uri = vsc.Uri.parse(decodeURIComponent(uri.toString().substr(10)));
|
||||
let document: vsc.TextDocument = await vsc.workspace.openTextDocument(sourceUri);
|
||||
|
||||
let html: string = XmlTreeService.getXmlTreeHtml(document.getText());
|
||||
|
||||
return Promise.resolve(html);
|
||||
}
|
||||
}
|
186
src/services/XmlTreeService.ts
Normal file
186
src/services/XmlTreeService.ts
Normal file
@ -0,0 +1,186 @@
|
||||
'use strict';
|
||||
|
||||
let DOMParser = require('xmldom').DOMParser;
|
||||
|
||||
export class XmlTreeService {
|
||||
static getXmlTreeHtml(xml: string): string {
|
||||
let xdoc: Document = new DOMParser().parseFromString(xml, 'text/xml');
|
||||
let html: string =
|
||||
`
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>XML Tree View</title>
|
||||
<style>
|
||||
*, html {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
}
|
||||
|
||||
body, form, ul, li, p, h1, h2, h3, h4, h5 {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
body {
|
||||
color: #ffffff;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
img {
|
||||
border: none;
|
||||
}
|
||||
|
||||
p {
|
||||
font-size: 1em;
|
||||
margin: 0 0 1em 0;
|
||||
}
|
||||
|
||||
html {
|
||||
font-size: 100%;
|
||||
/* IE hack */
|
||||
}
|
||||
|
||||
body {
|
||||
font-size: 1em;
|
||||
/* Sets base font size to 16px */
|
||||
}
|
||||
|
||||
table {
|
||||
font-size: 100%;
|
||||
/* IE hack */
|
||||
}
|
||||
|
||||
input, select, textarea, th, td {
|
||||
font-size: 1em;
|
||||
}
|
||||
|
||||
|
||||
/* CSS Tree menu styles */
|
||||
|
||||
ol.tree {
|
||||
padding: 0 0 0 30px;
|
||||
width: 300px;
|
||||
}
|
||||
|
||||
li {
|
||||
position: relative;
|
||||
margin-left: -15px;
|
||||
list-style: none;
|
||||
}
|
||||
|
||||
li.xml {
|
||||
margin-left: -1px !important;
|
||||
}
|
||||
|
||||
li.xml a {
|
||||
background: url(document.png) 0 0 no-repeat;
|
||||
color: #000;
|
||||
padding-left: 21px;
|
||||
text-decoration: none;
|
||||
display: block;
|
||||
}
|
||||
|
||||
li.xml-attribute a {
|
||||
background: url() 0 0 no-repeat;
|
||||
}
|
||||
|
||||
li.xml-text a {
|
||||
background: url() 0 0 no-repeat;
|
||||
}
|
||||
|
||||
li input {
|
||||
position: absolute;
|
||||
left: 0;
|
||||
margin-left: 0;
|
||||
opacity: 0;
|
||||
z-index: 2;
|
||||
cursor: pointer;
|
||||
height: 1em;
|
||||
width: 1em;
|
||||
top: 0;
|
||||
}
|
||||
|
||||
li input + ol {
|
||||
background: url() 40px 0 no-repeat;
|
||||
margin: -0.938em 0 0 -44px;
|
||||
/* 15px */
|
||||
height: 1em;
|
||||
}
|
||||
|
||||
li input + ol > li {
|
||||
display: none;
|
||||
margin-left: -14px !important;
|
||||
padding-left: 1px;
|
||||
}
|
||||
|
||||
li label {
|
||||
background: url() 15px 1px no-repeat;
|
||||
cursor: pointer;
|
||||
display: block;
|
||||
padding-left: 37px;
|
||||
}
|
||||
|
||||
li input:checked + ol {
|
||||
background: url() 40px 5px no-repeat;
|
||||
margin: -1.25em 0 0 -44px;
|
||||
/* 20px */
|
||||
padding: 1.563em 0 0 80px;
|
||||
height: auto;
|
||||
}
|
||||
|
||||
li input:checked + ol > li {
|
||||
display: block;
|
||||
margin: 0 0 0.125em;
|
||||
/* 2px */
|
||||
}
|
||||
|
||||
li input:checked + ol > li:last-child {
|
||||
margin: 0 0 0.063em;
|
||||
/* 1px */
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
`;
|
||||
|
||||
html += `<ol class="tree">`;
|
||||
html += XmlTreeService._processXmlNode(xdoc.lastChild);
|
||||
html += `</ol>`;
|
||||
|
||||
html +=
|
||||
`
|
||||
</body>
|
||||
</html>
|
||||
`;
|
||||
|
||||
return html;
|
||||
}
|
||||
|
||||
private static _processXmlNode(node: Node): string {
|
||||
let html: string = '';
|
||||
|
||||
if (node.childNodes) {
|
||||
html += `<li><label for="ID">${node.localName}</label><input type="checkbox" id="ID" /><ol>`;
|
||||
}
|
||||
|
||||
if (node.attributes) {
|
||||
for (let i = 0; i < node.attributes.length; i++) {
|
||||
html += `<li class="xml xml-attribute"><a href="">${node.attributes.item(i).localName} = '${node.attributes.item(i).value}'</a></li>`;
|
||||
}
|
||||
}
|
||||
|
||||
if (!node.childNodes && node.textContent) {
|
||||
html += `<li class="xml xml-text"><a href="">${node.textContent}</a></li>`;
|
||||
}
|
||||
|
||||
if (node.childNodes) {
|
||||
for (let i = 0; i < node.childNodes.length; i++) {
|
||||
html += XmlTreeService._processXmlNode(node.childNodes.item(i));
|
||||
}
|
||||
|
||||
html += `</ol></li>`;
|
||||
}
|
||||
|
||||
return html;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user