dao-treasury 0.0.32__tar.gz → 0.0.34__tar.gz

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.
Files changed (47) hide show
  1. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/PKG-INFO +1 -1
  2. dao_treasury-0.0.34/dao_treasury/.grafana/provisioning/dashboards/dashboards.yaml +60 -0
  3. dao_treasury-0.0.34/dao_treasury/.grafana/provisioning/dashboards/summary/Monthly.json +107 -0
  4. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/.grafana/provisioning/dashboards/transactions/Treasury Transactions.json +20 -20
  5. dao_treasury-0.0.34/dao_treasury/.grafana/provisioning/dashboards/treasury/Cashflow (Including Unsorted).json +835 -0
  6. dao_treasury-0.0.34/dao_treasury/.grafana/provisioning/dashboards/treasury/Cashflow.json +615 -0
  7. dao_treasury-0.0.34/dao_treasury/.grafana/provisioning/dashboards/treasury/Operating Cashflow.json +492 -0
  8. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/db.py +58 -31
  9. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/sorting/__init__.py +109 -6
  10. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury.egg-info/PKG-INFO +1 -1
  11. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury.egg-info/SOURCES.txt +2 -0
  12. dao_treasury-0.0.34/dao_treasury.egg-info/requires.txt +1 -0
  13. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/pyproject.toml +2 -2
  14. dao_treasury-0.0.32/dao_treasury/.grafana/provisioning/dashboards/dashboards.yaml +0 -34
  15. dao_treasury-0.0.32/dao_treasury/.grafana/provisioning/dashboards/summary/Monthly.json +0 -112
  16. dao_treasury-0.0.32/dao_treasury/.grafana/provisioning/dashboards/treasury/Cashflow.json +0 -1018
  17. dao_treasury-0.0.32/dao_treasury.egg-info/requires.txt +0 -1
  18. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/MANIFEST.in +0 -0
  19. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/README.md +0 -0
  20. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/.grafana/provisioning/dashboards/streams/LlamaPay.json +0 -0
  21. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/.grafana/provisioning/dashboards/treasury/Treasury.json +0 -0
  22. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/.grafana/provisioning/datasources/datasources.yaml +0 -0
  23. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/ENVIRONMENT_VARIABLES.py +0 -0
  24. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/__init__.py +0 -0
  25. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/_docker.py +0 -0
  26. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/_nicknames.py +0 -0
  27. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/_wallet.py +0 -0
  28. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/constants.py +0 -0
  29. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/docker-compose.yaml +0 -0
  30. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/main.py +0 -0
  31. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/py.typed +0 -0
  32. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/sorting/_matchers.py +0 -0
  33. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/sorting/_rules.py +0 -0
  34. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/sorting/factory.py +0 -0
  35. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/sorting/rule.py +0 -0
  36. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/sorting/rules/__init__.py +0 -0
  37. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/sorting/rules/ignore/__init__.py +0 -0
  38. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/sorting/rules/ignore/llamapay.py +0 -0
  39. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/streams/__init__.py +0 -0
  40. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/streams/llamapay.py +0 -0
  41. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/treasury.py +0 -0
  42. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury/types.py +0 -0
  43. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury.egg-info/dependency_links.txt +0 -0
  44. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury.egg-info/not-zip-safe +0 -0
  45. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/dao_treasury.egg-info/top_level.txt +0 -0
  46. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/setup.cfg +0 -0
  47. {dao_treasury-0.0.32 → dao_treasury-0.0.34}/setup.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: dao_treasury
3
- Version: 0.0.32
3
+ Version: 0.0.34
4
4
  Summary: Produce comprehensive financial reports for your on-chain org
5
5
  Classifier: Development Status :: 3 - Alpha
6
6
  Classifier: Intended Audience :: Developers
@@ -0,0 +1,60 @@
1
+ apiVersion: 1
2
+
3
+ providers:
4
+ # Home
5
+ - name: 'Summary'
6
+ folder: 'Summary'
7
+ type: file
8
+ disableDeletion: true
9
+ editable: false
10
+ options:
11
+ path: /etc/grafana/provisioning/dashboards/summary
12
+
13
+ # Dashboards
14
+ - name: 'Treasury'
15
+ folder: 'Treasury'
16
+ type: file
17
+ disableDeletion: true
18
+ editable: false
19
+ options:
20
+ path: /etc/grafana/provisioning/dashboards/treasury
21
+
22
+ - name: 'Operating Cashflow Summary'
23
+ folder: 'Treasury'
24
+ type: file
25
+ disableDeletion: true
26
+ editable: false
27
+ options:
28
+ path: /etc/grafana/provisioning/dashboards/treasury
29
+
30
+ - name: 'Total Cashflow Summary'
31
+ folder: 'Treasury'
32
+ type: file
33
+ disableDeletion: true
34
+ editable: false
35
+ options:
36
+ path: /etc/grafana/provisioning/dashboards/treasury
37
+
38
+ - name: 'Total Cashflow Summary (Including Unsorted)'
39
+ folder: 'Treasury'
40
+ type: file
41
+ disableDeletion: true
42
+ editable: false
43
+ options:
44
+ path: /etc/grafana/provisioning/dashboards/treasury
45
+
46
+ - name: 'Treasury Transactions'
47
+ folder: 'Transactions'
48
+ type: file
49
+ disableDeletion: true
50
+ editable: false
51
+ options:
52
+ path: /etc/grafana/provisioning/dashboards/transactions
53
+
54
+ - name: 'LlamaPay Streams'
55
+ folder: 'Streams'
56
+ type: file
57
+ disableDeletion: true
58
+ editable: false
59
+ options:
60
+ path: /etc/grafana/provisioning/dashboards/streams
@@ -0,0 +1,107 @@
1
+ {
2
+ "annotations": {
3
+ "list": [
4
+ {
5
+ "builtIn": 1,
6
+ "datasource": "-- Grafana --",
7
+ "enable": true,
8
+ "hide": true,
9
+ "iconColor": "rgba(0, 211, 255, 1)",
10
+ "name": "Annotations & Alerts",
11
+ "type": "dashboard"
12
+ }
13
+ ]
14
+ },
15
+ "editable": true,
16
+ "fiscalYearStartMonth": 0,
17
+ "graphTooltip": 0,
18
+ "id": 2,
19
+ "links": [],
20
+ "liveNow": false,
21
+ "panels": [
22
+ {
23
+ "datasource": "SQLite",
24
+ "fieldConfig": {
25
+ "defaults": {
26
+ "color": {
27
+ "mode": "thresholds"
28
+ },
29
+ "custom": {
30
+ "align": "auto",
31
+ "cellOptions": {
32
+ "type": "auto"
33
+ },
34
+ "inspect": false
35
+ },
36
+ "mappings": [],
37
+ "thresholds": {
38
+ "mode": "absolute",
39
+ "steps": [
40
+ {
41
+ "color": "green",
42
+ "value": null
43
+ },
44
+ {
45
+ "color": "red",
46
+ "value": 80
47
+ }
48
+ ]
49
+ }
50
+ },
51
+ "overrides": []
52
+ },
53
+ "gridPos": {
54
+ "h": 9,
55
+ "w": 24,
56
+ "x": 0,
57
+ "y": 0
58
+ },
59
+ "id": 1,
60
+ "options": {
61
+ "cellHeight": "sm",
62
+ "footer": {
63
+ "countRows": false,
64
+ "fields": "",
65
+ "reducer": [
66
+ "sum"
67
+ ],
68
+ "show": false
69
+ },
70
+ "showHeader": true,
71
+ "sortBy": [
72
+ {
73
+ "desc": true,
74
+ "displayName": "Month"
75
+ }
76
+ ]
77
+ },
78
+ "pluginVersion": "10.2.0",
79
+ "targets": [
80
+ {
81
+ "datasource": "SQLite",
82
+ "queryText": "SELECT\n month AS \"Month\",\n SUM(CASE WHEN s.top_category = 'Revenue' THEN value_usd ELSE 0 END) AS \"Revenue\",\n SUM(CASE WHEN s.top_category = 'Cost of Revenue' THEN value_usd ELSE 0 END) AS \"Cost of Revenue\",\n SUM(CASE WHEN s.top_category = 'Expenses' THEN value_usd ELSE 0 END) AS \"Expenses\",\n SUM(CASE WHEN s.top_category = 'Other Income' THEN value_usd ELSE 0 END) AS \"Other Income\",\n SUM(CASE WHEN s.top_category = 'Other Expenses' THEN value_usd ELSE 0 END) AS \"Other Expense\",\n (\n SUM(CASE WHEN s.top_category = 'Revenue' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Cost of Revenue' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Expenses' THEN value_usd ELSE 0 END)\n + SUM(CASE WHEN s.top_category = 'Other Income' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Other Expenses' THEN value_usd ELSE 0 END)\n ) AS \"Sorted Net\",\n SUM(CASE WHEN s.top_category = 'Sort Me (Inbound)' THEN value_usd ELSE 0 END) AS \"Unsorted Income\",\n SUM(CASE WHEN s.top_category = 'Sort Me (Outbound)' THEN value_usd ELSE 0 END) AS \"Unsorted Expense\",\n (\n SUM(CASE WHEN s.top_category = 'Revenue' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Cost of Revenue' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Expenses' THEN value_usd ELSE 0 END)\n + SUM(CASE WHEN s.top_category = 'Other Income' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Other Expenses' THEN value_usd ELSE 0 END)\n + SUM(CASE WHEN s.top_category = 'Sort Me (Inbound)' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Sort Me (Outbound)' THEN value_usd ELSE 0 END)\n ) AS \"Net\"\nFROM (\n SELECT\n strftime('%Y-%m', datetime(t.timestamp, 'unixepoch')) AS month,\n gh.top_category,\n COALESCE(t.value_usd, 0) AS value_usd\n FROM treasury_txs AS t\n JOIN txgroups AS tg ON t.txgroup_id = tg.txgroup_id\n JOIN txgroup_hierarchy AS gh ON tg.txgroup_id = gh.txgroup_id\n WHERE t.timestamp >= strftime('%s', '2025-01-01') AND tg.name <> 'Ignore'\n) AS s\nGROUP BY month;",
83
+ "queryType": "table",
84
+ "rawQueryText": "SELECT\n month AS \"Month\",\n SUM(CASE WHEN s.top_category = 'Revenue' THEN value_usd ELSE 0 END) AS \"Revenue\",\n SUM(CASE WHEN s.top_category = 'Cost of Revenue' THEN value_usd ELSE 0 END) AS \"Cost of Revenue\",\n SUM(CASE WHEN s.top_category = 'Expenses' THEN value_usd ELSE 0 END) AS \"Expenses\",\n SUM(CASE WHEN s.top_category = 'Other Income' THEN value_usd ELSE 0 END) AS \"Other Income\",\n SUM(CASE WHEN s.top_category = 'Other Expenses' THEN value_usd ELSE 0 END) AS \"Other Expense\",\n (\n SUM(CASE WHEN s.top_category = 'Revenue' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Cost of Revenue' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Expenses' THEN value_usd ELSE 0 END)\n + SUM(CASE WHEN s.top_category = 'Other Income' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Other Expenses' THEN value_usd ELSE 0 END)\n ) AS \"Sorted Net\",\n SUM(CASE WHEN s.top_category = 'Sort Me (Inbound)' THEN value_usd ELSE 0 END) AS \"Unsorted Income\",\n SUM(CASE WHEN s.top_category = 'Sort Me (Outbound)' THEN value_usd ELSE 0 END) AS \"Unsorted Expense\",\n (\n SUM(CASE WHEN s.top_category = 'Revenue' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Cost of Revenue' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Expenses' THEN value_usd ELSE 0 END)\n + SUM(CASE WHEN s.top_category = 'Other Income' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Other Expenses' THEN value_usd ELSE 0 END)\n + SUM(CASE WHEN s.top_category = 'Sort Me (Inbound)' THEN value_usd ELSE 0 END)\n - SUM(CASE WHEN s.top_category = 'Sort Me (Outbound)' THEN value_usd ELSE 0 END)\n ) AS \"Net\"\nFROM (\n SELECT\n strftime('%Y-%m', datetime(t.timestamp, 'unixepoch')) AS month,\n gh.top_category,\n COALESCE(t.value_usd, 0) AS value_usd\n FROM treasury_txs AS t\n JOIN txgroups AS tg ON t.txgroup_id = tg.txgroup_id\n JOIN txgroup_hierarchy AS gh ON tg.txgroup_id = gh.txgroup_id\n WHERE t.timestamp >= strftime('%s', '2025-01-01') AND tg.name <> 'Ignore'\n) AS s\nGROUP BY month;"
85
+ }
86
+ ],
87
+ "title": "Monthly Profit & Loss",
88
+ "type": "table"
89
+ }
90
+ ],
91
+ "refresh": "",
92
+ "schemaVersion": 38,
93
+ "tags": [],
94
+ "templating": {
95
+ "list": []
96
+ },
97
+ "time": {
98
+ "from": "now-6h",
99
+ "to": "now"
100
+ },
101
+ "timepicker": {},
102
+ "timezone": "",
103
+ "title": "Monthly P&L",
104
+ "uid": "a63fa9a7-d4f3-4092-9bde-194add8bcbeb",
105
+ "version": 1,
106
+ "weekStart": ""
107
+ }
@@ -49,7 +49,7 @@
49
49
  {
50
50
  "matcher": {
51
51
  "id": "byName",
52
- "options": "hash"
52
+ "options": "Hash"
53
53
  },
54
54
  "properties": [
55
55
  {
@@ -67,7 +67,7 @@
67
67
  {
68
68
  "matcher": {
69
69
  "id": "byName",
70
- "options": "block"
70
+ "options": "Block"
71
71
  },
72
72
  "properties": [
73
73
  {
@@ -85,7 +85,7 @@
85
85
  {
86
86
  "matcher": {
87
87
  "id": "byName",
88
- "options": "to"
88
+ "options": "To"
89
89
  },
90
90
  "properties": [
91
91
  {
@@ -103,7 +103,7 @@
103
103
  {
104
104
  "matcher": {
105
105
  "id": "byName",
106
- "options": "from"
106
+ "options": "From"
107
107
  },
108
108
  "properties": [
109
109
  {
@@ -121,7 +121,7 @@
121
121
  {
122
122
  "matcher": {
123
123
  "id": "byName",
124
- "options": "from nickname"
124
+ "options": "From Nickname"
125
125
  },
126
126
  "properties": [
127
127
  {
@@ -139,7 +139,7 @@
139
139
  {
140
140
  "matcher": {
141
141
  "id": "byName",
142
- "options": "to nickname"
142
+ "options": "To Nickname"
143
143
  },
144
144
  "properties": [
145
145
  {
@@ -157,7 +157,7 @@
157
157
  {
158
158
  "matcher": {
159
159
  "id": "byName",
160
- "options": "block"
160
+ "options": "Block"
161
161
  },
162
162
  "properties": [
163
163
  {
@@ -168,7 +168,7 @@
168
168
  {
169
169
  "matcher": {
170
170
  "id": "byName",
171
- "options": "log_index"
171
+ "options": "Log Index"
172
172
  },
173
173
  "properties": [
174
174
  {
@@ -199,7 +199,7 @@
199
199
  "sortBy": [
200
200
  {
201
201
  "desc": true,
202
- "displayName": "timestamp"
202
+ "displayName": "Timestamp"
203
203
  }
204
204
  ]
205
205
  },
@@ -207,9 +207,9 @@
207
207
  "targets": [
208
208
  {
209
209
  "datasource": "SQLite",
210
- "queryText": "WITH RECURSIVE group_hierarchy AS (\n -- Anchor: pick root groups (no parent_txgroup)\n SELECT\n txgroup_id,\n parent_txgroup,\n name\n FROM txgroups\n WHERE parent_txgroup IS NULL\n\n UNION ALL\n\n -- Recursively associate each child with its top-level parent's name\n SELECT\n child.txgroup_id,\n child.parent_txgroup,\n parent.name\n FROM txgroups child\n JOIN group_hierarchy parent \n ON child.parent_txgroup = parent.txgroup_id\n)\n\nselect timestamp, block, hash, token, \"from\", from_nickname as \"from nickname\", \"to\", to_nickname as \"to nickname\", amount, price, value_usd as \"value usd\", txgroup, a.parent_txgroup, log_index\nfrom (\n SELECT datetime(a.timestamp, 'unixepoch') AS timestamp, a.block, a.hash, c.symbol AS token, d.address AS \"from\", d.nickname as from_nickname, e.address AS \"to\", e.nickname as to_nickname, a.amount, a.price, a.value_usd, f.name AS txgroup, g.name AS parent_txgroup, f.txgroup_id, a.log_index\n FROM treasury_txs a\n LEFT JOIN chains b ON a.chain = b.chain_dbid\n LEFT JOIN tokens c ON a.token_id = c.token_id\n LEFT JOIN addresses d ON a.\"from\" = d.address_id\n LEFT JOIN addresses e ON a.\"to\" = e.address_id\n LEFT JOIN txgroups f ON a.txgroup_id = f.txgroup_id\n LEFT JOIN txgroups g ON f.parent_txgroup = g.txgroup_id\n WHERE a.timestamp >= $__from / 1000 \n and a.timestamp < $__to / 1000 \n and ('$Chain' like '{%' or b.chain_name = '$Chain') \n and ('$Token' like '{%' or c.symbol = '$Token') \n and ('$From' like '{%' or d.address = '$From') \n and ('$To' like '{%' or e.address = '$To')\n and ('$FromNickname' like '{%' or d.nickname = '$FromNickname') \n and ('$ToNickname' like '{%' or e.nickname = '$ToNickname')\n --UNION\n --SELECT -1, chain_name, TIMESTAMP, cast(block AS integer) block, hash, CAST(log_index AS integer) as log_index, token, \"from\", from_nickname, \"to\", to_nickname, amount, price, value_usd, txgroup, parent_txgroup, txgroup_id\n --FROM stream_ledger\n --UNION\n --SELECT -1, *\n --FROM vesting_ledger \n) a\nleft join group_hierarchy b on a.txgroup_id = b.txgroup_id\n-- Filter by $Top (accept \"All\"/multi-value if $Top starts with \"{\", or match name directly)\nWHERE ('$Top' LIKE '{%' OR b.name = '$Top')\nORDER BY timestamp",
210
+ "queryText": "select timestamp as \"Timestamp\", block as \"Block\", hash as \"Hash\", token as \"Token\", \"from\" as \"From\", from_nickname as \"From Nickname\", \"to\" as \"To\", to_nickname as \"To Nickname\", amount as \"Amount\", price as \"Price\", value_usd as \"Value USD\", txgroup as \"TxGroup\", a.parent_txgroup as \"Parent TxGroup\", log_index as \"Log Index\" from ( SELECT datetime(a.timestamp, 'unixepoch') AS timestamp, a.block, a.hash, c.symbol AS token, d.address AS \"from\", d.nickname as from_nickname, e.address AS \"to\", e.nickname as to_nickname, a.amount, a.price, a.value_usd, f.name AS txgroup, g.name AS parent_txgroup, f.txgroup_id, a.log_index FROM treasury_txs a LEFT JOIN chains b ON a.chain = b.chain_dbid LEFT JOIN tokens c ON a.token_id = c.token_id LEFT JOIN addresses d ON a.\"from\" = d.address_id LEFT JOIN addresses e ON a.\"to\" = e.address_id LEFT JOIN txgroups f ON a.txgroup_id = f.txgroup_id LEFT JOIN txgroups g ON f.parent_txgroup = g.txgroup_id WHERE a.timestamp >= $__from / 1000 and a.timestamp < $__to / 1000 and ('$Chain' like '{%' or b.chain_name = '$Chain') and ('$Token' like '{%' or c.symbol = '$Token') and ('$From' like '{%' or d.address = '$From') and ('$To' like '{%' or e.address = '$To') and ('$FromNickname' like '{%' or d.nickname = '$FromNickname') and ('$ToNickname' like '{%' or e.nickname = '$ToNickname') ) a left join txgroup_hierarchy b on a.txgroup_id = b.txgroup_id WHERE ('$Top' LIKE '{%' OR b.top_category = '$Top') ORDER BY timestamp",
211
211
  "queryType": "table",
212
- "rawQueryText": "WITH RECURSIVE group_hierarchy AS (\n -- Anchor: pick root groups (no parent_txgroup)\n SELECT\n txgroup_id,\n parent_txgroup,\n name\n FROM txgroups\n WHERE parent_txgroup IS NULL\n\n UNION ALL\n\n -- Recursively associate each child with its top-level parent's name\n SELECT\n child.txgroup_id,\n child.parent_txgroup,\n parent.name\n FROM txgroups child\n JOIN group_hierarchy parent \n ON child.parent_txgroup = parent.txgroup_id\n)\n\nselect timestamp, block, hash, token, \"from\", from_nickname as \"from nickname\", \"to\", to_nickname as \"to nickname\", amount, price, value_usd as \"value usd\", txgroup, a.parent_txgroup, log_index\nfrom (\n SELECT datetime(a.timestamp, 'unixepoch') AS timestamp, a.block, a.hash, c.symbol AS token, d.address AS \"from\", d.nickname as from_nickname, e.address AS \"to\", e.nickname as to_nickname, a.amount, a.price, a.value_usd, f.name AS txgroup, g.name AS parent_txgroup, f.txgroup_id, a.log_index\n FROM treasury_txs a\n LEFT JOIN chains b ON a.chain = b.chain_dbid\n LEFT JOIN tokens c ON a.token_id = c.token_id\n LEFT JOIN addresses d ON a.\"from\" = d.address_id\n LEFT JOIN addresses e ON a.\"to\" = e.address_id\n LEFT JOIN txgroups f ON a.txgroup_id = f.txgroup_id\n LEFT JOIN txgroups g ON f.parent_txgroup = g.txgroup_id\n WHERE a.timestamp >= $__from / 1000 \n and a.timestamp < $__to / 1000 \n and ('$Chain' like '{%' or b.chain_name = '$Chain') \n and ('$Token' like '{%' or c.symbol = '$Token') \n and ('$From' like '{%' or d.address = '$From') \n and ('$To' like '{%' or e.address = '$To')\n and ('$FromNickname' like '{%' or d.nickname = '$FromNickname') \n and ('$ToNickname' like '{%' or e.nickname = '$ToNickname')\n --UNION\n --SELECT -1, chain_name, TIMESTAMP, cast(block AS integer) block, hash, CAST(log_index AS integer) as log_index, token, \"from\", from_nickname, \"to\", to_nickname, amount, price, value_usd, txgroup, parent_txgroup, txgroup_id\n --FROM stream_ledger\n --UNION\n --SELECT -1, *\n --FROM vesting_ledger \n) a\nleft join group_hierarchy b on a.txgroup_id = b.txgroup_id\n-- Filter by $Top (accept \"All\"/multi-value if $Top starts with \"{\", or match name directly)\nWHERE ('$Top' LIKE '{%' OR b.name = '$Top')\nORDER BY timestamp",
212
+ "rawQueryText": "select timestamp as \"Timestamp\", block as \"Block\", hash as \"Hash\", token as \"Token\", \"from\" as \"From\", from_nickname as \"From Nickname\", \"to\" as \"To\", to_nickname as \"To Nickname\", amount as \"Amount\", price as \"Price\", value_usd as \"Value USD\", txgroup as \"TxGroup\", a.parent_txgroup as \"Parent TxGroup\", log_index as \"Log Index\" from ( SELECT datetime(a.timestamp, 'unixepoch') AS timestamp, a.block, a.hash, c.symbol AS token, d.address AS \"from\", d.nickname as from_nickname, e.address AS \"to\", e.nickname as to_nickname, a.amount, a.price, a.value_usd, f.name AS txgroup, g.name AS parent_txgroup, f.txgroup_id, a.log_index FROM treasury_txs a LEFT JOIN chains b ON a.chain = b.chain_dbid LEFT JOIN tokens c ON a.token_id = c.token_id LEFT JOIN addresses d ON a.\"from\" = d.address_id LEFT JOIN addresses e ON a.\"to\" = e.address_id LEFT JOIN txgroups f ON a.txgroup_id = f.txgroup_id LEFT JOIN txgroups g ON f.parent_txgroup = g.txgroup_id WHERE a.timestamp >= $__from / 1000 and a.timestamp < $__to / 1000 and ('$Chain' like '{%' or b.chain_name = '$Chain') and ('$Token' like '{%' or c.symbol = '$Token') and ('$From' like '{%' or d.address = '$From') and ('$To' like '{%' or e.address = '$To') and ('$FromNickname' like '{%' or d.nickname = '$FromNickname') and ('$ToNickname' like '{%' or e.nickname = '$ToNickname') ) a left join txgroup_hierarchy b on a.txgroup_id = b.txgroup_id WHERE ('$Top' LIKE '{%' OR b.top_category = '$Top') ORDER BY timestamp",
213
213
  "refId": "A",
214
214
  "timeColumns": [
215
215
  "time",
@@ -233,18 +233,18 @@
233
233
  "value": "$__all"
234
234
  },
235
235
  "datasource": "SQLite",
236
- "definition": "WITH RECURSIVE group_hierarchy AS (\n -- Anchor: pick all top-level groups (no parent)\n SELECT txgroup_id, parent_txgroup, name\n FROM txgroups\n WHERE parent_txgroup IS NULL\n UNION ALL\n -- Recursive: link child groups to the top-level parent's name\n SELECT\n child.txgroup_id,\n child.parent_txgroup,\n parent.name -- keep the top-level parent's name\n FROM txgroups child\n JOIN group_hierarchy parent\n ON child.parent_txgroup = parent.txgroup_id\n)\n\nSELECT DISTINCT gh.name\nFROM treasury_txs a\nINNER JOIN group_hierarchy gh\n ON a.txgroup_id = gh.txgroup_id;",
236
+ "definition": "SELECT DISTINCT gh.top_category FROM treasury_txs a INNER JOIN txgroup_hierarchy gh ON a.txgroup_id = gh.txgroup_id;",
237
237
  "hide": 0,
238
238
  "includeAll": true,
239
239
  "label": "Top Level",
240
240
  "multi": false,
241
241
  "name": "Top",
242
242
  "options": [],
243
- "query": "WITH RECURSIVE group_hierarchy AS (\n -- Anchor: pick all top-level groups (no parent)\n SELECT txgroup_id, parent_txgroup, name\n FROM txgroups\n WHERE parent_txgroup IS NULL\n UNION ALL\n -- Recursive: link child groups to the top-level parent's name\n SELECT\n child.txgroup_id,\n child.parent_txgroup,\n parent.name -- keep the top-level parent's name\n FROM txgroups child\n JOIN group_hierarchy parent\n ON child.parent_txgroup = parent.txgroup_id\n)\n\nSELECT DISTINCT gh.name\nFROM treasury_txs a\nINNER JOIN group_hierarchy gh\n ON a.txgroup_id = gh.txgroup_id;",
243
+ "query": "SELECT DISTINCT gh.top_category FROM treasury_txs a INNER JOIN txgroup_hierarchy gh ON a.txgroup_id = gh.txgroup_id;",
244
244
  "refresh": 2,
245
245
  "regex": "",
246
246
  "skipUrlSync": false,
247
- "sort": 1,
247
+ "sort": 5,
248
248
  "type": "query"
249
249
  },
250
250
  {
@@ -265,7 +265,7 @@
265
265
  "refresh": 2,
266
266
  "regex": "",
267
267
  "skipUrlSync": false,
268
- "sort": 0,
268
+ "sort": 5,
269
269
  "type": "query"
270
270
  },
271
271
  {
@@ -285,7 +285,7 @@
285
285
  "refresh": 2,
286
286
  "regex": "",
287
287
  "skipUrlSync": false,
288
- "sort": 1,
288
+ "sort": 5,
289
289
  "type": "query"
290
290
  },
291
291
  {
@@ -306,7 +306,7 @@
306
306
  "refresh": 2,
307
307
  "regex": "",
308
308
  "skipUrlSync": false,
309
- "sort": 1,
309
+ "sort": 5,
310
310
  "type": "query"
311
311
  },
312
312
  {
@@ -327,7 +327,7 @@
327
327
  "refresh": 2,
328
328
  "regex": "",
329
329
  "skipUrlSync": false,
330
- "sort": 1,
330
+ "sort": 5,
331
331
  "type": "query"
332
332
  },
333
333
  {
@@ -348,7 +348,7 @@
348
348
  "refresh": 2,
349
349
  "regex": "",
350
350
  "skipUrlSync": false,
351
- "sort": 1,
351
+ "sort": 5,
352
352
  "type": "query"
353
353
  },
354
354
  {
@@ -369,7 +369,7 @@
369
369
  "refresh": 2,
370
370
  "regex": "",
371
371
  "skipUrlSync": false,
372
- "sort": 1,
372
+ "sort": 5,
373
373
  "type": "query"
374
374
  }
375
375
  ]