From a6e18895b513f385c0af334e7d99d18a390ab8a4 Mon Sep 17 00:00:00 2001 From: Chris Lockwood Date: Fri, 22 Sep 2017 12:53:05 -0700 Subject: [PATCH 1/2] adding new vedio placemat code sample --- .../first-run/video-placemat/dialog.html | 2 +- .../first-run/video-placemat/index.html | 103 +++--- .../video-placemat/video.placemat.css | 296 ++++++++++++++++++ .../video-placemat/video.placemat.js | 102 ++++-- .../video-placemat/video.placemat.scss | 123 -------- 5 files changed, 439 insertions(+), 187 deletions(-) create mode 100644 src/templates/first-run/video-placemat/video.placemat.css delete mode 100644 src/templates/first-run/video-placemat/video.placemat.scss diff --git a/src/templates/first-run/video-placemat/dialog.html b/src/templates/first-run/video-placemat/dialog.html index 075f9cb..e66777c 100644 --- a/src/templates/first-run/video-placemat/dialog.html +++ b/src/templates/first-run/video-placemat/dialog.html @@ -1,4 +1,4 @@ - + + + + + + + + + + + + - - - - - - - - + + + - -
-
-
- Skip -
-
-
-

WELCOME

+ + +
+ + + + diff --git a/src/templates/first-run/video-placemat/video.placemat.css b/src/templates/first-run/video-placemat/video.placemat.css new file mode 100644 index 0000000..97a2e29 --- /dev/null +++ b/src/templates/first-run/video-placemat/video.placemat.css @@ -0,0 +1,296 @@ +/* Copyright (c) Microsoft. All rights reserved. Licensed under the MIT license. See full license in root of repo. */ + +html, body { + width: 100%; + height: 100%; + margin: 0; + padding: 0; + overflow: auto; +} + +body { + position: relative; + min-height: 450px; + min-width: 320px; +} + +main { + height: 100%; + overflow-y: auto; +} + +footer { + width: 100%; + position: relative; + bottom: 0; +} + +p, h1, h2, h3, h4, h5, h6 { + margin: 0; + padding: 0; +} + +ul { + padding: 0; +} + +.clearfix { + display: block; + clear: both; + height: 0; +} + +.ms-Icon.enlarge { + position: relative; + font-size: 20px; + top: 4px; +} + +.placeholder { + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-flex: 1 1 0; + -ms-flex: 1 1 0; + flex: 1 1 0; + height: 100%; +} + +.placeholder__header { + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + border-bottom-width: 1px; + border-bottom-style: solid; + height: 44px; + width: 100%; +} + +.placeholder__header--left { + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; + width: 44px; +} + +.placeholder__header--left nav { + width: 14px; + height: 14px; +} + +.placeholder__header--right { + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; +} + +.placeholder__header--right--cmd { + width: 14px; + height: 14px; + border-radius: 100%; +} + +.placeholder__header--right--text { + width: 30px; + height: 10px; + margin: auto 10px auto 6px; +} + +.placeholder__content { + padding: 20px; +} + +.placeholder__content--textTitle { + width: 100%; + height: 32px; + margin-bottom: 20px; +} + +.placeholder__content--textBody { + width: 100%; + height: 64px; + margin-bottom: 20px; +} + +.placeholder__footer { + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + height: 44px; + border-top-width: 1px; + border-top-style: solid; + position: absolute; + bottom: 0; +} + +.placeholder__footer--left { + width: 100%; + height: 100%; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + padding-left: 20px; +} + +.placeholder__footer--left--logo { + width: 32px; + height: 32px; +} + +.placeholder__footer--left--text { + min-width: 160px; + height: 14px; + margin-left: 7px; +} + +.placeholder__footer--right { + max-width: 100%; + height: 100%; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; +} + +.placeholder__footer--right--cmd { + width: 14px; + height: 14px; + border-radius: 50%; + margin: 0 20px; +} + +.dp-video-placemat { + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + height: 100%; + text-align: center; + position: relative; +} + +.dp-video-placemat--skip { + height: 44px; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-justify-content: flex-end; + -ms-flex-pack: end; + justify-content: flex-end; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; +} + +.dp-video-placemat #skip { + background: none repeat scroll 0 0 transparent; + border: 0 none; + line-height: 1; + cursor: pointer; + margin-right: 20px; + padding: 0; +} + +.dp-video-placemat--content__intro { + padding: 35px 20px 30px; +} + +.dp-video-placemat--content__intro p { + margin-top: 30px; + line-height: 1.5; +} + +.dp-video-placemat--content #videoImage { + cursor: pointer; +} + +.dp-video-placemat--content__caption { + padding: 10px 20px 0; +} + +.dp-video-placemat--button { + margin-top: 50px; +} + +.ms-MessageBar { + position: absolute; + top: 0; + left: 0; + text-align: left; + z-index: 99; + width: 100%; +} + +.hidden { + display: none; +} diff --git a/src/templates/first-run/video-placemat/video.placemat.js b/src/templates/first-run/video-placemat/video.placemat.js index 07f0479..2ac1e91 100644 --- a/src/templates/first-run/video-placemat/video.placemat.js +++ b/src/templates/first-run/video-placemat/video.placemat.js @@ -1,29 +1,89 @@ // Copyright (c) Microsoft. All rights reserved. Licensed under the MIT license. See full license in root of repo. - -(function () { +var dialog; +(function ($) { "use strict"; - - // The initialize function must be run each time a new page loads. + var overlay; Office.initialize = function () { $(document).ready(function () { - document.getElementById("videoimage").onclick = function () { - showVideoDialog(); + var OverlayElement = document.querySelector('.ms-Overlay'); + overlay = new fabric['Overlay'](OverlayElement); + function showMessage() { + // Direct the user to view the video. + $('.ms-MessageBar').attr('class', 'ms-MessageBar'); + } + function removeMessage() { + // Remove the messageBar from the task pane. + $('.ms-MessageBar').attr('class', 'ms-MessageBar hidden'); + } + ; + function reEnableParentUI() { + // Enable the button because they launched the video and then closed the dialog. + $("#buttonGetStarted").prop("disabled", false); + } + $('#videoImage').click(function () { + overlay.show(); + showMessage(); + reEnableParentUI(); + openDialog(); + }); + function dialogCallback(asyncResult) { + if (asyncResult.status == "failed") { + // In addition to general system errors, there are 3 specific errors for + // displayDialogAsync that you can handle individually. + switch (asyncResult.error.code) { + case 12004: + console.log("Domain is not trusted"); + break; + case 12005: + console.log("HTTPS is required"); + break; + case 12007: + console.log("A dialog is already opened."); + break; + default: + console.log(asyncResult.error.message); + break; + } + } + else { + dialog = asyncResult.value; + /*Messages are sent by developers programatically from the dialog using office.context.ui.messageParent(...)*/ + dialog.addEventHandler(Office.EventType.DialogMessageReceived, messageHandler); + /*Events are sent by the platform in response to user actions or errors. For example, the dialog is closed via the 'x' button*/ + dialog.addEventHandler(Office.EventType.DialogEventReceived, eventHandler); + } + } + function messageHandler(arg) { + dialog.close(); + console.log(arg.message); + } + function eventHandler(arg) { + // In addition to general system errors, there are 2 specific errors + // and one event that you can handle individually. + switch (arg.error) { + case 12002: + console.log("Cannot load URL, no such page or bad URL syntax."); + break; + case 12003: + console.log("HTTPS is required."); + break; + case 12006: + // The dialog was closed, typically because the user the pressed X button. + console.log("Dialog closed by user"); + $('.ms-MessageBar').attr('class', 'ms-MessageBar hidden'); + overlay.hide(); + break; + default: + console.log("Undefined error in dialog window"); + break; + } + } + function openDialog() { + var fullUrl = "https://localhost:3000/templates/first-run/video-placemat/dialog.html"; + Office.context.ui.displayDialogAsync(fullUrl, { height: 50, width: 50 }, dialogCallback); } }); }; +})(jQuery); - // Closes the dialog window. Consider adding additional code here that runs after the video finishes. - function reEnableParentUI(arg) { - // Enable the button because they launched the video and then closed the dialog. - $("#buttonGetStarted").prop("disabled", false); - } - - // Use the display dialog to open a pop-up and display the video. - function showVideoDialog() { - var fullUrl = "https://localhost:3000/templates/first-run/video-placemat/video.dialog.html"; - - // Height and width are percentages of the size of the parent Office application, e.g. PowerPoint, Excel, Word, etc. - Office.context.ui.displayDialogAsync(fullUrl, - { height: 50, width: 50, requireHTTPS: false }, reEnableParentUI); - } -}()); \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/templates/first-run/video-placemat/video.placemat.ts"],"names":[],"mappings":"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","file":"templates/first-run/video-placemat/video.placemat.js","sourcesContent":["// Copyright (c) Microsoft. All rights reserved. Licensed under the MIT license. See full license in root of repo.\r\n\r\n\r\ndeclare var fabric: any;\r\nvar dialog:any;\r\n\r\n(($) => {\r\n    \"use strict\";\r\n\r\n    let overlay:any;\r\n\r\n    Office.initialize = () => { \r\n        $(document).ready(() => {\r\n            \r\n            let OverlayElement = document.querySelector('.ms-Overlay');\r\n            overlay = new fabric['Overlay'](OverlayElement);\r\n\r\n            function showMessage() {\r\n                // Direct the user to view the video.\r\n                $('.ms-MessageBar').attr('class', 'ms-MessageBar');\r\n            }\r\n\r\n            function removeMessage() {\r\n                // Remove the messageBar from the task pane.\r\n                $('.ms-MessageBar').attr('class', 'ms-MessageBar hidden');\r\n            };\r\n\r\n            function reEnableParentUI() {\r\n                // Enable the button because they launched the video and then closed the dialog.\r\n                $(\"#buttonGetStarted\").prop(\"disabled\", false);\r\n            }\r\n\r\n            $('#videoImage').click(()=>{\r\n                overlay.show();\r\n                showMessage();\r\n                reEnableParentUI();\r\n                openDialog();\r\n            });\r\n\r\n            function dialogCallback(asyncResult:any) {\r\n                if (asyncResult.status == \"failed\") {\r\n            \r\n                    // In addition to general system errors, there are 3 specific errors for \r\n                    // displayDialogAsync that you can handle individually.\r\n                    switch (asyncResult.error.code) {\r\n                        case 12004:\r\n                            console.log(\"Domain is not trusted\");\r\n                            break;\r\n                        case 12005:\r\n                        console.log(\"HTTPS is required\");\r\n                            break;\r\n                        case 12007:\r\n                        console.log(\"A dialog is already opened.\");\r\n                            break;\r\n                        default:\r\n                        console.log(asyncResult.error.message);\r\n                            break;\r\n                    }\r\n                }\r\n                else {\r\n                    dialog = asyncResult.value;\r\n                    /*Messages are sent by developers programatically from the dialog using office.context.ui.messageParent(...)*/\r\n                    dialog.addEventHandler(Office.EventType.DialogMessageReceived, messageHandler);\r\n            \r\n                    /*Events are sent by the platform in response to user actions or errors. For example, the dialog is closed via the 'x' button*/\r\n                    dialog.addEventHandler(Office.EventType.DialogEventReceived, eventHandler);\r\n                }\r\n            }\r\n            \r\n            \r\n            function messageHandler(arg:any) {\r\n                dialog.close();\r\n                console.log(arg.message);\r\n            }\r\n            \r\n            \r\n            function eventHandler(arg:any) {\r\n            \r\n                // In addition to general system errors, there are 2 specific errors \r\n                // and one event that you can handle individually.\r\n                switch (arg.error) {\r\n                    case 12002:\r\n                    console.log(\"Cannot load URL, no such page or bad URL syntax.\");\r\n                        break;\r\n                    case 12003:\r\n                    console.log(\"HTTPS is required.\");\r\n                        break;\r\n                    case 12006:\r\n                        // The dialog was closed, typically because the user the pressed X button.\r\n                        console.log(\"Dialog closed by user\");\r\n                        $('.ms-MessageBar').attr('class', 'ms-MessageBar hidden');\r\n                        overlay.hide();\r\n                        break;\r\n                    default:\r\n                    console.log(\"Undefined error in dialog window\");\r\n                        break;\r\n                }\r\n            }\r\n            \r\n            function openDialog() {\r\n                let fullUrl = \"https://localhost:3000/templates/first-run/video-placemat/dialog.html\";\r\n\r\n                Office.context.ui.displayDialogAsync(fullUrl,\r\n                    { height: 50, width: 50 }, dialogCallback);\r\n            }\r\n\r\n        });\r\n    };\r\n})(jQuery);\r\n\r\n"]} diff --git a/src/templates/first-run/video-placemat/video.placemat.scss b/src/templates/first-run/video-placemat/video.placemat.scss deleted file mode 100644 index 1564915..0000000 --- a/src/templates/first-run/video-placemat/video.placemat.scss +++ /dev/null @@ -1,123 +0,0 @@ -@import '../../../common/common.scss'; - -.ms-firstrun-video { - @include flex(); - height: 100%; - text-align: center; - - &__header { - padding: $global-spacing; - min-height: 160px; - max-height: 250px; - @include flex(); - - h1 { - letter-spacing: 5px; - } - - p { - margin-top: 7px; - } - - &--skip { - text-align: right; - } - - &--image { - @include background-fill(cover) { - background-image: url('../../../assets/video-placeholder.png'); - } - - margin-top: 15px; - @include stretch-flex(); - @include focus-states(url('../../../assets/video-placeholder.png') center center no-repeat/cover); - - flex: 0 1 0; - min-height: 200px; - } - } - - - &__welcome { - width: 100%; - height: 100%; - flex: 1 1 0; - @include center-flex(); - - img { - height: 100px; - } - } - - &__player { - width: 100%; - height: 100%; - @include stretch-flex(); - - img { - height: 100%; - } - } - - - &__content { - @include flex(); - height: 100%; - flex: 1 1 0; - padding-left: $global-spacing; - padding-right: $global-spacing; - padding-bottom: $global-spacing; - - &--centered { - @include flex(); - } - - &--caption { - margin-top: 5px; - } - - &--valuestatement { - padding-top: 50px; - } - } - - &__list { - list-style-type: none; - - li { - margin-bottom: $global-spacing; - - i { - position: relative; - top: 2px; - margin-right: 10px; - } - } - } - - - - &__action { - &--primary { - &.ms-Button { - align-self: center; - margin-top: 65px; - border: solid 2px $ms-fontColor-white; - width: calc(100vw - 40px); - padding: 10px; - @include inline-flex(center, center); - - span.ms-Button-label { - color: $ms-fontColor-white; - } - - @include focus-states(#FFFFFF, $ms-fontColor-themePrimary, false); - } - } - } - - &__button { - padding-top: $global-spacing; - @include center-flex(); - } -} From e47e31262db746e756d37028eda13eac7d9341ed Mon Sep 17 00:00:00 2001 From: Chris Lockwood Date: Tue, 26 Sep 2017 11:35:43 -0700 Subject: [PATCH 2/2] Replacing css and js files with scss and ts --- .../first-run/video-placemat/dialog.html | 2 +- .../first-run/video-placemat/index.html | 2 +- .../video-placemat/video.placemat.css | 296 ------------------ .../video-placemat/video.placemat.js | 89 ------ .../video-placemat/video.placemat.scss | 178 +++++++++++ .../video-placemat/video.placemat.ts | 110 +++++++ 6 files changed, 290 insertions(+), 387 deletions(-) delete mode 100644 src/templates/first-run/video-placemat/video.placemat.css delete mode 100644 src/templates/first-run/video-placemat/video.placemat.js create mode 100644 src/templates/first-run/video-placemat/video.placemat.scss create mode 100644 src/templates/first-run/video-placemat/video.placemat.ts diff --git a/src/templates/first-run/video-placemat/dialog.html b/src/templates/first-run/video-placemat/dialog.html index e66777c..075f9cb 100644 --- a/src/templates/first-run/video-placemat/dialog.html +++ b/src/templates/first-run/video-placemat/dialog.html @@ -1,4 +1,4 @@ - + +