derive class iTask MTaskShareType, MTaskShare
manageShares :: [MTaskShare] -> Task ()
-manageShares shares = forever $
- /*viewSharesGrid shares -|| */viewShares shares @! ()
+manageShares shares = withShared Nothing $ \cs->forever $
+ viewSharesGrid cs shares /*||- (viewSharedInformation "" [] cs*/ @! ()//)//||- editCurrentShare cs
// >&^ \st->whileUnchanged st $ \msh->case msh of
// Nothing = viewShares shares
// ) @! ()
-viewShares :: [MTaskShare] -> Task BCValue
-viewShares shares = anyTask (map viewShare shares)
-
-viewAndDelete :: [MTaskShare] -> Task ()
-viewAndDelete shares
- = enterChoice "Choose share to update" [ChooseFromGrid id] shares @! ()
+//viewShares :: [MTaskShare] -> Task BCValue
+//viewShares shares = anyTask (map viewShare shares)
+//
+//viewAndDelete :: [MTaskShare] -> Task ()
+//viewAndDelete shares
+// = enterChoice "Choose share to update" [ChooseFromGrid id] shares @! ()
//updateShare :: MTaskShare a -> Task MTaskShare | toByteCode, iTask a
//updateShare sh=:{withTask,identifier} a = getDeviceByName withTask
// >>= sendMessages [MTUpd identifier $ toString $ toByteCode a]
// >>| treturn sh
+//
+from StdFunc import flip
-//viewSharesGrid :: [MTaskShare] -> Task [MTaskShare]
-//viewSharesGrid sh = allTasks [whileUnchanged (get $ getSDSShare m) (\s->treturn (m, s))\\m<-sh]
-// @ map (\(s,v)->{MTaskShare|s&value=v})
-// >>= enterChoice "Choose share" [ChooseFromGrid id]
-// >>= \s->treturn [s]
-//{anyTask (map viewShare sh) <<@ ArrangeHorizontal
-// >>| return (hd sh)
+viewSharesGrid :: (Shared (Maybe MTaskShare)) [MTaskShare] -> Task [BCValue]
+viewSharesGrid _ [] = viewInformation "No shares yet" [] []
+viewSharesGrid cs sh = (allTasks [watch (getSDSShare m)\\m<-sh] <<@ NoUserInterface)
+ >&^ \st->flip (<<@) NoUserInterface $ whileUnchanged st $ \mshs->enterChoice "" [ChooseFromGrid id]
+ [{MTaskShare|ss&value=s}\\s<-fromJust mshs & ss<-sh]
+// >>* [OnValue (withValue $ \s->Just (set (Just s) cs))]
+ @! fromJust mshs
viewShare :: MTaskShare -> Task BCValue
viewShare m = viewSharedInformation "" [] (getSDSShare m)
makeShare :: String Int BCValue -> Task MTaskShare
makeShare withTask identifier value = treturn
{MTaskShare
- |withTask=withTask
+ |withTask=[withTask]
,identifier=identifier
,value=value
,realShare=MTaskWithShare $ "mTaskSDS-" +++ toString identifier
} >>= \sh->set value (getSDSShare sh) >>| treturn sh
-updateShare :: Int String -> Task ()
+updateShare :: Int BCValue -> Task ()
updateShare ident val = get sdsStore
>>= \sh->(case find (\s->s.identifier==ident) sh of
Nothing = abort "Help, no share found with this ident"
- Just mts = set (fromByteCode val) (getSDSShare mts))
+ Just mts = set val (getSDSShare mts))
>>| traceValue "Updated" @! ()