Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

N21-1506 sharing ctl tools #3461

Merged
merged 27 commits into from
Dec 9, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
06356a8
share options modal, test and locales
IgorCapCoder Nov 25, 2024
cf2fa93
Merge branch 'main' into N21-1506-sharing-ctl-tools
IgorCapCoder Nov 26, 2024
7cc36b0
import modal, test and locales
IgorCapCoder Nov 26, 2024
a199cd0
update node version
IgorCapCoder Nov 26, 2024
c9e1f88
CopyResultModal, test, de-locales - ToDo: other locales
IgorCapCoder Nov 28, 2024
913d55f
Revert: CopyResultModal, test, de-locales - ToDo: other locales
IgorCapCoder Nov 29, 2024
966ded2
modify a locale
IgorCapCoder Nov 29, 2024
9f96acc
fix i18n tests
IgorCapCoder Nov 29, 2024
4610cd5
Merge branch 'main' into N21-1506-sharing-ctl-tools
IgorCapCoder Nov 29, 2024
adda424
Merge branch 'main' into N21-1506-sharing-ctl-tools
IgorCapCoder Dec 1, 2024
c8feea0
N21-1506 add data-testid
GordonNicholasCap Dec 2, 2024
65947e0
requested changes
IgorCapCoder Dec 2, 2024
4fb0ac3
...
IgorCapCoder Dec 2, 2024
a7d1895
Merge branch 'main' into N21-1506-sharing-ctl-tools
IgorCapCoder Dec 2, 2024
1b96a7a
...
IgorCapCoder Dec 2, 2024
a4ec323
requested changes locale keys
IgorCapCoder Dec 3, 2024
711efc0
add data-testid
MBergCap Dec 4, 2024
5eb17e0
add data-testid
MBergCap Dec 4, 2024
58ead6e
requested changes locales, <p>
IgorCapCoder Dec 4, 2024
6172c9b
N21-1506 show copy failed board external tool elements in copy result…
GordonNicholasCap Dec 4, 2024
381461a
N21-1506 show report when failing to copy course tools
GordonNicholasCap Dec 5, 2024
a7b726f
Merge branch 'main' into N21-1506-sharing-ctl-tools
IgorCapCoder Dec 5, 2024
172da66
- move deleted element warning alert below element
IgorCapCoder Dec 5, 2024
41b0cc9
N21-1506 fix missing warning text for failed board tools copy
GordonNicholasCap Dec 5, 2024
c49b78e
Merge branch 'main' into N21-1506-sharing-ctl-tools
GordonNicholasCap Dec 5, 2024
3f38e58
Merge branch 'main' into N21-1506-sharing-ctl-tools
GordonNicholasCap Dec 5, 2024
cc42f04
N21-1506 review changes
GordonNicholasCap Dec 6, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
112 changes: 68 additions & 44 deletions src/components/copy-result-modal/CopyResultModal.unit.ts
Original file line number Diff line number Diff line change
Expand Up @@ -151,53 +151,77 @@ describe("@/components/copy-result-modal/CopyResultModal", () => {
);
});

it("should render ctl tools info if root item is a Course and has no failed file ", () => {
const copyResultItems = mockLessonResultItems([]);

const envs = envsFactory.build({
FEATURE_CTL_TOOLS_TAB_ENABLED: true,
});
envConfigModule.setEnvs(envs);
const wrapper = createWrapper({
isOpen: true,
copyResultItems,
copyResultRootItemType: CopyApiResponseTypeEnum.Course,
});

const dialog = wrapper.findComponent(vCustomDialog);
const content = dialog.findComponent(".v-card-text").text();

expect(content).toContain(
"components.molecules.copyResult.ctlTools.info"
);
});

describe("when root item is a Course, has no failed file and CTL_TOOLS_COPY feature flag is enabled", () => {
const setup = () => {
const copyResultItems = mockLessonResultItems([]);
const wrapper = createWrapper({
isOpen: true,
copyResultItems,
copyResultRootItemType: CopyApiResponseTypeEnum.Course,
describe("when there is no failed file and CTL_TOOLS_COPY & CTL_TOOLS_TAB_ENABLED feature flag is enabled", () => {
describe("when the item has element of type external tool", () => {
const setup = () => {
const envs = envsFactory.build({
FEATURE_CTL_TOOLS_TAB_ENABLED: true,
FEATURE_CTL_TOOLS_COPY_ENABLED: true,
});
envConfigModule.setEnvs(envs);

const copyResultItems = mockLessonResultItems([]);
copyResultItems[0].elements.push({
title: "Course External Tool",
type: CopyApiResponseTypeEnum.ExternalTool,
});
copyResultItems[0].type = CopyApiResponseTypeEnum.Course;

const wrapper = createWrapper({
isOpen: true,
copyResultItems,
copyResultRootItemType: CopyApiResponseTypeEnum.Course,
});

return { wrapper };
};

it("should show the warning text for non-copyable course external tools", () => {
const { wrapper } = setup();

const dialog = wrapper.findComponent(vCustomDialog);
const content = dialog.findComponent(".v-card-text").text();

expect(content).toContain(
"components.molecules.copyResult.ctlTools.withFeature.info"
);
});
});

return { wrapper };
};

it("should render ctl tools copy info ", () => {
const envs = envsFactory.build({
FEATURE_CTL_TOOLS_TAB_ENABLED: true,
FEATURE_CTL_TOOLS_COPY_ENABLED: true,
describe("when there is an item of type ExternalToolElement", () => {
const setup = () => {
const envs = envsFactory.build({
FEATURE_CTL_TOOLS_TAB_ENABLED: true,
FEATURE_CTL_TOOLS_COPY_ENABLED: true,
});
envConfigModule.setEnvs(envs);

const copyResultItems = mockLessonResultItems([]);
copyResultItems[0].elements.push({
title: "Board External Tool Element",
type: CopyApiResponseTypeEnum.ExternalToolElement,
});
copyResultItems[0].type = CopyApiResponseTypeEnum.Course;

const wrapper = createWrapper({
isOpen: true,
copyResultItems,
copyResultRootItemType: CopyApiResponseTypeEnum.Course,
});

return { wrapper };
};

it("should show the warning text for non-copyable course external tools", () => {
const { wrapper } = setup();

const dialog = wrapper.findComponent(vCustomDialog);
const content = dialog.findComponent(".v-card-text").text();

expect(content).toContain(
"components.molecules.copyResult.ctlTools.withFeature.info"
);
});
envConfigModule.setEnvs(envs);
const { wrapper } = setup();

const dialog = wrapper.findComponent(vCustomDialog);
const content = dialog.findComponent(".v-card-text").text();

expect(content).toContain(
"components.molecules.copyResult.ctlTools.withFeature.info"
);
});
});

Expand Down
18 changes: 16 additions & 2 deletions src/components/copy-result-modal/CopyResultModal.vue
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,9 @@ export default {
title: this.$t("components.molecules.copyResult.label.files"),
},
{
isShow: this.hasFeatureCtlsToolsenabled,
isShow:
this.isFeatureCtlToolsEnabled &&
(this.hasExternalTool || this.hasExternalToolElement),
text: this.externalToolsInfoText,
title: this.$t("components.molecules.copyResult.label.externalTools"),
},
Expand Down Expand Up @@ -178,7 +180,7 @@ export default {
CopyApiResponseTypeEnum.CoursegroupGroup
);
},
hasFeatureCtlsToolsenabled() {
isFeatureCtlToolsEnabled() {
return envConfigModule.getCtlToolsTabEnabled;
},
hasErrors() {
Expand Down Expand Up @@ -206,6 +208,18 @@ export default {
? this.$t("components.molecules.copyResult.ctlTools.withFeature.info")
: this.$t("components.molecules.copyResult.ctlTools.info");
},
hasExternalTool() {
return this.hasElementOfType(
this.items,
CopyApiResponseTypeEnum.ExternalTool
);
},
hasExternalToolElement() {
return this.hasElementOfType(
this.items,
CopyApiResponseTypeEnum.ExternalToolElement
);
},
},
methods: {
hasElementOfType(items, types) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -161,6 +161,10 @@ describe("@/components/copy-result-modal/CopyResultModalListItem", () => {
CopyApiResponseTypeEnum.CollaborativeTextEditorElement,
"components.molecules.copyResult.label.etherpad",
],
[
CopyApiResponseTypeEnum.ExternalToolElement,
"components.molecules.copyResult.label.toolElements",
],
];

map.forEach(([constant, languageConstant]) => {
Expand Down
3 changes: 3 additions & 0 deletions src/components/copy-result-modal/CopyResultModalListItem.vue
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
v-for="element in aggregatedElements()"
:key="element.type"
class="element-info"
data-testid="copy-result-list-item-element-info"
>
<span>
{{ element.count }} {{ element.type }}
Expand Down Expand Up @@ -121,6 +122,8 @@ export default {
return this.$t("components.molecules.copyResult.label.columnBoard");
case CopyApiResponseTypeEnum.DrawingElement:
return this.$t("components.molecules.copyResult.label.tldraw");
case CopyApiResponseTypeEnum.ExternalToolElement:
return this.$t("components.molecules.copyResult.label.toolElements");
default:
return this.$t("components.molecules.copyResult.label.unknown");
}
Expand Down
12 changes: 6 additions & 6 deletions src/components/share/ImportModal.unit.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,11 @@ import ImportModal from "@/components/share/ImportModal.vue";
import EnvConfigModule from "@/store/env-config";
import { ENV_CONFIG_MODULE_KEY } from "@/utils/inject";
import { createModuleMocks } from "@@/tests/test-utils/mock-store-module";
import { mount } from "@vue/test-utils";
import {
createTestingI18n,
createTestingVuetify,
} from "@@/tests/test-utils/setup";
import { mount } from "@vue/test-utils";

describe("@components/share/ImportModal", () => {
const setup = (envConfigModuleGetter?: Partial<EnvConfigModule>) => {
Expand Down Expand Up @@ -122,11 +122,11 @@ describe("@components/share/ImportModal", () => {
`[data-testid="import-modal-external-tools-info"]`
);

expect(infoText.attributes("html")).toEqual(
"components.molecules.import.courses.options.ctlTools.infoText"
expect(infoText.text()).toEqual(
"components.molecules.shareImport.options.ctlTools.infoText.unavailable"
);
});
it("should not show course file info", () => {
it("should also show course file info", () => {
const { wrapper } = setup({ getCtlToolsTabEnabled: true });

const dialog = wrapper.findComponent({ name: "v-custom-dialog" });
Expand All @@ -136,7 +136,7 @@ describe("@components/share/ImportModal", () => {
`[data-testid="import-modal-coursefiles-info"]`
);

expect(infoText.exists()).toBe(false);
expect(infoText.exists()).toBe(true);
});
});
describe("show ctl tool info is disabled", () => {
Expand Down Expand Up @@ -176,7 +176,7 @@ describe("@components/share/ImportModal", () => {
);

expect(infoText.element.innerHTML).toEqual(
"components.molecules.import.courses.options.infoText"
"components.molecules.shareImport.options.restrictions.infoText.courseFiles"
);
});
});
Expand Down
87 changes: 70 additions & 17 deletions src/components/share/ImportModal.vue
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
confirm-btn-title-key="common.actions.import"
@dialog-confirmed="onConfirm"
@dialog-canceled="onCancel"
data-testid="import-modal"
>
<template #title>
<div ref="textTitle" class="text-h4 my-2">
Expand All @@ -21,39 +22,88 @@
<div class="mx-2">
<v-icon color="info" :icon="mdiInformation" />
</div>
<RenderHTML
data-testid="import-modal-external-tools-info"
v-if="ctlToolsEnabled && parentType === 'courses'"
:html="
t(
`components.molecules.import.${parentType}.options.ctlTools.infoText`
)
"
/>
<div v-else data-testid="import-modal-coursefiles-info">
{{
t(`components.molecules.import.${parentType}.options.infoText`)
}}
<div data-testid="import-options-table-header">
{{ t("components.molecules.import.options.tableHeader.InfoText") }}
<ul class="ml-6">
<li data-testid="import-options-personal-data-text">
{{
t(
"components.molecules.shareImport.options.restrictions.infoText.personalData"
)
}}
</li>
<li
v-if="showCtlToolsInfo"
data-testid="import-modal-external-tools-info"
>
{{
t(
"components.molecules.shareImport.options.ctlTools.infoText.unavailable"
)
}}
</li>
<li
v-if="showCtlToolsInfo"
data-testid="import-modal-external-tools-protected-parameter-info"
>
{{
t(
"components.molecules.shareImport.options.ctlTools.infoText.protected"
)
}}
</li>
<li data-testid="import-modal-coursefiles-info">
{{
t(
"components.molecules.shareImport.options.restrictions.infoText.courseFiles"
)
}}
</li>
<li>
{{
t(
"components.molecules.shareImport.options.restrictions.infoText.etherpad"
)
}}
</li>
<li>
{{
t(
"components.molecules.shareImport.options.restrictions.infoText.geogebra"
)
}}
</li>
<li>
{{
t(
"components.molecules.shareImport.options.restrictions.infoText.courseGroups"
)
}}
</li>
</ul>
</div>
</div>
<div class="mb-4">
{{ t(`components.molecules.import.${parentType}.rename`) }}
</div>
<v-text-field
ref="nameInputText"
v-model="newName"
:label="t(`components.molecules.import.${parentType}.label`)"
:rules="[rules.required]"
data-testid="import-modal-name-input"
/>
</div>
</template>
</v-custom-dialog>
</template>

<script setup>
import vCustomDialog from "@/components/organisms/vCustomDialog.vue";
import VCustomDialog from "@/components/organisms/vCustomDialog.vue";
import { ENV_CONFIG_MODULE_KEY, injectStrict } from "@/utils/inject";
import { mdiInformation } from "@icons/material";
import { computed, reactive, ref } from "vue";
import { useI18n } from "vue-i18n";
import { RenderHTML } from "@feature-render-html";

const emit = defineEmits(["import", "cancel"]);
const props = defineProps({
Expand Down Expand Up @@ -82,7 +132,10 @@ const onConfirm = () => {
};
const onCancel = () => emit("cancel");

const ctlToolsEnabled = computed(() => {
return envConfigModule.getCtlToolsTabEnabled;
const showCtlToolsInfo = computed(() => {
return (
envConfigModule.getCtlToolsTabEnabled &&
(props.parentType === "courses" || props.parentType === "columnBoard")
);
});
</script>
Loading
Loading