Офис-JS-помощник

Во-первых, я не программист, но отличный любитель в моем путешествии от vba к офису, чтобы стать настоящим производителем программного обеспечения. Так что, возможно, мой вопрос глупый. Я строю офис добавить с настройкой:

  • Сообщество Visual Studio 2017;
  • Office 365 Enterprise E3 Developer;
  • Прочитайте книгу Создание офисных надстроек с помощью Office.js (Михаил Златковский)
  • Использовать встроенный шаблон для добавления в Office: Excel добавить в функциональность;
  • выполнил шаги, чтобы сделать проект машинописным
  • переключился с тканевого интерфейса на загрузочный;

В скрипте Lab есть классный пример кода-фрагмента кода, который использует библиотеку office-js-helper (github). Для вопроса часть

async function createTable() {
    try {
        await Excel.run(async (context) => {

            await OfficeHelpers.ExcelUtilities.forceCreateSheet(context.workbook, "Indeling");

В книге также упоминается officehelper, но не описание того, как это реализовать в стандартном шаблоне VS. Это библиотека npm. https://github.com/OfficeDev/office-js-helpers/blob/master/README.md Я пытался ссылаться на сценарий в заголовке HTML, но не понял его правильно. Я попытался добавить его с помощью пакета быстрой установки (щелчок правой кнопкой мыши в обозревателе решений). Есть также вариант Nuget этой библиотеки? При сборке выдается ошибка Сборка: не удается найти имя "OfficeHelpers" (TS2304).

Как правильно это понять?

редактировать

<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=Edge" />
<title>Grip op mijn Geld Develop</title>

<script src="office.helpers.min.js"></script>
<script src="https://unpkg.com/@microsoft/office-js-helpers@1.0.2/dist/office.helpers.min.js"></script>

<script src="Scripts/jquery-3.3.1.js"></script>
<script src="Scripts/FabricUI/MessageBanner.js" type="text/javascript"></script>
<script src="https://appsforoffice.microsoft.com/lib/1/hosted/office.js" type="text/javascript"></script>

    <!-- To enable offline debugging using a local reference to Office.js, use:                        -->
<!-- <script src="Scripts/Office/MicrosoftAjax.js" type="text/javascript"></script>  -->
<!-- <script src="Scripts/Office/1/office.js" type="text/javascript"></script>  -->

<link href="Home.css" rel="stylesheet" type="text/css" />
<script src="Home.js" type="text/javascript"></script>
<script src="Home.js"></script>
<!--<script src="https://unpkg.com/@microsoft/office-js-helpers@1.0.2/dist/office.helpers.min.js"></script>-->
<!-- For the Office UI Fabric, go to https://aka.ms/office-ui-fabric to learn more.
<link rel="stylesheet" href="https://appsforoffice.microsoft.com/fabric/2.1.0/fabric.min.css">
<link rel="stylesheet" href="https://appsforoffice.microsoft.com/fabric/2.1.0/fabric.components.min.css">-->
<!-- To enable the offline use of Office UI Fabric, use: -->
<link rel="stylesheet" href="Content/fabric.min.css">
<link rel="stylesheet" href="Content/fabric.components.min.css">


<!-- For the Bootstrap UI -->
<link href="Content/bootstrap-grid.css" rel="stylesheet" />
<link href="Content/bootstrap-reboot.css" rel="stylesheet" />
<link href="Content/bootstrap.css" rel="stylesheet" />
<link href="Content/fontawesome.css" rel="stylesheet" />
<link href="Content/fontawesome-all.css" rel="stylesheet" />
<link href="Content/OverrideCss.css" rel="stylesheet" />

И home.ts

declare var fabric: any;

(function () {
"use strict";

var cellToHighlight;
var messageBanner;

// The initialize function must be run each time a new page is loaded.
Office.initialize = function (reason) {
    $(document).ready(function () {
        // Initialize the FabricUI notification mechanism and hide it
        var element = document.querySelector('.ms-MessageBanner');
        messageBanner = new fabric.MessageBanner(element);
        messageBanner.hideBanner();

        // If not using Excel 2016, use fallback logic.
        if (!Office.context.requirements.isSetSupported('ExcelApi', 1.1)) {

            return;
        }

        // Attach button click event handlers
        $("#create-table").click(createTable);
        $("#create-table2").click(createTable);


        (window as any).Promise = OfficeExtension.Promise   

    });
};
async function createTable2() {
    try {
        await Excel.run(async (context) => {

            // await OfficeHelpers.ExcelUtilities.forceCreateSheet(context.workbook, "Indeling");

            await OfficeHelpers.ExcelUtilities.forceCreatesheet(context.workbook, "Sample");

            const sheet = context.workbook.worksheets.getItem("sample");

            const expenseTable = sheet.tables.add("A1:d1",true)

            expenseTable.getHeaderRowRange().values = [["Type", "Soort", "Volgnr", "Hulp-Sorteer"]]

            expenseTable.rows.add(null /*add at the end*/, [
                ["1/1/2018", "the phone comp", "Communications", " €120"],
                ["1/5/2018", "the phone comp", "Anders", " €150"],
            ]);

            if (Office.context.requirements.isSetSupported('ExcelApi', 1.2)) {
                sheet.getUsedRange().format.autofitColumns();
                sheet.getUsedRange().format.autofitRows();
            }

            sheet.activate();

            await context.sync();


        });

    }
    catch (error) {
        OfficeHelpers.UI.notify(error);
        OfficeHelpers.Uilities.log(error);
    }



}




async function createTable() {
    try {
        await Excel.run(async (context) => {

            // await OfficeHelpers.ExcelUtilities.forceCreateSheet(context.workbook, "Indeling");

            let sheets = context.workbook.worksheets;
            let sheetIndeling = sheets.add("Indeling");
            sheetIndeling.load("Indeling");

            // Create strings to store all static content to display in the Indeling sheet
            let sheetTitle = "Indeling";
            let sheetSubTitel1 = "Herkennen";
            let sheetSubTitel2 = "Categorieën";
            let sheetSubTitel3 = "Soort";
            let table1 = "HerkennenTable";
            let table2 = "CategorieTable";
            let table3 = "SoortTable";

            //Queue a command to fill white color in the sheet to remove gridlines
            sheetIndeling.getRange().format.fill.color = "white";

            // Add all static content to the Welcome sheet and format the text
            addContentToWorksheet(sheetIndeling, "B1:N1", sheetTitle, "SheetTitle");
            addContentToWorksheet(sheetIndeling, "B3:E3", sheetSubTitel1, "SheetSubTitle");
            addContentToWorksheet(sheetIndeling, "G3:I3", sheetSubTitel2, "SheetSubTitle");
            addContentToWorksheet(sheetIndeling, "K3:N3", sheetSubTitel3, "SheetSubTitle");
            addContentToWorksheet(sheetIndeling, "B5:E5", table1, "TableHeading");
            addContentToWorksheet(sheetIndeling, "G5:I5", table2, "TableHeading");
            addContentToWorksheet(sheetIndeling, "K5:N5", table3, "TableHeading");

            const sheet = context.workbook.worksheets.getItem("Indeling");
            const herkennenTable = sheet.tables.add("B5:E5", true);
            const categorieTable = sheet.tables.add("G5:I5", true);
            const soortTable = sheet.tables.add("K5:N5", true);


            // Queue a command to set the header row
            herkennenTable.getHeaderRowRange().values = [["Soort", "Categorie", "Herkennen-Kenmerk", "Nr"]];
            categorieTable.getHeaderRowRange().values = [["Soort", "Categorie", "ID"]];
            soortTable.getHeaderRowRange().values = [["Type","Soort","Volgnr","Hulp-Sorteer"]]

            herkennenTable.rows.add(null /*add at the end*/, [
                ["1/1/2018", "the phone comp", "Communications"," €120"],
                ["1/5/2018", "the phone comp", "Anders", " €150"],
            ]);

            if (Office.context.requirements.isSetSupported('ExcelApi', 1.2)) {
                sheet.getUsedRange().format.autofitColumns();
                sheet.getUsedRange().format.autofitRows();
            }

            sheet.activate();

            await context.sync();


        });

    }
    catch (errorHandler) {

    }



}
// Helper function to add and format content in the workbook
function addContentToWorksheet(sheetObject, rangeAddress, displayText, typeOfText) {

    // Format differently by the type of content
    switch (typeOfText) {
        case "SheetTitle":
            var range = sheetObject.getRange(rangeAddress);
            range.values = displayText;
            range.format.font.name = "Corbel";
            range.format.font.size = 24;
            range.format.font.color = "yellow";
            range.merge();
            //Fill color in the brand bar
            sheetObject.getRange("A1:M1").format.fill.color = "#1f4e78";
            break;
        case "SheetSubTitle":
            var range = sheetObject.getRange(rangeAddress);
            range.values = displayText;
            range.format.font.name = "Corbel";
            range.format.font.size = 14;
            range.format.font.color = "#008000";
            range.format.fill.color = "yellow";
            range.format.horizontalAlignment = "center";
            range.merge();
            break;
        case "SheetHeading":
            var range = sheetObject.getRange(rangeAddress);
            range.values = displayText;
            range.format.font.name = "Corbel";
            range.format.font.size = 18;
            range.format.font.color = "#1f4e78";
            range.merge();
            break;
        case "SheetHeadingDesc":
            var range = sheetObject.getRange(rangeAddress);
            range.values = displayText;
            range.format.font.name = "Corbel";
            range.format.font.size = 10;
            range.merge();
            break;
        case "SummaryDataHeader":
            var range = sheetObject.getRange(rangeAddress);
            range.values = displayText;
            range.format.font.name = "Corbel";
            range.format.font.size = 13;
            range.merge();
            break;
        case "SummaryDataValue":
            var range = sheetObject.getRange(rangeAddress);
            range.numberFormat = "$#";
            range.values = displayText;
            range.format.font.name = "Corbel";
            range.format.font.size = 13;
            range.merge();
            break;
        case "TableHeading":
            var range = sheetObject.getRange(rangeAddress);
            range.values = displayText;
            range.format.font.name = "Corbel";
            range.format.font.size = 12;
            range.format.fill.color = "#1f4e78"
            range.format.font.color = "yellow";
            range.merge();
            break;
        case "TableHeaderRow":
            var range = sheetObject.getRange(rangeAddress);
            range.format.font.name = "Corbel";
            range.format.font.size = 10;
            range.format.font.bold = true;
            range.format.font.color = "black";
            break;
        case "TableDataRows":
            var range = sheetObject.getRange(rangeAddress);
            range.format.font.name = "Corbel";
            range.format.font.size = 10;
            sheetObject.getRange(rangeAddress).format.borders.getItem('EdgeBottom').style = 'Continuous';
            sheetObject.getRange(rangeAddress).format.borders.getItem('EdgeTop').style = 'Continuous';
            break;
        case "TableTotalsRow":
            var range = sheetObject.getRange(rangeAddress);
            range.format.font.name = "Corbel";
            range.format.font.size = 10;
            range.format.font.bold = true;
            break;
    }
}




// Helper function for treating errors
function errorHandler(error) {
    // Always be sure to catch any accumulated errors that bubble up from the Excel.run execution
    showNotification("Error", error);
    console.log("Error: " + error);
    if (error instanceof OfficeExtension.Error) {
        console.log("Debug info: " + JSON.stringify(error.debugInfo));
    }
}

// Helper function for displaying notifications
function showNotification(header, content) {
    $("#notification-header").text(header);
    $("#notification-body").text(content);
    messageBanner.showBanner();
    messageBanner.toggleExpansion();
}

})();

Изображение проекта решения исследовать

1 ответ

Решение

Вы должны иметь возможность обратиться к библиотеке, для тестирования, через <script src="https://unpkg.com/@microsoft/office-js-helpers@1.0.2/dist/office.helpers.min.js"></script> в HTML. Вы также можете скопировать этот файл локально и использовать его оттуда. Это не работает для вас?

Другие вопросы по тегам