forked from tantaman/strut
-
Notifications
You must be signed in to change notification settings - Fork 0
/
todo.txt
196 lines (132 loc) · 6.23 KB
/
todo.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
-EditorModel will get updated when a new generator is selected
-EditorModel will check to see if that generator allows modes
-Set mode to none if not
-Enable other controls required by generator
-Other controls will behave similarly to the mode button stuff in the header?
-text writer
-destroy event
-gradient picker
other things to jquery misc?
Should have a strut.command interface...
and certain command will go into the menu...
metadata will dictate where they go..
push to back, pull to front
z-tracker!!!
vert.x and clojure for strut service?
TODO: remove jquery and use zepto -or- use jquery 2
So end result:
config.js -> list bundle names and rmap location
rmap -> map bundle names to physical locations
framework -> loads config.js and sets up require.js paths
bundles -> load own contents based on relative paths,
load contents of other bundles based on bundle name and inner bundle paths.
TODO: how about bundles that export packages that aren't a superstring of their name?
Then config will be loaded... bundle metadata will all be loaded...
based on bundle metadata we can come up with rules?
because bundle will export something and we know the bundle path so whatever it
exports will be relative to the bundle path since packages
must be structured correctly within a bundle.
Packages must be separated by '/' not '.' to appease requirejs.
config.js:
return {
rmap: 'path/to/rmap',
bundles: [
'com/tantaman/web/storage',
'strut.editor',
etc...
]
}
rmap.js:
return {
'com/tantaman/web/storage': 'bundles/common/com.tantaman.storage',
'strut/editor': 'bundles/strut/editor'
}
and require.js path rules:
requirejs.config({
path: {
'bundle-name': 'bundle-location'
}
});
Path structure is basically the rmap! Can we load the rmap directly into the config then?
Or screw the rmap and have the user just make the rmap in their requirejs
configuration?
Eh, separate rmap is better so we can do tooling and build the rmap.
Later we need to handle exporting of packages from a bundle. Packages in a bundle
should be allowed to be unqualified? E.g.,
com.tantaman.storage/Thinger will be a part of com.tantaman.storage?
How do we then handle qualified ones? :| Does it really make sense in a js env?
It'll later have to be handled with export pkg. For the time being
the bundle will be considered to export a package that is the bundle name
and that'll be added to the rmap.
Eventually no bundle names, but only exported packages, will exist in the path mapping since we import packages and not bundle-name/package.
so what does that look like?
We still need the rmap for bundle-name to location but the requirejs.path will
only contain package -> location after those packages have been resolved to specific bundle.s
Bundle gets loaded based on path,
bundle metadata is returned,
exported packages are concatenated with bundle path to get full path.
path {
exported_package: bundle-location + exported_package
}
Seems like we can just modify requirejs to register anything under "exports" as
a new path.
This means package MUST be split by '/' and not '.'.
So this looks like:
manifest.js (or maybe just main.js):
bundleName: 'com/tantaman/web/storage',
exportPackage: [
'com/tantaman/web/storage',
'com/tantaman/web/storage/model',
'com/tantaman/web/storage/view'
]
The exports become 'path' rules for requirejs!
The path rule would be:
'package' => currentLocation + package.remove(bundleName)
This of course give access to everything unde the package..
Could remove exportPackage and just use "bundleName" for the re-write rule
of course this leads to uncontrolled exports (at first anyhow).
This rule looks like:
bundleName => currentLocation
How do we know our current location? The main.js's path...
We can use onResourceLoad https://github.com/jrburke/requirejs/wiki/Internal-API:-onResourceLoad
to figure out the url of the loaded module. The framework can then
determine if the loaded item is a bundle initializer or not...
if so it'll set up the bundle root path. How do we know if it is a bundle
initializer / bundle root? We can get that from the feature / config.ini..
Instead of requiring bundles directly we can tell the framework that we want
them and then it can register their paths as bundle roots. Well then we don't need onload? Since we know the bundle roots from the config we can set up re-write rules immediately? We need the bundle name for re-writing..
So
1. bundle root will just be "metadata" the gets loaded
2. metadata.js will have to register itself with the framework
3. It'll have a bundle name that it provides in registration
4. well we never have the name and path at the same time... so we
can't associate them...
This means the feature.xml / config.ini will need to know
the path and bundle name?
Any way to just know bundle names? We can do this by updating the build system?
Build system can look through bundle location(s) and generate the correct mappings... by going through the bundles in that location, looking at their meta and registering the mapping.
Maybe the config.ini just specifies the bundle names and then a resource map specifies their locations. The resource map can be constructed at build time or created manually or use a ResolutionConfiguration and Resolver?
config.ini (feature.js / config.js) will hold the path to the resource map.
bundle/strut/editor
Allow plugins to be sandboxed via i-frames?
So an import later
Need to update requirejs:
-files within a bundle will refer to one another via relative paths?
-once loaded those files will define their external name(s) to be loadable
from outside the bundle.
e.g.,
main:
define(['./Class1'], {})
Class1:
define('com.tantaman.Class1', {})
If no symbolic name is provided in the define then that class isn't exactly "exported"! :)
-We need the storage interface to be completely generic (i.e. reusable across projects)
-So we need to split that storage bundle into the generic storage interface
and the strut specific storage interface.
->Re-visit all components and split them according to the above advice.
->Re-visit wrappers (e.g., storageProviderWrapper) and update to use ServiceCollection.
-Re-visit the command structure and redo/undo
-Multi select
-Re-visit keyboard shortcut handling.
-Make place component smarter
-Handle z-ordering on slides