Skip to content
Snippets Groups Projects
Select Git revision
  • 4c51bfe232888a47b2a6c508f2cdb27c242ff44b
  • main default protected
  • step-3263
  • feature/plugins-cli
  • feature/vite
  • step-2484-peerreview
  • biest/issue-5051
  • tests/simplify-jsonapi-tests
  • fix/typo-in-1a70031
  • feature/broadcasting
  • database-seeders-and-factories
  • feature/peer-review-2
  • feature-feedback-jsonapi
  • feature/peerreview
  • feature/balloon-plus
  • feature/stock-images-unsplash
  • tic-2588
  • 5.0
  • 5.2
  • biest/unlock-blocks
  • biest-1514
21 results

ManagerApp.vue

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.
    ManagerApp.vue 1.15 KiB
    <template>
        <courseware-course-manager @reload="rebuildStructure"></courseware-course-manager>
    </template>
    
    <script>
    import CoursewareCourseManager from './CoursewareCourseManager.vue';
    import { mapActions, mapGetters } from 'vuex';
    
    export default {
        components: { CoursewareCourseManager },
        computed: {
            ...mapGetters({
                courseware: 'courseware',
                structuralElements: 'courseware-structural-elements/all',
            }),
        },
        methods: {
            ...mapActions({
                buildStructure: 'courseware-structure/build',
                invalidateStructureCache: 'courseware-structure/invalidateCache',
                loadCoursewareStructure: 'courseware-structure/load',
            }),
            async rebuildStructure() {
                // compute order of structural elements once more
                await this.buildStructure();
    
                // throw away stale cache
                this.invalidateStructureCache();
            },
        },
        async mounted() {
            await this.loadCoursewareStructure();
        },
        watch: {
            async structuralElements(newElements, oldElements) {
                this.rebuildStructure();
            },
        },
    };
    </script>