Flex gantt based on the sample code from ilog / elixir. The demo had a bunch of pitfalls, which I’ve tried to overcome
- underling data model (collections) are not XML based. Seems to me that adobe relies on the xml data for alot of their proof of concept.
- nested set library from pear php to persist the tree in the back end. There was a bit of heavy lifting and I ended up hacking the pear NestedSet.php
- support for multiple trees (forest) in the nested set
- ilog has bug in the constraints where the constraints do not refresh
- highlighting the selected constraint
- circular reference cycles in the directed graph using the tarjan algorithm from a previous post
- When a parent constraint changes the move.
- Database is sync’d for most interactions
- supports a templatization, where the dates get bumped to the the current date + 7 for each template, so you can ruse a project.
After a bunch of thought early on, I decided to try to map nodes, constraints and resources with associated reservations to rows in the database. My thinking was to build it this way for a few reasons:
- I didn’t want to have a corrupt xml and then have to go through the pain to of debugging it
- support for future concurrency. While it’s not in my use case as of now, my thinking was that XML blobs in the database do not lend themselves to collaboration. Of course if I was to go with real time concurrency, I would need to think about a COCOMO option
- templates and copying
- I didn’t want to get in the situation where a user made bunch of edits and then app failed, or the persistence failed or the javascript saying “you need to save” because you just navigated away.
The real drawback to going away from xml is that there would be a bunch more heavy lifting to import/export to MS Project Plan
As you can tell, I may have chosen poorly.
1 comment:
Hi, do you can post a source for me?
Post a Comment