mirror of
https://github.com/kuaifan/dootask.git
synced 2026-03-17 19:23:26 +00:00
优化全局加载器
This commit is contained in:
parent
db28811027
commit
8365f69de6
@ -7,8 +7,8 @@
|
|||||||
<!--任务操作-->
|
<!--任务操作-->
|
||||||
<TaskOperation/>
|
<TaskOperation/>
|
||||||
|
|
||||||
<!--右下角加载提示-->
|
<!--全局浮窗加载器-->
|
||||||
<Spinner/>
|
<FloatSpinner/>
|
||||||
|
|
||||||
<!--右下角客户端-->
|
<!--右下角客户端-->
|
||||||
<RightBottom/>
|
<RightBottom/>
|
||||||
@ -37,7 +37,7 @@
|
|||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
<script>
|
<script>
|
||||||
import Spinner from "./components/Spinner";
|
import FloatSpinner from "./components/FloatSpinner";
|
||||||
import RightBottom from "./components/RightBottom";
|
import RightBottom from "./components/RightBottom";
|
||||||
import PreviewImageState from "./components/PreviewImage/state";
|
import PreviewImageState from "./components/PreviewImage/state";
|
||||||
import NetworkException from "./components/NetworkException";
|
import NetworkException from "./components/NetworkException";
|
||||||
@ -46,7 +46,7 @@ import TaskOperation from "./pages/manage/components/TaskOperation";
|
|||||||
import {mapState} from "vuex";
|
import {mapState} from "vuex";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
components: {TaskOperation, AudioManager, NetworkException, PreviewImageState, RightBottom, Spinner},
|
components: {TaskOperation, AudioManager, NetworkException, PreviewImageState, RightBottom, FloatSpinner},
|
||||||
|
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
|||||||
18
resources/assets/js/components/FloatSpinner.vue
Normal file
18
resources/assets/js/components/FloatSpinner.vue
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<template>
|
||||||
|
<transition name="fade">
|
||||||
|
<div v-if="floatSpinnerLoad > 0" class="common-float-spinner">
|
||||||
|
<Loading class="common-float-circular"></Loading>
|
||||||
|
</div>
|
||||||
|
</transition>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import {mapState} from "vuex";
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: 'FloatSpinner',
|
||||||
|
computed: {
|
||||||
|
...mapState(['floatSpinnerLoad'])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@ -1,11 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div id="common-spinner" class="common-spinner">
|
|
||||||
<Loading class="common-circular"></Loading>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
export default {
|
|
||||||
name: 'Spinner',
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
22
resources/assets/js/functions/web.js
vendored
22
resources/assets/js/functions/web.js
vendored
@ -412,28 +412,6 @@
|
|||||||
* =============================================================================
|
* =============================================================================
|
||||||
*/
|
*/
|
||||||
$.extend({
|
$.extend({
|
||||||
// 加载器
|
|
||||||
spinnerShow() {
|
|
||||||
$A.spinnerLoadNum++
|
|
||||||
if ($A.spinnerLoadNum > 0) {
|
|
||||||
const spinner = document.getElementById("common-spinner");
|
|
||||||
if (spinner) {
|
|
||||||
spinner.style.display = "block"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
spinnerHide() {
|
|
||||||
$A.spinnerLoadNum--
|
|
||||||
if ($A.spinnerLoadNum <= 0) {
|
|
||||||
const spinner = document.getElementById("common-spinner");
|
|
||||||
if (spinner) {
|
|
||||||
spinner.style.display = "none"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
spinnerLoadNum: 0,
|
|
||||||
|
|
||||||
// 弹窗
|
// 弹窗
|
||||||
modalConfig(config) {
|
modalConfig(config) {
|
||||||
if (typeof config === "undefined") {
|
if (typeof config === "undefined") {
|
||||||
|
|||||||
24
resources/assets/js/store/actions.js
vendored
24
resources/assets/js/store/actions.js
vendored
@ -29,12 +29,15 @@ export default {
|
|||||||
const cloneParams = $A.cloneJSON(params);
|
const cloneParams = $A.cloneJSON(params);
|
||||||
return new Promise(function (resolve, reject) {
|
return new Promise(function (resolve, reject) {
|
||||||
if (params.spinner === true) {
|
if (params.spinner === true) {
|
||||||
|
const {before, complete, spinnerDelay} = params;
|
||||||
params.before = () => {
|
params.before = () => {
|
||||||
$A.spinnerShow();
|
dispatch("showSpinner", spinnerDelay)
|
||||||
|
typeof before === "function" && before()
|
||||||
};
|
};
|
||||||
//
|
//
|
||||||
params.complete = () => {
|
params.complete = () => {
|
||||||
$A.spinnerHide();
|
dispatch("hiddenSpinner")
|
||||||
|
typeof complete === "function" && complete()
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
@ -2317,6 +2320,23 @@ export default {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 显示全局浮窗加载器
|
||||||
|
* @param state
|
||||||
|
* @param delay
|
||||||
|
*/
|
||||||
|
showSpinner({state}, delay) {
|
||||||
|
setTimeout(_ => state.floatSpinnerLoad++, typeof delay === "number" ? delay : 0)
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 隐藏全局浮窗加载器
|
||||||
|
* @param state
|
||||||
|
*/
|
||||||
|
hiddenSpinner({state}) {
|
||||||
|
state.floatSpinnerLoad--
|
||||||
|
},
|
||||||
|
|
||||||
/** *****************************************************************************************/
|
/** *****************************************************************************************/
|
||||||
/** *********************************** websocket *******************************************/
|
/** *********************************** websocket *******************************************/
|
||||||
/** *****************************************************************************************/
|
/** *****************************************************************************************/
|
||||||
|
|||||||
1
resources/assets/js/store/state.js
vendored
1
resources/assets/js/store/state.js
vendored
@ -24,6 +24,7 @@ const stateData = {
|
|||||||
loadUserBasic: false,
|
loadUserBasic: false,
|
||||||
loadProjects: 0,
|
loadProjects: 0,
|
||||||
loadDialogs: 0,
|
loadDialogs: 0,
|
||||||
|
floatSpinnerLoad: 0,
|
||||||
touchBackInProgress: false,
|
touchBackInProgress: false,
|
||||||
|
|
||||||
// User
|
// User
|
||||||
|
|||||||
2
resources/assets/sass/components/_.scss
vendored
2
resources/assets/sass/components/_.scss
vendored
@ -1,12 +1,12 @@
|
|||||||
@import "auto-tip";
|
@import "auto-tip";
|
||||||
@import "circle";
|
@import "circle";
|
||||||
@import "drawer-overlay";
|
@import "drawer-overlay";
|
||||||
|
@import "float-spinner";
|
||||||
@import "gantt-view";
|
@import "gantt-view";
|
||||||
@import "img-update";
|
@import "img-update";
|
||||||
@import "loading";
|
@import "loading";
|
||||||
@import "mobile";
|
@import "mobile";
|
||||||
@import "scroller-y";
|
@import "scroller-y";
|
||||||
@import "spinner";
|
|
||||||
@import "t-editor";
|
@import "t-editor";
|
||||||
@import "quick-edit";
|
@import "quick-edit";
|
||||||
@import "tag-input";
|
@import "tag-input";
|
||||||
|
|||||||
17
resources/assets/sass/components/float-spinner.scss
vendored
Normal file
17
resources/assets/sass/components/float-spinner.scss
vendored
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
.common-float-spinner {
|
||||||
|
position: fixed;
|
||||||
|
z-index: 9999;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
bottom: 0;
|
||||||
|
right: 0;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
background-color: rgba(255, 255, 255, 0.6);
|
||||||
|
|
||||||
|
.common-float-circular {
|
||||||
|
width: 30px;
|
||||||
|
height: 30px;
|
||||||
|
}
|
||||||
|
}
|
||||||
20
resources/assets/sass/components/spinner.scss
vendored
20
resources/assets/sass/components/spinner.scss
vendored
@ -1,20 +0,0 @@
|
|||||||
.common-spinner {
|
|
||||||
display: none;
|
|
||||||
position: fixed;
|
|
||||||
z-index: 9999;
|
|
||||||
bottom: 20px;
|
|
||||||
right: 20px;
|
|
||||||
margin: 0 auto;
|
|
||||||
width: 30px;
|
|
||||||
height: 30px;
|
|
||||||
|
|
||||||
.common-circular {
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
bottom: 0;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Loading…
x
Reference in New Issue
Block a user