diff --git a/e2e/tests/plugins/notebook/addInitRestrictedNotebook.js b/e2e/tests/plugins/notebook/addInitRestrictedNotebook.js
new file mode 100644
index 0000000000..dd303fb521
--- /dev/null
+++ b/e2e/tests/plugins/notebook/addInitRestrictedNotebook.js
@@ -0,0 +1,30 @@
+/*****************************************************************************
+ * Open MCT, Copyright (c) 2014-2022, United States Government
+ * as represented by the Administrator of the National Aeronautics and Space
+ * Administration. All rights reserved.
+ *
+ * Open MCT is licensed under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0.
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ * Open MCT includes source code licensed under additional open source
+ * licenses. See the Open Source Licenses file (LICENSES.md) included with
+ * this source code distribution or the Licensing information page available
+ * at runtime from the About dialog for additional information.
+ *****************************************************************************/
+
+// this will be called from the test suite with
+// await page.addInitScript({ path: path.join(__dirname, 'addInitRestrictedNotebook.js') });
+// it will install the RestrictedNotebook since it is not installed by default
+
+document.addEventListener('DOMContentLoaded', () => {
+ const openmct = window.openmct;
+ openmct.install(openmct.plugins.RestrictedNotebook('CUSTOM_NAME'));
+});
diff --git a/e2e/tests/plugins/notebook/notebook.e2e.spec.js b/e2e/tests/plugins/notebook/notebook.e2e.spec.js
new file mode 100644
index 0000000000..021946c875
--- /dev/null
+++ b/e2e/tests/plugins/notebook/notebook.e2e.spec.js
@@ -0,0 +1,198 @@
+/*****************************************************************************
+ * Open MCT, Copyright (c) 2014-2022, United States Government
+ * as represented by the Administrator of the National Aeronautics and Space
+ * Administration. All rights reserved.
+ *
+ * Open MCT is licensed under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0.
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ * Open MCT includes source code licensed under additional open source
+ * licenses. See the Open Source Licenses file (LICENSES.md) included with
+ * this source code distribution or the Licensing information page available
+ * at runtime from the About dialog for additional information.
+ *****************************************************************************/
+
+/*
+This test suite is dedicated to tests which verify the basic operations surrounding Notebooks.
+*/
+
+const { test } = require('../../../fixtures');
+
+test.describe('Notebook CRUD Operations', () => {
+ test.fixme('Can create a Notebook Object', async ({ page }) => {
+ //Create domain object
+ //Newly created notebook should have one Section and one page, 'Unnamed Section'/'Unnamed Page'
+ });
+ test.fixme('Can update a Notebook Object', async ({ page }) => {});
+ test.fixme('Can view a perviously created Notebook Object', async ({ page }) => {});
+ test.fixme('Can Delete a Notebook Object', async ({ page }) => {
+ // Other than non-persistible objects
+ });
+});
+
+test.describe('Default Notebook', () => {
+ // General Default Notebook statements
+ // ## Useful commands:
+ // 1. - To check default notebook:
+ // `JSON.parse(localStorage.getItem('notebook-storage'));`
+ // 1. - Clear default notebook:
+ // `localStorage.setItem('notebook-storage', null);`
+ test.fixme('A newly created Notebook is automatically set as the default notebook if no other notebooks exist', async ({ page }) => {
+ //Create new notebook
+ //Verify Default Notebook Characteristics
+ });
+ test.fixme('A newly created Notebook is automatically set as the default notebook if at least one other notebook exists', async ({ page }) => {
+ //Create new notebook A
+ //Create second notebook B
+ //Verify Non-Default Notebook A Characteristics
+ //Verify Default Notebook B Characteristics
+ });
+ test.fixme('If a default notebook is deleted, the second most recent notebook becomes the default', async ({ page }) => {
+ //Create new notebook A
+ //Create second notebook B
+ //Delete Notebook B
+ //Verify Default Notebook A Characteristics
+ });
+});
+
+test.describe('Notebook section tests', () => {
+ //The following test cases are associated with Notebook Sections
+ test.fixme('New sections are automatically named Unnamed Section with Unnamed Page', async ({ page }) => {
+ //Create new notebook A
+ //Add section
+ //Verify new section and new page details
+ });
+ test.fixme('Section selection operations and associated behavior', async ({ page }) => {
+ //Create new notebook A
+ //Add Sections until 6 total with no default section/page
+ //Select 3rd section
+ //Delete 4th section
+ //3rd section is still selected
+ //Delete 3rd section
+ //1st section is selected
+ //Set 3rd section as default
+ //Delete 2nd section
+ //3rd section is still default
+ //Delete 3rd section
+ //1st is selected and there is no default notebook
+ });
+});
+
+test.describe('Notebook page tests', () => {
+ //The following test cases are associated with Notebook Pages
+ test.fixme('Page selection operations and associated behavior', async ({ page }) => {
+ //Create new notebook A
+ //Delete existing Page
+ //New 'Unnamed Page' automatically created
+ //Create 6 total Pages without a default page
+ //Select 3rd
+ //Delete 3rd
+ //First is now selected
+ //Set 3rd as default
+ //Select 2nd page
+ //Delete 2nd page
+ //3rd (default) is now selected
+ //Set 3rd as default page
+ //Select 3rd (default) page
+ //Delete 3rd page
+ //First is now selected and there is no default notebook
+ });
+});
+
+test.describe('Notebook search tests', () => {
+ test.fixme('Can search for a single result', async ({ page }) => {});
+ test.fixme('Can search for many results', async ({ page }) => {});
+ test.fixme('Can search for new and recently modified entries', async ({ page }) => {});
+ test.fixme('Can search for section text', async ({ page }) => {});
+ test.fixme('Can search for page text', async ({ page }) => {});
+ test.fixme('Can search for entry text', async ({ page }) => {});
+});
+
+test.describe('Notebook entry tests', () => {
+ test.fixme('When a new entry is created, it should be focused', async ({ page }) => {});
+ test.fixme('When a telemetry object is dropped into a notebook, a new entry is created and it should be focused', async ({ page }) => {
+ // Drag and drop any telmetry object on 'drop object'
+ // new entry gets created with telemtry object
+ });
+ test.fixme('When a telemetry object is dropped into a notebooks existing entry, it should be focused', async ({ page }) => {
+ // Drag and drop any telemetry object onto existing entry
+ // Entry updated with object and snapshot
+ });
+ test.fixme('new entries persist through navigation events without save', async ({ page }) => {});
+ test.fixme('previous and new entries can be deleted', async ({ page }) => {});
+});
+
+test.describe('Snapshot Menu tests', () => {
+ test.fixme('When no default notebook is selected, Snapshot Menu dropdown should only have a single option', async ({ page }) => {
+ // There should be no default notebook
+ // Clear default notebook if exists using `localStorage.setItem('notebook-storage', null);`
+ // refresh page
+ // Click on 'Notebook Snaphot Menu'
+ // 'save to Notebook Snapshots' should be only option there
+ });
+ test.fixme('When default notebook is updated selected, Snapshot Menu dropdown should list it as the newest option', async ({ page }) => {
+ // Create 2a notebooks
+ // Set Notebook A as Default
+ // Open Snapshot Menu and note that Notebook A is listed
+ // Close Snapshot Menu
+ // Set Default Notebook to Notebook B
+ // Open Snapshot Notebook and note that Notebook B is listed
+ // Select Default Notebook Option and verify that Snapshot is added to Notebook B
+ });
+ test.fixme('Can add Snapshots via Snapshot Menu and details are correct', async ({ page }) => {
+ //Note this should be a visual test, too
+ // Create Telemetry object
+ // Create A notebook with many pages and sections.
+ // Set page and section defaults to be between first and last of many. i.e. 3 of 5
+ // Navigate to Telemetry object
+ // Select Default Notebook Option and verify that Snapshot is added to Notebook A
+ // Verify Snapshot Details appear correctly
+ });
+ test.fixme('Snapshots adjust time conductor', async ({ page }) => {
+ // Create Telemetry object
+ // Set Telemetry object's timeconductor to Fixed time with Start and Endtimes are recorded
+ // Embed Telemetry object into notebook
+ // Set Time Conductor to Local clock
+ // Click into embedded telemetry object and verify object appears with same fixed time from record
+ });
+});
+
+test.describe('Snapshot Container tests', () => {
+ test.fixme('5 Snapshots can be added to a container', async ({ page }) => {});
+ test.fixme('5 Snapshots can be added to a container and Deleted with Delete All action', async ({ page }) => {});
+ test.fixme('A snapshot can be Deleted from Container', async ({ page }) => {});
+ test.fixme('A snapshot can be Previewed from Container', async ({ page }) => {});
+ test.fixme('A snapshot Container can be open and closed', async ({ page }) => {});
+ test.fixme('Can add object to Snapshot container and pull into notebook and create a new entry', async ({ page }) => {
+ //Create Notebook
+ //Create Telemetry Object
+ //From Telemetry Object, use 'save to Notebook Snapshots'
+ //Snapshots indicator should blink, click on it to view snapshots
+ //Navigate to Notebook
+ //Drag and Drop onto droppable area for new entry
+ //New Entry created with given snapshot added
+ //Snapshot removed from container?
+ });
+ test.fixme('Can add object to Snapshot container and pull into notebook and existing entry', async ({ page }) => {
+ //Create Notebook
+ //Create Telemetry Object
+ //From Telemetry Object, use 'save to Notebook Snapshots'
+ //Snapshots indicator should blink, click on it to view snapshots
+ //Navigate to Notebook
+ //Drag and Drop into exiting entry
+ //Existing Entry updated with given snapshot
+ //Snapshot removed from container?
+ });
+ test.fixme('Verify Embedded options for PNG, JPG, and Annotate work correctly', async ({ page }) => {
+ //Add snapshot to container
+ //Verify PNG, JPG, and Annotate buttons work correctly
+ });
+});
diff --git a/e2e/tests/plugins/notebook/restrictedNotebook.e2e.spec.js b/e2e/tests/plugins/notebook/restrictedNotebook.e2e.spec.js
new file mode 100644
index 0000000000..12e1cc3220
--- /dev/null
+++ b/e2e/tests/plugins/notebook/restrictedNotebook.e2e.spec.js
@@ -0,0 +1,264 @@
+/*****************************************************************************
+ * Open MCT, Copyright (c) 2014-2022, United States Government
+ * as represented by the Administrator of the National Aeronautics and Space
+ * Administration. All rights reserved.
+ *
+ * Open MCT is licensed under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0.
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ * Open MCT includes source code licensed under additional open source
+ * licenses. See the Open Source Licenses file (LICENSES.md) included with
+ * this source code distribution or the Licensing information page available
+ * at runtime from the About dialog for additional information.
+ *****************************************************************************/
+
+const { test } = require('../../../fixtures');
+const { expect } = require('@playwright/test');
+const path = require('path');
+
+const TEST_TEXT = 'Testing text for entries.';
+const TEST_TEXT_NAME = 'Test Page';
+const CUSTOM_NAME = 'CUSTOM_NAME';
+const COMMIT_BUTTON_TEXT = 'button:has-text("Commit Entries")';
+const SINE_WAVE_GENERATOR = 'text=Unnamed Sine Wave Generator';
+const NOTEBOOK_DROP_AREA = '.c-notebook__drag-area';
+
+/**
+ * @param {import('@playwright/test').Page} page
+ */
+async function startAndAddNotebookObject(page) {
+ // eslint-disable-next-line no-undef
+ await page.addInitScript({ path: path.join(__dirname, 'addInitRestrictedNotebook.js') });
+ //Go to baseURL
+ await page.goto('/', { waitUntil: 'networkidle' });
+ //Click the Create button
+ await page.click('button:has-text("Create")');
+ // Click text=CUSTOME_NAME
+ await page.click(`text=${CUSTOM_NAME}`); // secondarily tests renamability also
+ // Click text=OK
+ await Promise.all([
+ page.waitForNavigation({waitUntil: 'networkidle'}),
+ page.click('text=OK')
+ ]);
+
+ return;
+}
+
+/**
+ * @param {import('@playwright/test').Page} page
+ */
+async function enterTextEntry(page) {
+ // Click .c-notebook__drag-area
+ await page.locator(NOTEBOOK_DROP_AREA).click();
+
+ // enter text
+ await page.locator('div.c-ne__text').click();
+ await page.locator('div.c-ne__text').fill(TEST_TEXT);
+ await page.locator('div.c-ne__text').press('Enter');
+
+ return;
+}
+
+/**
+ * @param {import('@playwright/test').Page} page
+ */
+async function dragAndDropEmbed(page) {
+ // Click button:has-text("Create")
+ await page.locator('button:has-text("Create")').click();
+ // Click li:has-text("Sine Wave Generator")
+ await page.locator('li:has-text("Sine Wave Generator")').click();
+ // Click form[name="mctForm"] >> text=My Items
+ await page.locator('form[name="mctForm"] >> text=My Items').click();
+ // Click text=OK
+ await page.locator('text=OK').click();
+ // Click text=Open MCT My Items >> span >> nth=3
+ await page.locator('text=Open MCT My Items >> span').nth(3).click();
+ // Click text=Unnamed CUSTOM_NAME
+ await Promise.all([
+ page.waitForNavigation(),
+ page.locator('text=Unnamed CUSTOM_NAME').click()
+ ]);
+
+ await page.dragAndDrop(SINE_WAVE_GENERATOR, NOTEBOOK_DROP_AREA);
+
+ return;
+}
+
+/**
+ * @param {import('@playwright/test').Page} page
+ */
+async function lockPage(page) {
+ const commitButton = page.locator(COMMIT_BUTTON_TEXT);
+ await commitButton.click();
+
+ // confirmation dialog click
+ await page.locator('text=Lock Page').click();
+
+ // waiting for mutation of locked page
+ await new Promise((resolve, reject) => {
+ setTimeout(resolve, 1000);
+ });
+
+ return;
+}
+
+/**
+ * @param {import('@playwright/test').Page} page
+ */
+async function openContextMenuRestrictedNotebook(page) {
+ // Click text=Open MCT My Items (This expands the My Items folder to show it's chilren in the tree)
+ await page.locator('text=Open MCT My Items >> span').nth(3).click();
+
+ // Click a:has-text("Unnamed CUSTOM_NAME")
+ await page.locator(`a:has-text("Unnamed ${CUSTOM_NAME}")`).click({
+ button: 'right'
+ });
+
+ return;
+}
+
+test.describe('Restricted Notebook', () => {
+
+ test.beforeEach(async ({ page }) => {
+ await startAndAddNotebookObject(page);
+ });
+
+ test('Can be renamed', async ({ page }) => {
+ await expect.soft(page.locator('.l-browse-bar__object-name')).toContainText(`Unnamed ${CUSTOM_NAME}`);
+ });
+
+ test('Can be deleted if there are no locked pages', async ({ page }) => {
+ await openContextMenuRestrictedNotebook(page);
+
+ const menuOptions = page.locator('.c-menu ul');
+ await expect.soft(menuOptions).toContainText('Remove');
+
+ const restrictedNotebookTreeObject = page.locator(`a:has-text("Unnamed ${CUSTOM_NAME}")`);
+
+ // notbook tree object exists
+ expect.soft(await restrictedNotebookTreeObject.count()).toEqual(1);
+
+ // Click text=Remove
+ await page.locator('text=Remove').click();
+ // Click text=OK
+ await Promise.all([
+ page.waitForNavigation(/*{ url: 'http://localhost:8080/#/browse/mine?tc.mode=fixed&tc.startBound=1653671067340&tc.endBound=1653672867340&tc.timeSystem=utc&view=grid' }*/),
+ page.locator('text=OK').click()
+ ]);
+
+ // has been deleted
+ expect.soft(await restrictedNotebookTreeObject.count()).toEqual(0);
+ });
+
+ test('Can be locked if at least one page has one entry', async ({ page }) => {
+
+ await enterTextEntry(page);
+
+ const commitButton = page.locator(COMMIT_BUTTON_TEXT);
+ expect.soft(await commitButton.count()).toEqual(1);
+ });
+
+});
+
+test.describe('Restricted Notebook with at least one entry and with the page locked', () => {
+
+ test.beforeEach(async ({ page }) => {
+ await startAndAddNotebookObject(page);
+ await enterTextEntry(page);
+ await lockPage(page);
+
+ // open sidebar
+ await page.locator('button.c-notebook__toggle-nav-button').click();
+ });
+
+ test('Locked page should now be in a locked state', async ({ page }) => {
+ // main lock message on page
+ const lockMessage = page.locator('text=This page has been committed and cannot be modified or removed');
+ expect.soft(await lockMessage.count()).toEqual(1);
+
+ // lock icon on page in sidebar
+ const pageLockIcon = page.locator('ul.c-notebook__pages li div.icon-lock');
+ expect.soft(await pageLockIcon.count()).toEqual(1);
+
+ // no way to remove a restricted notebook with a locked page
+ await openContextMenuRestrictedNotebook(page);
+
+ const menuOptions = page.locator('.c-menu ul');
+
+ await expect.soft(menuOptions).not.toContainText('Remove');
+
+ });
+
+ test('Can still: add page, rename, add entry, delete unlocked pages', async ({ page }) => {
+ // Click text=Page Add >> button
+ await Promise.all([
+ page.waitForNavigation(),
+ page.locator('text=Page Add >> button').click()
+ ]);
+ // Click text=Unnamed Page >> nth=1
+ await page.locator('text=Unnamed Page').nth(1).click();
+ // Press a with modifiers
+ await page.locator('text=Unnamed Page').nth(1).fill(TEST_TEXT_NAME);
+
+ // expect to be able to rename unlocked pages
+ const newPageElement = page.locator(`text=${TEST_TEXT_NAME}`);
+ const newPageCount = await newPageElement.count();
+ await newPageElement.press('Enter'); // exit contenteditable state
+ expect.soft(newPageCount).toEqual(1);
+
+ // enter test text
+ await enterTextEntry(page);
+
+ // expect new page to be lockable
+ const commitButton = page.locator(COMMIT_BUTTON_TEXT);
+ expect.soft(await commitButton.count()).toEqual(1);
+
+ // Click text=Unnamed PageTest Page >> button
+ await page.locator('text=Unnamed PageTest Page >> button').click();
+ // Click text=Delete Page
+ await page.locator('text=Delete Page').click();
+ // Click text=Ok
+ await Promise.all([
+ page.waitForNavigation(),
+ page.locator('text=Ok').click()
+ ]);
+
+ // deleted page, should no longer exist
+ const deletedPageElement = page.locator(`text=${TEST_TEXT_NAME}`);
+ expect.soft(await deletedPageElement.count()).toEqual(0);
+ });
+});
+
+test.describe('Restricted Notebook with a page locked and with an embed', () => {
+
+ test.beforeEach(async ({ page }) => {
+ await startAndAddNotebookObject(page);
+ await dragAndDropEmbed(page);
+ });
+
+ test('Allows embeds to be deleted if page unlocked', async ({ page }) => {
+ // Click .c-ne__embed__name .c-popup-menu-button
+ await page.locator('.c-ne__embed__name .c-popup-menu-button').click(); // embed popup menu
+
+ const embedMenu = page.locator('body >> .c-menu');
+ await expect.soft(embedMenu).toContainText('Remove This Embed');
+ });
+
+ test('Disallows embeds to be deleted if page locked', async ({ page }) => {
+ await lockPage(page);
+ // Click .c-ne__embed__name .c-popup-menu-button
+ await page.locator('.c-ne__embed__name .c-popup-menu-button').click(); // embed popup menu
+
+ const embedMenu = page.locator('body >> .c-menu');
+ await expect.soft(embedMenu).not.toContainText('Remove This Embed');
+ });
+
+});
diff --git a/e2e/tests/recycled_storage.json b/e2e/tests/recycled_storage.json
index 86c3f906bc..c20b7ee73d 100644
--- a/e2e/tests/recycled_storage.json
+++ b/e2e/tests/recycled_storage.json
@@ -6,11 +6,11 @@
"localStorage": [
{
"name": "tcHistory",
- "value": "{\"utc\":[{\"start\":1651513945533,\"end\":1651515745533}]}"
+ "value": "{\"utc\":[{\"start\":1652301954635,\"end\":1652303754635}]}"
},
{
"name": "mct",
- "value": "{\"mine\":{\"identifier\":{\"key\":\"mine\",\"namespace\":\"\"},\"name\":\"My Items\",\"type\":\"folder\",\"composition\":[{\"key\":\"c0f99e39-85e7-4ef7-99b1-ef52d4ed69b2\",\"namespace\":\"\"}],\"location\":\"ROOT\",\"persisted\":1651515746374,\"modified\":1651515746374},\"c0f99e39-85e7-4ef7-99b1-ef52d4ed69b2\":{\"name\":\"Unnamed Condition Set\",\"type\":\"conditionSet\",\"identifier\":{\"key\":\"c0f99e39-85e7-4ef7-99b1-ef52d4ed69b2\",\"namespace\":\"\"},\"configuration\":{\"conditionTestData\":[],\"conditionCollection\":[{\"isDefault\":true,\"id\":\"e35a066b-eb0e-4b05-a4c9-cc31dc202572\",\"configuration\":{\"name\":\"Default\",\"output\":\"Default\",\"trigger\":\"all\",\"criteria\":[]},\"summary\":\"Default condition\"}]},\"composition\":[],\"telemetry\":{},\"modified\":1651515746373,\"location\":\"mine\",\"persisted\":1651515746373}}"
+ "value": "{\"mine\":{\"identifier\":{\"key\":\"mine\",\"namespace\":\"\"},\"name\":\"My Items\",\"type\":\"folder\",\"composition\":[{\"key\":\"f64bea3b-58a7-4586-8c05-8b651e5f0bfd\",\"namespace\":\"\"}],\"location\":\"ROOT\",\"persisted\":1652303756008,\"modified\":1652303756007},\"f64bea3b-58a7-4586-8c05-8b651e5f0bfd\":{\"name\":\"Unnamed Condition Set\",\"type\":\"conditionSet\",\"identifier\":{\"key\":\"f64bea3b-58a7-4586-8c05-8b651e5f0bfd\",\"namespace\":\"\"},\"configuration\":{\"conditionTestData\":[],\"conditionCollection\":[{\"isDefault\":true,\"id\":\"73f2d9ae-d1f3-4561-b7fc-ecd5df557249\",\"configuration\":{\"name\":\"Default\",\"output\":\"Default\",\"trigger\":\"all\",\"criteria\":[]},\"summary\":\"Default condition\"}]},\"composition\":[],\"telemetry\":{},\"modified\":1652303755999,\"location\":\"mine\",\"persisted\":1652303756002}}"
},
{
"name": "mct-tree-expanded",
diff --git a/e2e/tests/visual/default.visual.spec.js b/e2e/tests/visual/default.visual.spec.js
index dd88b893ad..b069f2e95f 100644
--- a/e2e/tests/visual/default.visual.spec.js
+++ b/e2e/tests/visual/default.visual.spec.js
@@ -192,7 +192,6 @@ test('Visual - Save Successful Banner', async ({ page }) => {
//Wait until Save Banner is gone
await page.waitForSelector('.c-message-banner__message', { state: 'detached'});
await percySnapshot(page, 'Banner message gone');
-
});
test('Visual - Display Layout Icon is correct', async ({ page }) => {
diff --git a/src/plugins/notebook/NotebookType.js b/src/plugins/notebook/NotebookType.js
new file mode 100644
index 0000000000..d112502b79
--- /dev/null
+++ b/src/plugins/notebook/NotebookType.js
@@ -0,0 +1,88 @@
+/*****************************************************************************
+ * Open MCT, Copyright (c) 2014-2022, United States Government
+ * as represented by the Administrator of the National Aeronautics and Space
+ * Administration. All rights reserved.
+ *
+ * Open MCT is licensed under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0.
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ * Open MCT includes source code licensed under additional open source
+ * licenses. See the Open Source Licenses file (LICENSES.md) included with
+ * this source code distribution or the Licensing information page available
+ * at runtime from the About dialog for additional information.
+ *****************************************************************************/
+
+import { IMAGE_MIGRATION_VER } from '../notebook/utils/notebook-migration';
+
+export default class NotebookType {
+ constructor(name, description, icon) {
+ this.name = name;
+ this.description = description;
+ this.cssClass = icon;
+ this.creatable = true;
+ this.form = [
+ {
+ key: 'defaultSort',
+ name: 'Entry Sorting',
+ control: 'select',
+ options: [
+ {
+ name: 'Newest First',
+ value: "newest"
+ },
+ {
+ name: 'Oldest First',
+ value: "oldest"
+ }
+ ],
+ cssClass: 'l-inline',
+ property: [
+ "configuration",
+ "defaultSort"
+ ]
+ },
+ {
+ key: 'sectionTitle',
+ name: 'Section Title',
+ control: 'textfield',
+ cssClass: 'l-inline',
+ required: true,
+ property: [
+ "configuration",
+ "sectionTitle"
+ ]
+ },
+ {
+ key: 'pageTitle',
+ name: 'Page Title',
+ control: 'textfield',
+ cssClass: 'l-inline',
+ required: true,
+ property: [
+ "configuration",
+ "pageTitle"
+ ]
+ }
+ ];
+ }
+
+ initialize(domainObject) {
+ domainObject.configuration = {
+ defaultSort: 'oldest',
+ entries: {},
+ imageMigrationVer: IMAGE_MIGRATION_VER,
+ pageTitle: 'Page',
+ sections: [],
+ sectionTitle: 'Section',
+ type: 'General'
+ };
+ }
+}
diff --git a/src/plugins/notebook/NotebookViewProvider.js b/src/plugins/notebook/NotebookViewProvider.js
new file mode 100644
index 0000000000..66617789c7
--- /dev/null
+++ b/src/plugins/notebook/NotebookViewProvider.js
@@ -0,0 +1,72 @@
+/*****************************************************************************
+ * Open MCT, Copyright (c) 2014-2022, United States Government
+ * as represented by the Administrator of the National Aeronautics and Space
+ * Administration. All rights reserved.
+ *
+ * Open MCT is licensed under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0.
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ * Open MCT includes source code licensed under additional open source
+ * licenses. See the Open Source Licenses file (LICENSES.md) included with
+ * this source code distribution or the Licensing information page available
+ * at runtime from the About dialog for additional information.
+ *****************************************************************************/
+
+import Vue from 'vue';
+import Notebook from './components/Notebook.vue';
+import Agent from '@/utils/agent/Agent';
+
+export default class NotebookViewProvider {
+ constructor(openmct, name, key, type, cssClass, snapshotContainer) {
+ this.openmct = openmct;
+ this.key = key;
+ this.name = `${name} View`;
+ this.type = type;
+ this.cssClass = cssClass;
+ this.snapshotContainer = snapshotContainer;
+ }
+
+ canView(domainObject) {
+ return domainObject.type === this.type;
+ }
+
+ view(domainObject) {
+ let component;
+ let openmct = this.openmct;
+ let snapshotContainer = this.snapshotContainer;
+ let agent = new Agent(window);
+
+ return {
+ show(container) {
+ component = new Vue({
+ el: container,
+ components: {
+ Notebook
+ },
+ provide: {
+ openmct,
+ snapshotContainer,
+ agent
+ },
+ data() {
+ return {
+ domainObject
+ };
+ },
+ template: ''
+ });
+ },
+ destroy() {
+ component.$destroy();
+ }
+ };
+ }
+}
diff --git a/src/plugins/notebook/components/Notebook.vue b/src/plugins/notebook/components/Notebook.vue
index 0fbc83f68a..9dbead306b 100644
--- a/src/plugins/notebook/components/Notebook.vue
+++ b/src/plugins/notebook/components/Notebook.vue
@@ -21,7 +21,10 @@
*****************************************************************************/
-
+
+
+
+
This page has been committed and cannot be modified or removed