ywana-core8 0.0.834 → 0.0.835

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ywana-core8",
3
- "version": "0.0.834",
3
+ "version": "0.0.835",
4
4
  "description": "ywana-core8",
5
5
  "homepage": "https://ywana.github.io/workspace",
6
6
  "author": "Ernesto Roldan Garcia",
@@ -1,3 +1,4 @@
1
1
  export { CollectionContext as CollectionContext2 } from './CollectionContext'
2
2
  export { CollectionPage as CollectionPage2 } from './CollectionPage'
3
+ export { CollectionAPI as CollectionAPI2 } from './CollectionAPI'
3
4
  export { DynamicForm } from './DynamicForm'
@@ -1,7 +1,6 @@
1
1
  import React, { useEffect, useContext, useState } from 'react'
2
- import { CollectionAPI } from '../domain/CollectionAPI'
3
- import { FORMATS, TYPES } from '../domain/ContentType'
4
- import { LinearProgress, Header, DataTable, Icon, Chip } from '../html'
2
+ import { CollectionAPI, FORMATS, TYPES } from '../domain'
3
+ import { 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 = 5000, children, listeners = {} } = props
16
+ const { host, url = "/tasks", frequency = 1000, children } = props
18
17
  const API = CollectionAPI(url, host)
19
- const _listeners = Object.assign({}, listeners)
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
- _listeners[taskID] = listener
80
+ const next = { ...listeners, [taskID]: listener }
81
+ setListeners(next)
69
82
  }
70
83
 
71
84
  function removeListener(taskID) {
72
- delete _listeners[taskID]
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: _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
- { context.listeners ? <Chip label={Object.keys(context.listeners).length} /> : null }
214
+
216
215
  </Header>
217
216
  <main>
218
217
  <DataTable {...table} />