flex_scaffold 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (48) hide show
  1. data/CHANGELOG +4 -0
  2. data/MIT-LICENSE +20 -0
  3. data/README +169 -0
  4. data/Rakefile +116 -0
  5. data/TODO +23 -0
  6. data/generators/flex_scaffold/USAGE +16 -0
  7. data/generators/flex_scaffold/flex_scaffold_generator.rb +434 -0
  8. data/generators/flex_scaffold/templates/_form.rhtml +1 -0
  9. data/generators/flex_scaffold/templates/_index.rmxml +210 -0
  10. data/generators/flex_scaffold/templates/_list.rhtml +0 -0
  11. data/generators/flex_scaffold/templates/_list.rmxml +17 -0
  12. data/generators/flex_scaffold_resource/USAGE +36 -0
  13. data/generators/flex_scaffold_resource/flex_scaffold_resource_generator.rb +81 -0
  14. data/generators/flex_scaffold_resource/templates/controller.rb +101 -0
  15. data/generators/flex_scaffold_resource/templates/index.rhtml +3 -0
  16. data/generators/flex_scaffold_resource/templates/layout.rhtml +19 -0
  17. data/init.rb +29 -0
  18. data/install.rb +1 -0
  19. data/lib/action_view_helper.rb +49 -0
  20. data/lib/actionscript_helper.rb +81 -0
  21. data/lib/config.rb +49 -0
  22. data/lib/flex_scaffold_plugin.rb +25 -0
  23. data/lib/flexobject_view_helper.rb +132 -0
  24. data/lib/mtag_helper.rb +98 -0
  25. data/lib/mxml_helper.rb +107 -0
  26. data/lib/rest_scaffolding.rb +137 -0
  27. data/lib/validations.rb +180 -0
  28. data/public/crossdomain.xml +6 -0
  29. data/public/history.htm +21 -0
  30. data/public/history.swf +0 -0
  31. data/public/images/add.gif +0 -0
  32. data/public/images/arrow_down.gif +0 -0
  33. data/public/images/arrow_up.gif +0 -0
  34. data/public/images/create.gif +0 -0
  35. data/public/images/delete.gif +0 -0
  36. data/public/images/indicator-small.gif +0 -0
  37. data/public/images/indicator.gif +0 -0
  38. data/public/images/read.gif +0 -0
  39. data/public/images/search.gif +0 -0
  40. data/public/images/update.gif +0 -0
  41. data/public/javascripts/flashobject.js +168 -0
  42. data/public/javascripts/history.js +48 -0
  43. data/public/playerProductInstall.swf +0 -0
  44. data/public/stylesheets/default.css +28 -0
  45. data/tasks/compile_swf.rake +100 -0
  46. data/tasks/flex_scaffold.rake +38 -0
  47. data/uninstall.rb +1 -0
  48. metadata +125 -0
data/CHANGELOG ADDED
@@ -0,0 +1,4 @@
1
+
2
+ 0.1.0 ==========
3
+
4
+ * Initial release 03/04/2007
data/MIT-LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2007 toddb
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README ADDED
@@ -0,0 +1,169 @@
1
+ =FlexScaffold
2
+
3
+
4
+ Flex Scaffold should allow you to swap in and out different view layers on your REST controller.
5
+ For example, to use the model <tt>contact</tt>, use <tt>flex_scaffold: contact</tt>
6
+
7
+ class ContactsController < ApplicationController
8
+
9
+ layout 'flex_scaffold'
10
+ flex_scaffold :contact (optional - :size => '800x600')
11
+
12
+ # The following line can be used instead of the generated definitions
13
+ # of index, show, new, edit, update, destroy. There is also the action
14
+ # schema to look at the data model
15
+ ...
16
+ end
17
+
18
+ Other files that are created:
19
+
20
+ /app/flex/contacts/_list.mxml
21
+ /app/flex/contacts/_contacts.mxml <-- these are compiled to a swf file
22
+
23
+ /public/swfs/flex_scaffold/_contacts.swf <-- created via rake flex:app mxml=contacts
24
+
25
+ /app/views/layout/flex_scaffold.rhtml <-- templated pages
26
+ /app/views/flex_scaffold/index.rhtml <-- loads up the swf
27
+
28
+ ==USAGE
29
+
30
+ ===Summary
31
+
32
+ To generate a scaffold for the model <tt>message</tt> with fields <tt>title</tt> and <tt>body</tt>:
33
+
34
+ > ruby script/generate flex_scaffold_resource message title:string body:string
35
+ > rake db:migrate
36
+ > ruby script/generate flex_scaffold message
37
+ > rake flex:app mxml=messages
38
+ > ruby script/server start
39
+
40
+ ===1. Install a REST service from flex_scaffold_resource
41
+
42
+ Create an Active Resource (REST service)
43
+
44
+ > ruby script/generate flex_scaffold_resource message title:string body:string
45
+
46
+ This simple command will generate a lot of stuff, in detail:
47
+
48
+ * A controller with REST actions and an action for getting the schema
49
+ * A model named message
50
+ * A migration named xxx_create_messages
51
+ * Fixture and unit tests for the model and the controller
52
+ * A line in your <tt>config/routes.rb</tt> file <tt>map.resources :messages</tt>
53
+
54
+
55
+ Alternatively, you can add scaffolding to any REST resources by adding to any controller:
56
+
57
+ flex_scaffold :message
58
+
59
+ Note: You can then delete or extend all the other REST actions as they are implicitly scaffolded
60
+
61
+ ===2. Migrate the database
62
+
63
+ > db:migrate
64
+
65
+ This updates the database ready for the scaffold to pick up the columns.
66
+
67
+ ===3. Create the scaffolds
68
+
69
+ > ruby script/generate flex_scaffold message
70
+
71
+ This will generate:
72
+
73
+ * A scaffold view for the controller which loads the swf
74
+ * A template layout for the controller
75
+ * Scaffolded mxml files (in <tt>app/flex</tt>)
76
+
77
+ ===4. Compile the scaffolds
78
+
79
+ > rake flex:app mxml=messages
80
+
81
+ This will generate:
82
+
83
+ * copy assets into the <tt>/app/flex/<model></tt> folder ready for compilation (see below)
84
+ * compile the swf files based on the configuration in the related controller to <tt>/app/flex/<model></tt>
85
+ * save the resulting swf in <tt>/public/swfs/flex_scaffold</tt>
86
+ * ensure that all needed public assets are copied to <tt>/public/</tt> [stylesheets, javascript] (also see Restart server below)
87
+
88
+ This +Rake+ task infact copies the necessary assets into the build folder </tt>/app/flex</tt> and then remove when finished. To avoid you compile only. This would involved steps either side for use:
89
+
90
+ > rake flex:build:install mxml=contacts [move the assets into the build structure]
91
+ > rake flex:compile mxml=contacts [repeat this as many times as needed]
92
+
93
+ Optionally you may wish to clean up:
94
+ > rake flex:build:clobber mxml=contacts
95
+
96
+ Note: There is currently no way to build multiple scaffolds at one time.
97
+
98
+ ===5. (Re)Start server?
99
+
100
+ Just check this. You should only need to restart the start to init the plugin. This will also copy the correct files to public which is equivalent to the +Rake+ task: <tt>rake flex:public:install</tt>
101
+
102
+
103
+ ==General Design Notes:
104
+
105
+ Key features:
106
+
107
+ * Easily scaffold
108
+ * Be able to manually compile
109
+ * Getting model validation generated out to the client (still working out on full validation conversion)
110
+
111
+ To do:
112
+
113
+ * Be able to cutomise views
114
+ * Automatic (re)complilation
115
+ * Perhaps, auto install <tt>flex_sdk2</tt> (this will probably break license - but could have local repository/or checked into a library)
116
+
117
+ Long run:
118
+
119
+ I suspect that there will need to split out flex_scaffold and ActionView::Helpers::FlexObjectHelper. I would hope
120
+ that flex have an equivalent set of helpers as javascript.
121
+
122
+ ===Phase I (complete)
123
+ * tie in REST (resource) generation for flex_scaffold
124
+ * scaffold model for flex viewing (flex_scaffold)
125
+ * generate mxml files for model
126
+ * compile swf
127
+ * transfer swf to public folder
128
+ * load page which points flash file (use JavascriptHelper in openLaszlo)
129
+ * add CRUD actions on controller
130
+ * add return schema onto controller
131
+
132
+ ===Phase II
133
+ * remove js, styles, etc as generator and put as rake command at startup
134
+ * add the view layer as the plugin rather than generator
135
+ * duplicate model validation (at compile time) into client (as well as server)
136
+ * autocompilation (generator knows whether there were changes)
137
+
138
+ ===Phase III
139
+ * configurable scaffold see ajax_scaffold [http://ajaxscaffold.stikipad.com/doc/show/4.0+Design+Docs]
140
+
141
+ flex_scaffold :task do
142
+ table :only => [ :name, :role ]
143
+ form :except => [ :created_at, :updated_at ]
144
+ columns do
145
+ name do
146
+ sort("name.downcase")
147
+ is_required
148
+ end
149
+ end
150
+ end
151
+
152
+
153
+ * template the flex code created in generator using helpers (develop ActiveView::Helpers::FlexHelper)
154
+ * that is use, rhtml to embed flex within pages (scaffold as a plugin) [unsure whether this will work and/or is desirable]
155
+
156
+ ===Phase IV
157
+ * multiple models on a page
158
+
159
+ ==Credits
160
+
161
+ Released under the MIT license (included)
162
+
163
+ * toddb --- Flex Scaffold plugin
164
+
165
+ The initial code was inspired by (or lifted from)
166
+ * <tt>flex_engenial_scaffold:</tt> This is the basis for the CRUD look and feel and early code basis
167
+ * <tt>flexible_rails:</tt> I have used his section from FlexibleRails for using REST services
168
+ * <tt>ajax_scaffold:</tt> basically reproduced their tables and hook code
169
+ * <tt>laszlo-plugin:</tt> this separates out the generators well and has a good javascript helper
data/Rakefile ADDED
@@ -0,0 +1,116 @@
1
+ require 'rake'
2
+ require 'rake/testtask'
3
+ require 'rake/rdoctask'
4
+ require 'rake/packagetask'
5
+ require 'rake/gempackagetask'
6
+ require 'rake/contrib/rubyforgepublisher'
7
+
8
+ PKG_NAME = "flex_scaffold"
9
+ PKG_VERSION = '0.1.0'
10
+ RUBYFORGE_PROJECT = 'flexible-rails'
11
+ RUBYFORGE_USER = ENV['RUBYFORGE_USER']
12
+
13
+ desc 'Default: run unit tests.'
14
+ task :default => :test
15
+
16
+ desc 'Test the flex_scaffold plugin.'
17
+ Rake::TestTask.new(:test) do |t|
18
+ t.libs << 'lib'
19
+ t.pattern = 'test/**/*_test.rb'
20
+ t.verbose = true
21
+ end
22
+
23
+ # Generate packages ------------------------------------------------------------------
24
+
25
+ Rake::PackageTask.new(PKG_NAME, PKG_VERSION) do |p|
26
+ p.need_tar = true
27
+ p.need_zip = true
28
+ p.package_files.include("./**/*")
29
+ p.package_files.exclude 'pkg', 'rdoc'
30
+ p.package_files.exclude 'notes.txt', '#*'
31
+ end
32
+
33
+ # Tag SVN for releases ------------------------------------------------------------------
34
+
35
+ task :tag_svn do
36
+ url = `svn info`[/^URL:\s*(.*\/)trunk/, 1]
37
+ tag_message = "-m \"tag release #{PKG_VERSION}\""
38
+ system("svn cp #{tag_message} #{url}/trunk #{url}/tags/REL-#{PKG_VERSION.gsub(/\./,'_')}")
39
+ system("svn cp #{tag_message} #{url}/trunk #{url}/rails/plugins/flex_scaffold")
40
+ end
41
+
42
+ # Generate documentation ------------------------------------------------------------------
43
+
44
+ desc 'Generate documentation for the flex_scaffold plugin.'
45
+ Rake::RDocTask.new(:rdoc) do |rdoc|
46
+ rdoc.rdoc_dir = 'rdoc'
47
+ rdoc.title = 'Flexible Scaffolding for Rails -- Embedding Flex in Rails through REST'
48
+ rdoc.main = 'README'
49
+ rdoc.options << '--line-numbers' << '--inline-source'
50
+ rdoc.rdoc_files.include('README', 'TODO', 'MIT-LICENSE', 'CHANGELOG')
51
+ rdoc.rdoc_files.include('lib/**/*.rb')
52
+ end
53
+
54
+ # Generate GEM ----------------------------------------------------------------------------
55
+
56
+ PKG_FILES = FileList[
57
+ '[a-zA-Z]*',
58
+ 'tasks/**/*',
59
+ 'public/**/*',
60
+ 'generators/**/*',
61
+ 'lib/**/*'
62
+ ] - [ 'test' ]
63
+
64
+ spec = Gem::Specification.new do |s|
65
+ s.name = 'flex_scaffold'
66
+ s.version = PKG_VERSION
67
+ s.summary = "Plugin for scaffolding a Flex view within Rails on REST services."
68
+ s.description = <<-EOF
69
+ Flexible Rails Scaffolding is a plugin to scaffold REST controllers and a flex view for models. Use generators
70
+ to create the code and rake to compile. Flexible Rails generates .mxml and .as code so that it can be edited
71
+ by both Rails and Flex coders.
72
+ EOF
73
+
74
+ s.add_dependency('rake', '>= 0.7.2')
75
+ s.add_dependency('rails','>= 1.2.0')
76
+
77
+ s.rdoc_options << '--exclude' << '.'
78
+ s.has_rdoc = false
79
+
80
+ s.files = PKG_FILES.to_a.delete_if {|f| f.include?('.svn')}
81
+ s.require_path = 'lib'
82
+
83
+ s.author = "toddb"
84
+ s.email = "todd@8wireunlimited.com"
85
+ s.homepage = "http://flexible-rails.rubyforge.org"
86
+ s.rubyforge_project = "flexible-rails"
87
+ end
88
+
89
+ Rake::GemPackageTask.new(spec) do |pkg|
90
+ pkg.gem_spec = spec
91
+ end
92
+
93
+
94
+ # Publishing -------------------------------------------------------
95
+ #desc "Publish the API documentation"
96
+ #task :pgem => [:gem] do
97
+ # Rake::SshFilePublisher.new("davidhh@wrath.rubyonrails.org", "public_html/gems/gems", "pkg", "#{PKG_FILE_NAME}.gem").upload
98
+ # `ssh davidhh@wrath.rubyonrails.org './gemupdate.sh'`
99
+ #end
100
+
101
+ desc "Publish the API documentation"
102
+ task :publish_rdoc => [:rdoc] do
103
+ program = (RUBY_PLATFORM =~ /mswin32/) ? "winscp3" : "scp"
104
+ system("#{program} -r rdoc/* #{RUBYFORGE_USER}@rubyforge.org:/var/www/gforge-projects/#{RUBYFORGE_PROJECT}")
105
+ end
106
+
107
+ desc "Publish the release files to RubyForge."
108
+ task :release => [ :package ] do
109
+ require 'rubyforge'
110
+
111
+ packages = %w( gem tgz zip ).collect{ |ext| "pkg/#{PKG_NAME}-#{PKG_VERSION}.#{ext}" }
112
+
113
+ rubyforge = RubyForge.new
114
+ rubyforge.login
115
+ rubyforge.add_release(RUBYFORGE_PROJECT, PKG_NAME, "REL #{PKG_VERSION}", *packages)
116
+ end
data/TODO ADDED
@@ -0,0 +1,23 @@
1
+ = Flexible Rails -- To Do List
2
+
3
+ == Fixes
4
+ * Sizing on pages at 100% height is dodgy because it needs it is based on the parent element - if this is body it is not implicitly sized (see http://www.webmasterworld.com/forum83/200.htm)
5
+ * Update is slightly broken
6
+
7
+ == Better understanding
8
+ * Flex use of CSS (personally I'm finding it limited) for themes
9
+
10
+ == New features
11
+ * Warn when needs recompilation
12
+ * Automatic recompilation
13
+ * themes
14
+ * Ensure app/flex/ can be used in conjunction with FlexBuilder
15
+
16
+ ==Refactoring
17
+ * The generator code is ugly
18
+ * Separate out the functions in the mxml code
19
+
20
+ ==Limitations
21
+ * Extend validation conversions
22
+ * No test suite
23
+ * Remove the hooks into the validation on the ActiveRecord (see lib\validations.rb)
@@ -0,0 +1,16 @@
1
+ Description:
2
+ The flex_scaffold generator creates a Flex application mxml source file and
3
+ a view that displays it. The model and controller must alrady exist: user script/generate
4
+ flex_scaffold_resource.
5
+
6
+ The generator takes a model name (singular) as its first argument.
7
+
8
+ Example:
9
+ ./script/generate flex_scaffold contact
10
+
11
+ This will create:
12
+ app/flex/contacts/contacts.mxml
13
+ app/flex/contacts/_list.mxml
14
+ app/views/contacts/index.rhtml
15
+ app/views/layouts/contacts.rhtml
16
+