]> gerrit.simantics Code Review - simantics/platform.git/blob - bundles/org.simantics.spreadsheet.graph/scl/Spreadsheet/All.scl
Merge branch 'feature/funcwrite'
[simantics/platform.git] / bundles / org.simantics.spreadsheet.graph / scl / Spreadsheet / All.scl
1 include "Simantics/DB"
2 include "Simantics/Ontologies"
3 include "Simantics/SCL"
4 include "Document/All"
5 include "File"
6
7 importJava "org.simantics.spreadsheet.common.TableCell" where
8     data TableCell
9
10 importJava "org.simantics.spreadsheet.common.TreeTableCell" where
11     data TreeTableCell
12
13     @JavaName getData
14     getTreeTableCellData :: TreeTableCell -> <Proc> a
15     
16     createTreeTableCell :: String -> a -> Maybe b -> Integer -> Integer -> Integer -> Boolean -> <Proc> TreeTableCell
17     
18     @JavaName getText
19     treeTableCellText :: TreeTableCell -> <Proc> String
20     @JavaName getFont
21     treeTableCellFont :: TreeTableCell -> <Proc> Maybe IFont
22     @JavaName getRow
23     treeTableCellRow :: TreeTableCell -> <Proc> Integer
24     @JavaName getColumn
25     treeTableCellColumn :: TreeTableCell -> <Proc> Integer
26     
27 importJava "org.simantics.spreadsheet.common.SpreadsheetCell" where
28     data SpreadsheetCell
29
30 importJava "org.simantics.spreadsheet.graph.SCL" where
31     toVariant :: a -> Variant
32     modelsSourceContribution :: Resource -> <ReadGraph> [Variable]
33     modelsSourceContributionLabeler :: Variable -> <ReadGraph> String
34
35 importJava "org.simantics.spreadsheet.graph.SpreadsheetGraphUtils" where
36     @JavaName "fullSynchronization"
37     fullSynchronizeSheet :: Variable -> <ReadGraph> Boolean
38     evaluateAll :: Variable -> <ReadGraph> ()
39     saveInitialCondition :: Variable -> Resource -> String -> <WriteGraph> Resource
40     findCell :: Variable -> String -> <ReadGraph> Maybe Variable
41     invalidateAll :: Variable -> <ReadGraph> ()
42
43 importJava "org.simantics.spreadsheet.util.SpreadsheetUtils" where
44     createSheet :: Resource -> String -> <WriteGraph> Resource
45     queryCells :: a -> [TableCell]
46     modifyCells1 :: [TableCell] -> (TableCell -> TableCell) -> [TableCell]
47     modifyCells :: [TableCell] -> [(TableCell -> TableCell)] -> [TableCell]
48     organizeCells :: Integer -> [String] -> [TableCell] -> [TableCell]
49     applyFont :: IFont -> (TableCell -> Boolean) -> TableCell -> TableCell
50     applyAlign :: Integer -> (TableCell -> Boolean) -> TableCell -> TableCell
51     applyForeground :: IColor -> (TableCell -> Boolean) -> TableCell -> TableCell
52     applyBackground :: IColor -> (TableCell -> Boolean) -> TableCell -> TableCell
53     simpleFont :: String -> String -> Integer -> IFont
54     rgbColor :: Integer -> Integer -> Integer -> IColor
55     selectRow :: Integer -> TableCell -> Boolean
56     selectColumn :: Integer -> TableCell -> Boolean
57     setSCLLine :: Resource -> Integer -> String -> <WriteGraph> ()
58     sheetRun :: Resource -> Variable -> <ReadGraph> Variable
59     
60 importJava "org.simantics.spreadsheet.graph.ExcelImport" where
61     importBook :: Resource -> File -> <Proc> ()
62
63 createSpreadsheetBookAction :: Resource -> <Proc> ()
64 createSpreadsheetBookAction res = do
65   syncWrite (\() -> createSpreadsheetBookDefault res)
66   ()
67   
68 createSpreadsheetSheetAction :: Resource -> <Proc> ()
69 createSpreadsheetSheetAction res = do
70   syncWrite (\() -> createSpreadsheetDefault res)
71   ()
72
73 createSpreadsheetDefault :: Resource -> <WriteGraph> Resource
74 createSpreadsheetDefault library = createSheet library $ findFreshEscapedName "Sheet" library 
75
76 createSpreadsheetBookDefault :: Resource -> <WriteGraph> Resource
77 createSpreadsheetBookDefault library = createSpreadsheetBook library $ findFreshEscapedName "Book" library 
78
79 createRange :: Resource -> Resource -> String -> String -> <WriteGraph> Resource
80 createRange library type_ name expression = do
81     range = newResource ()
82     claim range L0.InstanceOf type_
83     claimRelatedValue range L0.HasName name
84     createSCLValue range SHEET.ExpressionRange.cells SHEET.SCLValue expression
85     claim range L0.PartOf library
86     range
87
88 createSpreadsheetBook :: Resource -> String -> <WriteGraph> Resource
89 createSpreadsheetBook library name = do
90     markUndoPoint ()
91     book = newResource ()
92     claim book L0.InstanceOf SHEET.Book
93     claimRelatedValue book L0.HasName name
94     claim book L0.PartOf library
95     createSheet book "Sheet"
96     addCommentMetadata ("Created Spreadsheet Book " + name)
97     book
98