Skip to content
Snippets Groups Projects
Select Git revision
  • a3da1483a9e689846179159355badfec8073dbec
  • main default protected
  • studip-rector
  • ci-opt
  • course-members-export-as-word
  • data-vue-app
  • pipeline-improvements
  • webpack-optimizations
  • rector
  • icon-renewal
  • http-client-and-factories
  • jsonapi-atomic-operations
  • vueify-messages
  • tic-2341
  • 135-translatable-study-areas
  • extensible-sorm-action-parameters
  • sorm-configuration-trait
  • jsonapi-mvv-routes
  • docblocks-for-magic-methods
19 results

ModulesNotification.class.php

Blame
  • Forked from Stud.IP / Stud.IP
    Source project has a limited visibility.
    Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    CoursewareImportWidget.vue 1.81 KiB
    <template>
        <sidebar-widget :title="$gettext('Import')">
            <template #content>
                <ul class="widget-list widget-links cw-import-widget">
                    <li class="cw-import-widget-archive">
                        <button @click="importElements">
                            {{ $gettext('Seiten importieren') }}
                        </button>
                    </li>
                    <li class="cw-import-widget-copy">
                        <button @click="copyElements">
                            {{ $gettext('Seiten kopieren') }}
                        </button>
                    </li>
                    <li v-if="inCourseContext && userIsTeacher" class="cw-action-widget-link">
                        <button @click="linkElement">
                            {{ $gettext('Seiten verknüpfen') }}
                        </button>
                    </li>
                </ul>
            </template>
        </sidebar-widget>
    </template>
    
    <script>
    import SidebarWidget from '../SidebarWidget.vue';
    import { mapActions, mapGetters } from 'vuex';
    
    export default {
        name: 'courseware-import-widget',
        components: {
            SidebarWidget,
        },
        computed: {
            ...mapGetters({
                context: 'context',
                userIsTeacher: 'userIsTeacher',
            }),
            inCourseContext() {
                return this.context.type === 'courses';
            }
        },
        methods: {
            ...mapActions({
                showElementImportDialog: 'showElementImportDialog',
                showElementCopyDialog: 'showElementCopyDialog',
                showElementLinkDialog: 'showElementLinkDialog',
            }),
            importElements() {
                this.showElementImportDialog(true);
            },
            copyElements() {
                this.showElementCopyDialog(true);
            },
            linkElement() {
                this.showElementLinkDialog(true);
            },
        },
    }
    </script>