Показать HTML в окне кнопкой ОК в расширении VSCode - PullRequest
1 голос
/ 19 марта 2019

Мне нужно вставить текст после курсора, если пользователь согласен.Я не могу найти что-либо в документации для моей задачи.

Миссия моего расширения:

  1. пользователь пишет код
  2. , затем онвызывает добавочный номер
  3. , он отправляет весь код на сервер
  4. возвращает и отображает некоторый код в дополнительном окне с кнопкой «ОК»
  5. при нажатии кнопки «ОК» вставляетответ сервера после курсора

У меня проблема с пунктом 4. Я не могу найти способ показать дополнительное окно кнопкой "ОК".

Весь кодот extension.js:

function activate(context) {
  console.log('"showText" active');

  const commandId = 'extension.showText'
  let disposable = vscode.commands.registerCommand(commandId, function () {
    const text = editor.document.getText()

    let options = {
      method: 'GET',
      uri: 'http://example.com:8081/',
      body: {
        text: text
      },
      json: true
    }
    rp(options)
      .then(function (respString) {
        console.log(respString);
        // what should I call here?
        // vscode.window.showInformationMessage(respString);
      })
      .catch(function(err) {
        console.log(err);
      });
  });
  context.subscriptions.push(disposable);
}
exports.activate = activate;

function deactivate() {
  console.log('showText disactive');
}

module.exports = {
  activate,
  deactivate
}

1 Ответ

0 голосов
/ 12 мая 2019

Это не дубликат Как обрабатывать событие щелчка в окне сообщения кода Visual Studio? , потому что мне нужна страница HTML.И это решение просто показывает текстовое сообщение с кнопкой подтверждения.

Мое решение: webview-sample Webview API

My example:
// The module 'vscode' contains the VS Code extensibility API
// Import the module and reference it with the alias vscode in your code below
const vscode = require('vscode');
const workspace = vscode.workspace;
const window = vscode.window;
const rp = require("request-promise");

// this method is called when your extension is activated
// your extension is activated the very first time the command is executed

/**
 * @param {vscode.ExtensionContext} context
 */

function activate(context) {
  // Use the console to output diagnostic information (console.log) and errors (console.error)
  // This line of code will only be executed once when your extension is activated
  console.log('Extension activated');


  // The command has been defined in the package.json file
  // Now provide the implementation of the command with  registerCommand
  // The commandId parameter must match the command field in package.json
  const commandId = 'extension.showText'
  let disposable = vscode.commands.registerCommand(commandId, function () {
    const editor = window.activeTextEditor;
    const text = editor.document.getText();

    console.log('For editor "'+ editor._id +'"');

    let options = {
      method: 'POST',
      uri: URL,
      body: {
        text: text
      },
      json: true
    };

    rp(options)
      .then(function (res) { // res
        const panel = window.createWebviewPanel(
          'type_id', // Identifies the type of the webview. Used internally
          'Title', // Title of the panel displayed to the user
          vscode.ViewColumn.Two, // Editor column to show the new webview panel in.
          {
            // Enable scripts in the webview
            enableScripts: true
          } // Webview options. More on these later.
        );
        panel.webview.html = res;


        // Handle messages from the webview
        // закрывать когда выбираешь другое окошко
        window.onDidChangeActiveTextEditor(
          ev => {
            // console.log(ev._id, editor._id, editor);
            ev && ev._id && ev._id != editor._id && panel.dispose();
          }
        )
        // закрывать когда закрываешь окно
        workspace.onDidCloseTextDocument(
          textDocument => {
            console.log("closed => " + textDocument.isClosed)
            panel.dispose();
          },
          null,
          context.subscriptions
        );
        // любая клавиша кроме enter - фильтр по префиксу
        // если enter - поиск подсказок
        workspace.onDidChangeTextDocument(
          ev => {
            console.log(ev);

            if (ev && ev.contentChanges && ev.contentChanges.length
                   && (ev.contentChanges[0].text || ev.contentChanges[0].rangeLength)) {
              // do smth
            } else {
              console.error('No changes detected. But it must be.', ev);
            }
          },
          null,
          context.subscriptions
        );

        panel.webview.onDidReceiveMessage(
          message => {
            switch (message.command) {
            case 'use':
              console.log('use');
              editor.edit(edit => {
                let pos = new vscode.Position(editor.selection.start.line,
                                              editor.selection.start.character)
                edit.insert(pos, message.text);
                panel.dispose()
              });
              return;
            case 'hide':
              panel.dispose()
              console.log('hide');
              return;
            }
          },
          undefined,
          context.subscriptions
        );

        panel.onDidDispose(
          () => {
            console.log('disposed');
          },
          null,
          context.subscriptions
        )
    })
    .catch(function(err) {
      console.log(err);
    });
  });
  context.subscriptions.push(disposable);
}
exports.activate = activate;

// this method is called when your extension is deactivated
function deactivate() {
  console.log('Extension disactivated');
}

module.exports = {
  activate,
  deactivate
}

Примерres:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Title</title>
    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
  </head>
  <body>
    <p id="text">Text</p>
    <button onclick="useAdvise()">Use</button>
    <button onclick="hideAdvise()">Hide</button>
    <script>
      const vscode = acquireVsCodeApi();
      function useAdvise(){
        let text_ = $(document).find("#text").text();
        vscode.postMessage({command: 'use',text: text_})
      }
      function hideAdvise(){
        vscode.postMessage({command: 'hide'})
      }
    </script>
  </body>
</html>
...