ywana-core8 0.0.834 → 0.0.836
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +118 -113
- package/dist/index.cjs.map +1 -1
- package/dist/index.modern.js +118 -114
- package/dist/index.modern.js.map +1 -1
- package/dist/index.umd.js +118 -113
- package/dist/index.umd.js.map +1 -1
- package/package.json +1 -1
- package/src/domain2/index.js +1 -0
- package/src/incubator/task.js +24 -25
package/package.json
CHANGED
package/src/domain2/index.js
CHANGED
package/src/incubator/task.js
CHANGED
@@ -1,7 +1,6 @@
|
|
1
1
|
import React, { useEffect, useContext, useState } from 'react'
|
2
|
-
import { CollectionAPI } from '../domain
|
3
|
-
import {
|
4
|
-
import { LinearProgress, Header, DataTable, Icon, Chip } from '../html'
|
2
|
+
import { CollectionAPI, FORMATS, TYPES } from '../domain'
|
3
|
+
import { Icon, DataTable, Header, LinearProgress } from '../html'
|
5
4
|
import "./task.css"
|
6
5
|
|
7
6
|
/**
|
@@ -14,9 +13,22 @@ export const TaskContext = React.createContext({})
|
|
14
13
|
*/
|
15
14
|
export const TaskContextProvider = (props) => {
|
16
15
|
|
17
|
-
const { host, url = "/tasks", frequency =
|
16
|
+
const { host, url = "/tasks", frequency = 1000, children } = props
|
18
17
|
const API = CollectionAPI(url, host)
|
19
|
-
const
|
18
|
+
const [ listeners, setListeners ] = useState({})
|
19
|
+
|
20
|
+
useEffect(() => {
|
21
|
+
const _interval = setInterval(async () => {
|
22
|
+
const taskIDs = Object.keys(listeners)
|
23
|
+
for (let i = 0; i < taskIDs.length; i++) {
|
24
|
+
const taskID = taskIDs[i]
|
25
|
+
const listener = listeners[taskID]
|
26
|
+
const tsk = await task(taskID)
|
27
|
+
if (listener) listener(tsk)
|
28
|
+
}
|
29
|
+
}, frequency)
|
30
|
+
return () => clearInterval(_interval)
|
31
|
+
}, [listeners])
|
20
32
|
|
21
33
|
async function tasks(filters, likes) {
|
22
34
|
try {
|
@@ -65,36 +77,23 @@ export const TaskContextProvider = (props) => {
|
|
65
77
|
}
|
66
78
|
|
67
79
|
function addListener(taskID, listener) {
|
68
|
-
|
80
|
+
const next = { ...listeners, [taskID]: listener }
|
81
|
+
setListeners(next)
|
69
82
|
}
|
70
83
|
|
71
84
|
function removeListener(taskID) {
|
72
|
-
|
85
|
+
const next = { ...listeners }
|
86
|
+
delete next[taskID]
|
87
|
+
setListeners(next)
|
73
88
|
}
|
74
89
|
|
75
|
-
useEffect(() => {
|
76
|
-
const interval = setInterval(async () => {
|
77
|
-
const taskIDs = Object.keys(_listeners)
|
78
|
-
if (taskIDs.length === 0) return
|
79
|
-
for (let i = 0; i < taskIDs.length; i++) {
|
80
|
-
const taskID = taskIDs[i]
|
81
|
-
const tsk = await task(taskID)
|
82
|
-
if (tsk) {
|
83
|
-
const listener = _listeners[taskID]
|
84
|
-
if (listener) listener(tsk, value)
|
85
|
-
}
|
86
|
-
}
|
87
|
-
}, frequency)
|
88
|
-
return () => clearInterval(interval)
|
89
|
-
}, [])
|
90
|
-
|
91
90
|
const value = {
|
92
91
|
tasks,
|
93
92
|
task,
|
94
93
|
createTask,
|
95
94
|
updateTask,
|
96
95
|
removeTask,
|
97
|
-
listeners
|
96
|
+
listeners,
|
98
97
|
addListener,
|
99
98
|
removeListener
|
100
99
|
};
|
@@ -212,7 +211,7 @@ export const TaskMonitor = (props) => {
|
|
212
211
|
return (
|
213
212
|
<div className="task-manager">
|
214
213
|
<Header icon="list" title={title} >
|
215
|
-
|
214
|
+
|
216
215
|
</Header>
|
217
216
|
<main>
|
218
217
|
<DataTable {...table} />
|