{"version":3,"sources":["webpack:///./src/components/Learning/List/Nav.vue?abaa","webpack:///./src/components/common/BgTop.vue?cb01","webpack:///./src/components/common/BgTop.vue","webpack:///src/components/common/BgTop.vue","webpack:///./src/components/common/BgTop.vue?21c7","webpack:///./src/components/common/BgTop.vue?9c80","webpack:///./src/components/Learning/List/SwitchList.vue?fcb2","webpack:///./src/components/Learning/List/Nav.vue","webpack:///src/components/Learning/List/Nav.vue","webpack:///./src/components/Learning/List/Nav.vue?9ae0","webpack:///./src/components/Learning/List/Nav.vue?d0db","webpack:///./src/views/Learning/components/List.vue","webpack:///./src/components/Learning/List/SwitchList.vue","webpack:///src/components/Learning/List/SwitchList.vue","webpack:///./src/components/Learning/List/SwitchList.vue?a4f8","webpack:///./src/components/Learning/List/SwitchList.vue?a4f2","webpack:///src/views/Learning/components/List.vue","webpack:///./src/views/Learning/components/List.vue?11ee","webpack:///./src/views/Learning/components/List.vue?1e8a","webpack:///./src/components/Learning/List/CubeItem.vue","webpack:///src/components/Learning/List/CubeItem.vue","webpack:///./src/components/Learning/List/CubeItem.vue?7afd","webpack:///./src/components/Learning/List/CubeItem.vue?6bbf","webpack:///./src/components/Learning/List/CubeItem.vue?5e77","webpack:///./src/views/Learning/components/List.vue?d6ab"],"names":["render","_vm","this","_c","_self","staticClass","attrs","title","_t","staticRenderFns","props","components","Breadcrumb","component","loading","_v","model","value","curSubject","callback","$$v","expression","_l","subjectList","item","key","Id","_s","Title","children","subItem","class","curSubSubject","on","$event","changeSubSubject","subsubitem","_e","data","computed","subjectListNoTree","methods","getParentId","changeSubject","createIds","ids","parent","findId","curItem","ele","ParentId","created","subjectChange","onSearch","params","total","list","length","switchtype","switchList","grid","scopedSlots","_u","fn","pageSize","pageIndex","pageChange","curSwitch","changeType","icon","name","metaInfo","meta","content","BgTop","Nav","Search","SwitchList","Pagination","CubeItem","ListItem","navList","mateInfo","subject","gutter","column","setTimeout","console","then","res","catch","e","document","goDetail","ImageUrl","Name","slot","IsCollection","toggleCollect","Info","time","userInfo","id","ToggleCollectModel"],"mappings":"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","file":"js/chunk-715d1e05.2430a609.js","sourcesContent":["export * from \"-!../../../../node_modules/@vue/cli-service/node_modules/mini-css-extract-plugin/dist/loader.js??ref--11-oneOf-1-0!../../../../node_modules/css-loader/dist/cjs.js??ref--11-oneOf-1-1!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../node_modules/postcss-loader/src/index.js??ref--11-oneOf-1-2!../../../../node_modules/less-loader/dist/cjs.js??ref--11-oneOf-1-3!../../../../node_modules/style-resources-loader/lib/index.js??ref--11-oneOf-1-4!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./Nav.vue?vue&type=style&index=0&id=1c932c2e&prod&scoped=true&lang=less&\"","export * from \"-!../../../node_modules/@vue/cli-service/node_modules/mini-css-extract-plugin/dist/loader.js??ref--11-oneOf-1-0!../../../node_modules/css-loader/dist/cjs.js??ref--11-oneOf-1-1!../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../node_modules/postcss-loader/src/index.js??ref--11-oneOf-1-2!../../../node_modules/less-loader/dist/cjs.js??ref--11-oneOf-1-3!../../../node_modules/style-resources-loader/lib/index.js??ref--11-oneOf-1-4!../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./BgTop.vue?vue&type=style&index=0&id=56c647b2&prod&scoped=true&lang=less&\"","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"top\"},[_c('div',{staticClass:\"auto-1440\"},[_c('Breadcrumb',{attrs:{\"title\":_vm.title,\"type\":\"grey\"}}),_vm._t(\"default\")],2)])\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\r\n    <div class=\"top\">\r\n        <div class=\"auto-1440\">\r\n            <Breadcrumb :title=\"title\" type=\"grey\" />\r\n            <slot></slot>\r\n        </div>\r\n    </div>\r\n</template>\r\n<script>\r\nimport Breadcrumb from '@/components/common/Breadcrumb'\r\nexport default {\r\n    props: ['title'],\r\n    components: {\r\n        Breadcrumb,\r\n    },\r\n}\r\n</script>\r\n<style scoped lang=\"less\">\r\n.top {\r\n    // background: url('~@/assets/images/learning_nav_bg.jpg') center bottom / cover no-repeat;\r\n    // padding-bottom: 40px;\r\n}\r\n</style>\r\n","import mod from \"-!../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../node_modules/babel-loader/lib/index.js!../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./BgTop.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../node_modules/babel-loader/lib/index.js!../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./BgTop.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./BgTop.vue?vue&type=template&id=56c647b2&scoped=true&\"\nimport script from \"./BgTop.vue?vue&type=script&lang=js&\"\nexport * from \"./BgTop.vue?vue&type=script&lang=js&\"\nimport style0 from \"./BgTop.vue?vue&type=style&index=0&id=56c647b2&prod&scoped=true&lang=less&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n  script,\n  render,\n  staticRenderFns,\n  false,\n  null,\n  \"56c647b2\",\n  null\n  \n)\n\nexport default component.exports","export * from \"-!../../../../node_modules/@vue/cli-service/node_modules/mini-css-extract-plugin/dist/loader.js??ref--11-oneOf-1-0!../../../../node_modules/css-loader/dist/cjs.js??ref--11-oneOf-1-1!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../node_modules/postcss-loader/src/index.js??ref--11-oneOf-1-2!../../../../node_modules/less-loader/dist/cjs.js??ref--11-oneOf-1-3!../../../../node_modules/style-resources-loader/lib/index.js??ref--11-oneOf-1-4!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./SwitchList.vue?vue&type=style&index=0&id=a1752eb2&prod&scoped=true&lang=less&\"","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"filter\"},[_c('a-skeleton',{attrs:{\"active\":\"\",\"loading\":_vm.loading}},[_c('div',{staticClass:\"cate\"},[_c('div',{staticClass:\"item\"},[_vm._v(\" 专业 \")]),_c('a-select',{staticClass:\"item-select\",model:{value:(_vm.curSubject),callback:function ($$v) {_vm.curSubject=$$v},expression:\"curSubject\"}},[_c('a-select-option',{attrs:{\"value\":\"all\"}},[_vm._v(\"全部\")]),_vm._l((_vm.subjectList),function(item){return _c('a-select-option',{key:item.Id,attrs:{\"value\":item.Id}},[_vm._v(_vm._s(item.Title))])})],2)],1),_c('div',{staticClass:\"subCate\"},[_vm._l((_vm.subjectList),function(item){return [(item.Id == _vm.curSubject)?_c('div',{key:item.Id},_vm._l((item.children),function(subItem){return _c('div',{key:subItem.Id,staticClass:\"item\"},[_c('div',{staticClass:\"label\"},[_c('span',{staticClass:\"tag\"},[_vm._v(_vm._s(subItem.Title))])]),_c('div',{staticClass:\"subCate_inner\"},[_c('div',{staticClass:\"subCate_item\",class:subItem.Id == _vm.curSubSubject\n                                        ? 'active'\n                                        : '',on:{\"click\":function($event){return _vm.changeSubSubject(subItem)}}},[_c('span',{staticClass:\"tag\"},[_vm._v(\"全部\")])]),_vm._l((subItem.children),function(subsubitem){return _c('div',{key:subsubitem.Id,staticClass:\"subCate_item\",class:subsubitem.Id == _vm.curSubSubject\n                                        ? 'active'\n                                        : '',attrs:{\"id\":subsubitem.Id},on:{\"click\":function($event){return _vm.changeSubSubject(subsubitem)}}},[_c('span',{staticClass:\"tag\"},[_vm._v(\" \"+_vm._s(subsubitem.Title)+\" \")])])})],2)])}),0):_vm._e()]})],2)])],1)\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\r\n    <div class=\"filter\">\r\n        <a-skeleton active :loading=\"loading\">\r\n            <div class=\"cate\">\r\n                <div\r\n                    class=\"item\"\r\n                >\r\n                    专业\r\n                </div>\r\n                <!-- <div\r\n                    class=\"item\"\r\n                    key=\"all\"\r\n                    :class=\"curSubject == 'all' ? 'active' : ''\"\r\n                    @click=\"changeSubject('all')\"\r\n                >\r\n                    全部\r\n                </div> -->\r\n                <!-- <div\r\n                    class=\"item\"\r\n                    :id=\"item.Id\"\r\n                    :class=\"item.Id == curSubject ? 'active' : ''\"\r\n                    v-for=\"item in subjectList\"\r\n                    :key=\"item.Id\"\r\n                    @click=\"changeSubject(item)\"\r\n                >\r\n                    <span>{{ item.Title }}</span>\r\n                </div> -->\r\n                <a-select\r\n                    v-model=\"curSubject\"\r\n                    class=\"item-select\"\r\n                >\r\n                    <a-select-option\r\n                        value=\"all\" \r\n                    >全部</a-select-option>\r\n                    <a-select-option\r\n                        v-for=\"item in subjectList\"\r\n                        :value=\"item.Id\" \r\n                        :key=\"item.Id\"\r\n                    >{{ item.Title }}</a-select-option>\r\n                </a-select>\r\n            </div>\r\n            <div class=\"subCate\">\r\n                <template v-for=\"item in subjectList\">\r\n                    <div v-if=\"item.Id == curSubject\" :key=\"item.Id\">\r\n                        <div\r\n                            class=\"item\"\r\n                            v-for=\"subItem in item.children\"\r\n                            :key=\"subItem.Id\"\r\n                        >\r\n                            <div class=\"label\">\r\n                                <span class=\"tag\">{{ subItem.Title }}</span>\r\n                            </div>\r\n                            <div class=\"subCate_inner\">\r\n                                <div\r\n                                    class=\"subCate_item\"\r\n                                    @click=\"changeSubSubject(subItem)\"\r\n                                    :class=\"\r\n                                        subItem.Id == curSubSubject\r\n                                            ? 'active'\r\n                                            : ''\r\n                                    \"\r\n                                >\r\n                                    <span class=\"tag\">全部</span>\r\n                                </div>\r\n                                <div\r\n                                    class=\"subCate_item\"\r\n                                    v-for=\"subsubitem in subItem.children\"\r\n                                    :key=\"subsubitem.Id\"\r\n                                    :id=\"subsubitem.Id\"\r\n                                    :class=\"\r\n                                        subsubitem.Id == curSubSubject\r\n                                            ? 'active'\r\n                                            : ''\r\n                                    \"\r\n                                    @click=\"changeSubSubject(subsubitem)\"\r\n                                >\r\n                                    <span class=\"tag\">\r\n                                        {{ subsubitem.Title }}\r\n                                    </span>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </template>\r\n            </div>\r\n        </a-skeleton>\r\n    </div>\r\n</template>\r\n<script>\r\nimport { mapState, mapActions, mapMutations } from 'vuex'\r\nexport default {\r\n    data() {\r\n        return {\r\n            subjectList: [],\r\n            curSubject: '',\r\n            curSubSubject: '',\r\n            loading: false,\r\n        }\r\n    },\r\n    computed: {\r\n        ...mapState({\r\n            subjectListNoTree: state => state.model.subjectListNoTree,\r\n        }),\r\n    },\r\n    methods: {\r\n        getParentId (list,id) {\r\n            const item = list.find(item => item.Id == id)\r\n            \r\n            if(item.ParentId) {\r\n                return this.getParentId(list,item.ParentId)\r\n            } else {\r\n                return item.Id\r\n            }\r\n        },\r\n        // 获取考试科目\r\n        async getSubjectList() {\r\n            this.loading = true\r\n            this.subjectList = await this.$store.dispatch('model/getSubject')\r\n            \r\n            // 获取导航科目id\r\n            const id = this.$route.query.subject\r\n            let parent = this.getParentId(this.subjectListNoTree,id)\r\n            if(!id && !parent) {\r\n                this.$emit('change', [])\r\n                this.curSubject = 'all'\r\n                this.loading = false\r\n                return\r\n            }\r\n            // 获取各级选中id\r\n            if (id) {\r\n                this.curSubject = id\r\n            } else if(parent) {\r\n                this.curSubject = parent\r\n            } \r\n            this.curSubject = Number(this.findId(id).curSubject)\r\n            this.curSubSubject = this.findId(id).curSubSubject\r\n            const curSubjectItem = this.findId(id).curItem\r\n            \r\n            const ids = this.createIds(curSubjectItem)\r\n            \r\n            // 触发父级事件\r\n            this.$emit('change', ids)\r\n            \r\n            this.loading = false\r\n        },\r\n        // 切换一级考试科目\r\n        changeSubject(item) {\r\n            this.curSubSubject = ''\r\n            this.curSubject = item?.Id || 'all'\r\n            if (item == 'all') {\r\n                const ids = []\r\n                this.$emit('change', ids)\r\n            } else {\r\n                this.curSubject = item?.Id || 'all'\r\n                const ids = this.createIds(item)\r\n                this.$emit('change', ids)\r\n            }\r\n        },\r\n        // 切换二级考试科目\r\n        changeSubSubject(item) {\r\n            this.curSubSubject = item.Id\r\n            const ids = this.createIds(item)\r\n            this.$emit('change', ids)\r\n        },\r\n        // 获取选中ids\r\n        createIds(parent) {\r\n            if (!parent.children) {\r\n                return [parent.Id]\r\n            } else {\r\n                let ids = []\r\n                ids.push(parent.Id)\r\n                parent.children.forEach(ele => {\r\n                    ids.push(ele.Id)\r\n                    if (ele.children) {\r\n                        ids = ids.concat(ele.children.map(i => i.Id))\r\n                    }\r\n                })\r\n                return ids\r\n            }\r\n        },\r\n        // 根据id查找选中id以及选中父级id\r\n        findId(id) {\r\n            let curItem, curSubject, curSubSubject\r\n\r\n            if (id) {\r\n                this.subjectListNoTree.forEach(item => {\r\n                    if (item.Id == id) {\r\n                        curItem = item\r\n                        curSubSubject = item.Id\r\n                        if(item.ParentId) {\r\n                            curSubject = this.subjectListNoTree.find(\r\n                                ele => ele.Id == item?.ParentId\r\n                            ).ParentId\r\n                        }else {\r\n                            curSubject = item.Id\r\n                        }\r\n                        \r\n                    }\r\n                })\r\n            } else {\r\n                curItem = this.subjectList[0]\r\n                curSubject = this.subjectList[0].Id\r\n                curSubSubject = ''\r\n            }\r\n            return {\r\n                curItem,\r\n                curSubject,\r\n                curSubSubject,\r\n            }\r\n        },\r\n    },\r\n    created() {\r\n        this.getSubjectList()\r\n    },\r\n}\r\n</script>\r\n<style scoped lang=\"less\">\r\n@import '~@/assets/css/TopList.less';\r\n\r\n.item-select {\r\n    margin: 10px 0;\r\n    width: 300px;\r\n}\r\n</style>\r\n","import mod from \"-!../../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./Nav.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./Nav.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./Nav.vue?vue&type=template&id=1c932c2e&scoped=true&\"\nimport script from \"./Nav.vue?vue&type=script&lang=js&\"\nexport * from \"./Nav.vue?vue&type=script&lang=js&\"\nimport style0 from \"./Nav.vue?vue&type=style&index=0&id=1c932c2e&prod&scoped=true&lang=less&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n  script,\n  render,\n  staticRenderFns,\n  false,\n  null,\n  \"1c932c2e\",\n  null\n  \n)\n\nexport default component.exports","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"learning-list\"},[_c('BgTop',[_c('Nav',{on:{\"change\":_vm.subjectChange}})],1),_c('div',{staticClass:\"main\"},[_c('div',{staticClass:\"auto-1440\"},[_c('div',{staticClass:\"search-wrap\"},[_c('Search',{on:{\"search\":_vm.onSearch},model:{value:(_vm.params),callback:function ($$v) {_vm.params=$$v},expression:\"params\"}}),_c('SwitchList',{attrs:{\"total\":_vm.total,\"pageSize\":_vm.list.length,\"curSwitch\":_vm.switchtype},on:{\"change\":_vm.switchList}})],1),_c('div',{staticClass:\"list clearfix\"},[_c('a-list',{attrs:{\"grid\":_vm.grid[_vm.switchtype],\"data-source\":_vm.list,\"loading\":_vm.loading},scopedSlots:_vm._u([{key:\"renderItem\",fn:function(item){return _c('a-list-item',{},[(_vm.switchtype == 0)?_c('CubeItem',{attrs:{\"data\":item}}):_c('ListItem',{attrs:{\"data\":item}})],1)}}])})],1),_c('Pagination',{attrs:{\"pageSize\":_vm.params.pageSize,\"total\":_vm.total,\"current\":_vm.params.pageIndex},on:{\"pageChange\":_vm.pageChange}})],1)])],1)\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"switch\"},[_c('div',{staticClass:\"sum\"},[_vm._v(\" 共计\"+_vm._s(_vm.total)+\"个,当前页面呈现\"+_vm._s(_vm.pageSize)+\"个 \")]),_c('div',{staticClass:\"switch_box\"},_vm._l((_vm.switchList),function(item){return _c('div',{key:item.value,class:['item',item.value == _vm.curSwitch ? 'active':''],on:{\"click\":function($event){return _vm.changeType(item.value)}}},[_c('svg-icon',{staticClass:\"icon\",attrs:{\"icon-class\":item.icon}})],1)}),0)])\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\r\n    <div class=\"switch\">\r\n        <div class=\"sum\">\r\n            共计{{total}}个,当前页面呈现{{pageSize}}个\r\n        </div>\r\n        <div class=\"switch_box\">\r\n            <div \r\n                :class=\"['item',item.value == curSwitch ? 'active':'']\" \r\n                v-for=\"item in switchList\" \r\n                :key=\"item.value\"\r\n                @click=\"changeType(item.value)\"\r\n            >\r\n                <svg-icon class=\"icon\" :icon-class=\"item.icon\"></svg-icon>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</template>\r\n<script>\r\nexport default {\r\n    props:['total','pageSize','curSwitch'],\r\n    data(){\r\n        return{\r\n            switchList:[\r\n                {\r\n                    name:'cube',\r\n                    value:0,\r\n                    icon:'icon_cube'\r\n                },\r\n                {\r\n                    name:'list',\r\n                    value:1,\r\n                    icon:'icon_list'\r\n                }\r\n            ],\r\n        }\r\n    },\r\n    methods:{\r\n        changeType(val){\r\n            // this.curSwitch = val\r\n            this.$emit('change',val)\r\n        }\r\n    }\r\n}\r\n</script>\r\n<style scoped lang=\"less\">\r\n.switch{\r\n    display: flex;\r\n    justify-content: space-between;\r\n    align-items: center;\r\n    margin-bottom: 10px;\r\n    .sum{\r\n        font-size: 18px;\r\n        color: rgb(136, 136, 136);\r\n    }\r\n    .switch_box{\r\n        display: flex;\r\n        .item{\r\n            width: 36px;\r\n            height: 36px;\r\n            background-color: #f5f5f5;\r\n            border-radius: 3px;\r\n            display: flex;\r\n            align-items: center;\r\n            justify-content: center;\r\n            margin-left: 10px;\r\n            color: #bbb;\r\n            cursor: pointer;\r\n            transition: .3s;\r\n            .icon{\r\n                font-size: 26px;\r\n                color: #bbb;\r\n            }\r\n            &:hover,\r\n            &.active{\r\n                \r\n                background-color: #e5e5e5;\r\n                .icon{\r\n                    color: #888;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n</style>","import mod from \"-!../../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./SwitchList.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./SwitchList.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./SwitchList.vue?vue&type=template&id=a1752eb2&scoped=true&\"\nimport script from \"./SwitchList.vue?vue&type=script&lang=js&\"\nexport * from \"./SwitchList.vue?vue&type=script&lang=js&\"\nimport style0 from \"./SwitchList.vue?vue&type=style&index=0&id=a1752eb2&prod&scoped=true&lang=less&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n  script,\n  render,\n  staticRenderFns,\n  false,\n  null,\n  \"a1752eb2\",\n  null\n  \n)\n\nexport default component.exports","<template>\r\n    <div class=\"learning-list\">\r\n        <BgTop>\r\n            <Nav @change=\"subjectChange\" />\r\n        </BgTop>\r\n        <div class=\"main\">\r\n            <div class=\"auto-1440\">\r\n                <div class=\"search-wrap\">\r\n                    <Search @search=\"onSearch\" v-model=\"params\" />\r\n                    <SwitchList @change=\"switchList\" :total=\"total\" :pageSize=\"list.length\" :curSwitch=\"switchtype\" />\r\n                </div>\r\n\r\n                <div class=\"list clearfix\">\r\n                    <a-list :grid=\"grid[switchtype]\" :data-source=\"list\" :loading=\"loading\">\r\n                        <a-list-item slot=\"renderItem\" slot-scope=\"item\">\r\n                            <CubeItem :data=\"item\" v-if=\"switchtype == 0\" />\r\n                            <ListItem :data=\"item\" v-else />\r\n                        </a-list-item>\r\n                    </a-list>\r\n                </div>\r\n                <Pagination :pageSize=\"params.pageSize\" :total=\"total\" @pageChange=\"pageChange\"\r\n                    :current=\"params.pageIndex\" />\r\n            </div>\r\n        </div>\r\n    </div>\r\n</template>\r\n<script>\r\nimport BgTop from '@/components/common/BgTop'\r\nimport Pagination from '@/components/common/Pagination'\r\nimport Nav from '@/components/Learning/List/Nav'\r\nimport Search from '@/components/Learning/List/Search'\r\nimport SwitchList from '@/components/Learning/List/SwitchList'\r\nimport CubeItem from '@/components/Learning/List/CubeItem'\r\nimport ListItem from '@/components/Learning/List/ListItem'\r\nimport { mapState } from 'vuex'\r\nimport { GetList, GetListSenior } from '@/api/model'\r\nexport default {\r\n    metaInfo() {\r\n        return {\r\n            title: this.mateInfo?.Title || '文物出版社',\r\n            meta: [\r\n                {\r\n                    name: 'keyWords',\r\n                    content: this.mateInfo?.Title || '文物出版社',\r\n                },\r\n                {\r\n                    name: 'description',\r\n                    content: this.mateInfo?.Title || '文物出版社',\r\n                },\r\n            ],\r\n        }\r\n    },\r\n    components: {\r\n        BgTop,\r\n        Nav,\r\n        Search,\r\n        SwitchList,\r\n        Pagination,\r\n        CubeItem,\r\n        ListItem,\r\n    },\r\n    computed:{\r\n        ...mapState({\r\n            navList: state => state.app.navList,\r\n        }),\r\n        mateInfo(){\r\n            return this.navList.find(i => i.LinkUrl.indexOf('#/learning/list') !== -1)\r\n        }\r\n    },\r\n    data() {\r\n        return {\r\n            list: [],\r\n            params: {\r\n                pageIndex: 1,\r\n                pageSize: 12,\r\n                subject: '',\r\n            },\r\n            total: 0,\r\n            loading: false,\r\n            grid: [\r\n                { gutter: 30, column: 3 },\r\n                { gutter: 0, column: 1 },\r\n            ],\r\n            switchtype: 0,\r\n        }\r\n    },\r\n    methods: {\r\n        // 切换列表形式\r\n        switchList(val) {\r\n            this.switchtype = val\r\n            this.loading = true\r\n            setTimeout(() => {\r\n                this.loading = false\r\n            }, 200)\r\n        },\r\n        // 获取列表\r\n        async getList() {\r\n            console.log(this.params)\r\n            this.loading = true\r\n            await GetListSenior(this.params)\r\n                .then(res => {\r\n                    const { data, total } = res\r\n                    data.forEach(item => {\r\n                        item.key = item.Id\r\n                    })\r\n                    this.list = data\r\n                    this.total = total\r\n                })\r\n                .catch(e => e)\r\n            this.loading = false\r\n        },\r\n        // 翻页\r\n        pageChange(page) {\r\n            console.log(page)\r\n            this.params.pageIndex = page.page\r\n            document.documentElement.scrollTop = 0\r\n            this.getList()\r\n        },\r\n        // 翻页\r\n        onSearch(obj) {\r\n            this.params.pageIndex = 1\r\n            this.getList()\r\n        },\r\n        subjectChange(ids) {\r\n            this.params.subject = ids.join(',')\r\n            this.params.pageIndex = 1\r\n            this.getList()\r\n        },\r\n    },\r\n    created() {\r\n        // this.getList()\r\n    },\r\n}\r\n</script>\r\n<style lang=\"less\" scoped>\r\n.main {\r\n    padding: 49px 0 80px;\r\n}\r\n\r\n// .list{\r\n//     display: flex;\r\n//     flex-wrap: wrap;\r\n//     margin-bottom: 30px;\r\n//     /deep/.item{\r\n//         width: calc(33.33% - 20px);\r\n//     }\r\n//     &.line{\r\n//         /deep/.item{\r\n//             width: 100%;\r\n//             margin-right: 0;\r\n//         }\r\n//     }\r\n// }\r\n/deep/.ant-list {\r\n    min-height: 100px;\r\n}\r\n\r\n.search-wrap {\r\n    // display: flex;\r\n    // align-items: center;\r\n    // justify-content: space-between;\r\n}\r\n</style>\r\n","import mod from \"-!../../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./List.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./List.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./List.vue?vue&type=template&id=479cfa0f&scoped=true&\"\nimport script from \"./List.vue?vue&type=script&lang=js&\"\nexport * from \"./List.vue?vue&type=script&lang=js&\"\nimport style0 from \"./List.vue?vue&type=style&index=0&id=479cfa0f&prod&lang=less&scoped=true&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n  script,\n  render,\n  staticRenderFns,\n  false,\n  null,\n  \"479cfa0f\",\n  null\n  \n)\n\nexport default component.exports","var render = function render(){var _vm=this,_c=_vm._self._c;return _c('div',{staticClass:\"item\"},[_c('div',{staticClass:\"pic\",on:{\"click\":_vm.goDetail}},[_c('img',{attrs:{\"src\":_vm.data.ImageUrl,\"alt\":\"\"}})]),_c('div',{staticClass:\"txt\"},[_c('h2',[_c('pre',{staticClass:\"dot2\",on:{\"click\":_vm.goDetail}},[_vm._v(_vm._s(_vm.data.Name))]),_c('a-tooltip',{attrs:{\"placement\":\"top\"}},[_c('template',{slot:\"title\"},[(_vm.data.IsCollection)?_c('span',[_vm._v(\"取消收藏\")]):_c('span',[_vm._v(\"收藏\")])]),_c('i',{class:[_vm.data.IsCollection ? 'active' : ''],on:{\"click\":_vm.toggleCollect}},[_c('svg-icon',{staticClass:\"icon_collect\",attrs:{\"icon-class\":\"icon_collect\"}})],1)],2)],1),_c('div',{staticClass:\"des\"},[_c('pre',{staticClass:\"dot3\"},[_vm._v(_vm._s(_vm.data.Info))])])])])\n}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","<template>\r\n    <div class=\"item\">\r\n        <!-- <div class=\"tag\">精选</div> -->\r\n        <div class=\"pic\" @click=\"goDetail\">\r\n            <img :src=\"data.ImageUrl\" alt=\"\" />\r\n        </div>\r\n        <div class=\"txt\">\r\n            <h2>\r\n                <pre class=\"dot2\" @click=\"goDetail\">{{ data.Name }}</pre>\r\n                <a-tooltip placement=\"top\">\r\n                    <template slot=\"title\">\r\n                        <span v-if=\"data.IsCollection\">取消收藏</span>\r\n                        <span v-else>收藏</span>\r\n                    </template>\r\n                    <i\r\n                        :class=\"[data.IsCollection ? 'active' : '']\"\r\n                        @click=\"toggleCollect\"\r\n                    >\r\n                        <svg-icon\r\n                            icon-class=\"icon_collect\"\r\n                            class=\"icon_collect\"\r\n                        ></svg-icon>\r\n                    </i>\r\n                </a-tooltip>\r\n            </h2>\r\n            <div class=\"des\">\r\n                <pre class=\"dot3\">{{ data.Info }}</pre>\r\n            </div>\r\n            <!-- <div class=\"time\">{{ time }}</div> -->\r\n        </div>\r\n    </div>\r\n</template>\r\n<script>\r\nimport { mapState, mapActions, mapMutations } from 'vuex'\r\nimport { ToggleCollectModel } from '@/api/collection'\r\nexport default {\r\n    props: ['data'],\r\n    data() {\r\n        return {}\r\n    },\r\n    computed: {\r\n        time() {\r\n            return this.data.CreateTime.split(' ')[0].split('/').join('-')\r\n        },\r\n        ...mapState({\r\n            userInfo: state => state.user.userInfo,\r\n        }),\r\n    },\r\n    methods: {\r\n        goDetail() {\r\n            this.$router.push({\r\n                name: 'learning-info',\r\n                params: { id: this.data.Id },\r\n            })\r\n        },\r\n        toggleCollect() {\r\n            const user = this.userInfo.LoginName\r\n            if (!user) {\r\n                this.$message.info('登录之后才能收藏,请先登录!')\r\n                this.$store.commit('saveLoginDialog', true)\r\n            } else {\r\n                ToggleCollectModel(this.data.Id)\r\n                    .then(res => {\r\n                        const msg = this.data.IsCollection\r\n                            ? '取消成功'\r\n                            : '收藏成功'\r\n                        this.$message.success(msg)\r\n                        this.data.IsCollection = !this.data.IsCollection\r\n                    })\r\n                    .catch(e => e)\r\n            }\r\n        },\r\n    },\r\n}\r\n</script>\r\n<style scoped lang=\"less\">\r\n.item {\r\n    background-color: #f5f5f5;\r\n    padding: 20px;\r\n    width: 100%;\r\n    margin-bottom: 20px;\r\n    display: flex;\r\n    position: relative;\r\n    transition: 0.3s;\r\n    &:hover {\r\n        box-shadow: 0 3px 6px -4px #0000001f, 0 6px 16px #00000014,\r\n            0 9px 28px 8px #0000000d;\r\n        h2 pre {\r\n            color: #f49133;\r\n        }\r\n    }\r\n    &:not(:nth-of-type(3n)) {\r\n        margin-right: 30px;\r\n    }\r\n    .tag {\r\n        position: absolute;\r\n        left: 0;\r\n        top: 0;\r\n        line-height: 30px;\r\n        padding: 0 10px;\r\n        background-color: #f49133;\r\n        color: #fff;\r\n        border-radius: 0 0 13px 0;\r\n    }\r\n    .pic {\r\n        margin-right: 30px;\r\n        flex-shrink: 0;\r\n        cursor: pointer;\r\n        img {\r\n            width: 120px;\r\n            height: 180px;\r\n            background-color: #eee;\r\n            object-fit: cover;\r\n        }\r\n    }\r\n    .txt {\r\n        flex: 1;\r\n        display: flex;\r\n        flex-direction: column;\r\n        justify-content: space-between;\r\n    }\r\n    h2 {\r\n        display: flex;\r\n        cursor: pointer;\r\n        pre {\r\n            font-size: 17px;\r\n            // font-weight: bold;\r\n            color: #333;\r\n            line-height: 1.566;\r\n            flex: 1;\r\n        }\r\n        i {\r\n            flex-shrink: 0;\r\n            color: #999;\r\n            transition: 0.3s;\r\n            margin-left: 10px;\r\n            .icon_collect {\r\n                font-size: 20px;\r\n            }\r\n            &:hover,\r\n            &.active {\r\n                color: #f49133;\r\n            }\r\n        }\r\n    }\r\n    .des {\r\n        font-size: 16px;\r\n        color: rgb(85, 85, 85);\r\n        line-height: 1.5;\r\n        min-height: 1.5 * 3em;\r\n        padding-right: 20px;\r\n        cursor: pointer;\r\n    }\r\n    .time {\r\n        font-size: 16px;\r\n        color: rgb(136, 136, 136);\r\n    }\r\n}\r\n</style>\r\n","import mod from \"-!../../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./CubeItem.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../../../node_modules/@vue/cli-plugin-babel/node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../node_modules/@vue/cli-plugin-babel/node_modules/thread-loader/dist/cjs.js!../../../../node_modules/babel-loader/lib/index.js!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./CubeItem.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./CubeItem.vue?vue&type=template&id=18e293c2&scoped=true&\"\nimport script from \"./CubeItem.vue?vue&type=script&lang=js&\"\nexport * from \"./CubeItem.vue?vue&type=script&lang=js&\"\nimport style0 from \"./CubeItem.vue?vue&type=style&index=0&id=18e293c2&prod&scoped=true&lang=less&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n  script,\n  render,\n  staticRenderFns,\n  false,\n  null,\n  \"18e293c2\",\n  null\n  \n)\n\nexport default component.exports","export * from \"-!../../../../node_modules/@vue/cli-service/node_modules/mini-css-extract-plugin/dist/loader.js??ref--11-oneOf-1-0!../../../../node_modules/css-loader/dist/cjs.js??ref--11-oneOf-1-1!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../node_modules/postcss-loader/src/index.js??ref--11-oneOf-1-2!../../../../node_modules/less-loader/dist/cjs.js??ref--11-oneOf-1-3!../../../../node_modules/style-resources-loader/lib/index.js??ref--11-oneOf-1-4!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./CubeItem.vue?vue&type=style&index=0&id=18e293c2&prod&scoped=true&lang=less&\"","export * from \"-!../../../../node_modules/@vue/cli-service/node_modules/mini-css-extract-plugin/dist/loader.js??ref--11-oneOf-1-0!../../../../node_modules/css-loader/dist/cjs.js??ref--11-oneOf-1-1!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../../node_modules/postcss-loader/src/index.js??ref--11-oneOf-1-2!../../../../node_modules/less-loader/dist/cjs.js??ref--11-oneOf-1-3!../../../../node_modules/style-resources-loader/lib/index.js??ref--11-oneOf-1-4!../../../../node_modules/@vue/cli-service/node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../node_modules/@vue/cli-service/node_modules/vue-loader/lib/index.js??vue-loader-options!./List.vue?vue&type=style&index=0&id=479cfa0f&prod&lang=less&scoped=true&\""],"sourceRoot":""}