= withDevices device (\d->{d & deviceTask=Nothing, deviceError=Just e}) @! ()
manageDevices :: (MTaskDevice (Shared Channels) -> Task ()) -> Task ()
-manageDevices processFun = get deviceStoreNP >>= \ds->anyTask [
- addDevice processFun <<@ Title "Add new device" @! ()]//:
-// [viewDevice processFun d <<@ Title d.deviceName\\d<-ds]]
+manageDevices processFun = whileUnchanged deviceStoreNP $ \ds->anyTask [
+ addDevice processFun <<@ Title "Add new device" @! ():
+ [viewDevice processFun d <<@ Title d.deviceName\\d<-ds]]
<<@ ArrangeWithTabs
@! ()
viewDevice :: (MTaskDevice (Shared Channels) -> Task ()) MTaskDevice -> Task ()
viewDevice pf d = forever $ traceValue "viewDevice" >>| anyTask
[viewInformation "Device settings" [] d @! ()
- /*,viewSharedInformation "Channels" [ViewAs dropEmpty] (channels d) @! ()*/
+ ,viewSharedInformation "Channels" [ViewAs dropEmpty] (channels d) @! ()
,forever $
enterChoice "Delete task on device" [ChooseFromGrid id] d.deviceTasks
>>* [OnAction (Action "Delete") $ ifValue (\t->t.ident <> -1) (deviceTaskDelete d)]