Add role attribution to notebook entries and export (#6793)

Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov>
This commit is contained in:
Michael Rogers 2023-07-13 14:09:00 -05:00 committed by GitHub
parent ac22bebe76
commit 5031010a00
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 31 additions and 6 deletions

View File

@ -105,14 +105,16 @@ export default class ExportNotebookAsTextAction {
if (changes.exportMetaData) {
const createdTimestamp = entry.createdOn;
const createdBy = this.getUserName(entry.createdBy);
const createdByRole = entry.createdByRole;
const modifiedBy = this.getUserName(entry.modifiedBy);
const modifiedByRole = entry.modifiedByRole;
const modifiedTimestamp = entry.modified ?? entry.created;
notebookAsText += `Created on ${this.formatTimeStamp(
createdTimestamp
)} by user ${createdBy}\n\n`;
)} by user ${createdBy}${createdByRole ? `: ${createdByRole}` : ''}\n\n`;
notebookAsText += `Updated on ${this.formatTimeStamp(
modifiedTimestamp
)} by user ${modifiedBy}\n\n`;
)} by user ${modifiedBy}${modifiedByRole ? `: ${modifiedByRole}` : ''}\n\n`;
}
if (changes.exportTags) {

View File

@ -37,7 +37,10 @@
<span class="c-ne__created-date">{{ createdOnDate }}</span>
<span class="c-ne__created-time">{{ createdOnTime }}</span>
<span v-if="entry.createdBy" class="c-ne__creator">
<span class="icon-person"></span> {{ entry.createdBy }}
<span class="icon-person"></span>
{{
entry.createdByRole ? `${entry.createdBy}: ${entry.createdByRole}` : entry.createdBy
}}
</span>
</div>
<span v-if="!readOnly && !isLocked" class="c-ne__local-controls--hidden">
@ -433,10 +436,17 @@ export default {
this.timestampAndUpdate();
},
async timestampAndUpdate() {
const user = await this.openmct.user.getCurrentUser();
const [user, activeRole] = await Promise.all([
this.openmct.user.getCurrentUser(),
this.openmct.user.getActiveRole?.()
]);
if (user === undefined) {
this.entry.modifiedBy = UNKNOWN_USER;
} else {
this.entry.modifiedBy = user.getName();
if (activeRole) {
this.entry.modifiedByRole = activeRole;
}
}
this.entry.modified = Date.now();

View File

@ -12,6 +12,15 @@ async function getUsername(openmct) {
return username;
}
async function getActiveRole(openmct) {
let role = null;
if (openmct.user.hasProvider()) {
role = await openmct.user.getActiveRole?.();
}
return role;
}
export const DEFAULT_CLASS = 'notebook-default';
const TIME_BOUNDS = {
START_BOUND: 'tc.startBound',
@ -156,11 +165,15 @@ export async function addNotebookEntry(
const embeds = embed ? [embed] : [];
const id = `entry-${uuid()}`;
const createdBy = await getUsername(openmct);
const [createdBy, createdByRole] = await Promise.all([
getUsername(openmct),
getActiveRole(openmct)
]);
const entry = {
id,
createdOn: date,
createdBy,
createdByRole,
text: entryText,
embeds
};