extjs-rails 4.1.0.alpha1
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +18 -0
- data/Gemfile +4 -0
- data/LICENSE +36 -0
- data/README.md +29 -0
- data/Rakefile +2 -0
- data/app/assets/javascripts/extjs-rails/extjs-rails.js +1 -0
- data/app/assets/javascripts/extjs-rails/index.js.erb +9 -0
- data/app/assets/javascripts/extjs-rails/sdk.jsb3 +2017 -0
- data/app/assets/javascripts/extjs-rails/src/AbstractComponent.js +3290 -0
- data/app/assets/javascripts/extjs-rails/src/AbstractManager.js +144 -0
- data/app/assets/javascripts/extjs-rails/src/AbstractPlugin.js +72 -0
- data/app/assets/javascripts/extjs-rails/src/Action.js +276 -0
- data/app/assets/javascripts/extjs-rails/src/Ajax.js +99 -0
- data/app/assets/javascripts/extjs-rails/src/Component.js +1344 -0
- data/app/assets/javascripts/extjs-rails/src/ComponentLoader.js +202 -0
- data/app/assets/javascripts/extjs-rails/src/ComponentManager.js +47 -0
- data/app/assets/javascripts/extjs-rails/src/ComponentQuery.js +521 -0
- data/app/assets/javascripts/extjs-rails/src/Editor.js +494 -0
- data/app/assets/javascripts/extjs-rails/src/ElementLoader.js +404 -0
- data/app/assets/javascripts/extjs-rails/src/FocusManager.js +712 -0
- data/app/assets/javascripts/extjs-rails/src/Img.js +111 -0
- data/app/assets/javascripts/extjs-rails/src/Layer.js +543 -0
- data/app/assets/javascripts/extjs-rails/src/LoadMask.js +432 -0
- data/app/assets/javascripts/extjs-rails/src/ModelManager.js +186 -0
- data/app/assets/javascripts/extjs-rails/src/PluginManager.js +110 -0
- data/app/assets/javascripts/extjs-rails/src/ProgressBar.js +336 -0
- data/app/assets/javascripts/extjs-rails/src/Shadow.js +233 -0
- data/app/assets/javascripts/extjs-rails/src/ShadowPool.js +43 -0
- data/app/assets/javascripts/extjs-rails/src/Template.js +331 -0
- data/app/assets/javascripts/extjs-rails/src/XTemplate.js +365 -0
- data/app/assets/javascripts/extjs-rails/src/XTemplateCompiler.js +450 -0
- data/app/assets/javascripts/extjs-rails/src/XTemplateParser.js +249 -0
- data/app/assets/javascripts/extjs-rails/src/ZIndexManager.js +519 -0
- data/app/assets/javascripts/extjs-rails/src/app/Application.js +271 -0
- data/app/assets/javascripts/extjs-rails/src/app/Controller.js +458 -0
- data/app/assets/javascripts/extjs-rails/src/app/EventBus.js +112 -0
- data/app/assets/javascripts/extjs-rails/src/button/Button.js +1483 -0
- data/app/assets/javascripts/extjs-rails/src/button/Cycle.js +215 -0
- data/app/assets/javascripts/extjs-rails/src/button/Split.js +99 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Callout.js +140 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Chart.js +966 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Highlight.js +172 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Label.js +241 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Legend.js +474 -0
- data/app/assets/javascripts/extjs-rails/src/chart/LegendItem.js +217 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Mask.js +230 -0
- data/app/assets/javascripts/extjs-rails/src/chart/MaskLayer.js +48 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Navigation.js +79 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Shape.js +106 -0
- data/app/assets/javascripts/extjs-rails/src/chart/Tip.js +98 -0
- data/app/assets/javascripts/extjs-rails/src/chart/TipSurface.js +42 -0
- data/app/assets/javascripts/extjs-rails/src/chart/axis/Abstract.js +73 -0
- data/app/assets/javascripts/extjs-rails/src/chart/axis/Axis.js +961 -0
- data/app/assets/javascripts/extjs-rails/src/chart/axis/Category.js +130 -0
- data/app/assets/javascripts/extjs-rails/src/chart/axis/Gauge.js +203 -0
- data/app/assets/javascripts/extjs-rails/src/chart/axis/Numeric.js +235 -0
- data/app/assets/javascripts/extjs-rails/src/chart/axis/Radial.js +204 -0
- data/app/assets/javascripts/extjs-rails/src/chart/axis/Time.js +135 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Area.js +803 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Bar.js +853 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Cartesian.js +328 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Column.js +104 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Gauge.js +490 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Line.js +1104 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Pie.js +1072 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Radar.js +440 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Scatter.js +668 -0
- data/app/assets/javascripts/extjs-rails/src/chart/series/Series.js +443 -0
- data/app/assets/javascripts/extjs-rails/src/chart/theme/Base.js +175 -0
- data/app/assets/javascripts/extjs-rails/src/chart/theme/Theme.js +253 -0
- data/app/assets/javascripts/extjs-rails/src/container/AbstractContainer.js +1062 -0
- data/app/assets/javascripts/extjs-rails/src/container/ButtonGroup.js +143 -0
- data/app/assets/javascripts/extjs-rails/src/container/Container.js +212 -0
- data/app/assets/javascripts/extjs-rails/src/container/DockingContainer.js +265 -0
- data/app/assets/javascripts/extjs-rails/src/container/Viewport.js +184 -0
- data/app/assets/javascripts/extjs-rails/src/core/dom/Element.form.js +50 -0
- data/app/assets/javascripts/extjs-rails/src/core/dom/Element.static-more.js +159 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/index.html +321 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/index.js +6 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/CTO.js +25 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/CoolGuy.js +20 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/Developer.js +43 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/Gun.js +3 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/HumanResource.js +23 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/Musician.js +20 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/Person.js +50 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/ability/CanComposeSongs.js +9 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/ability/CanPlayGuitar.js +9 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/ability/CanSing.js +18 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/deadlock/A.js +3 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/deadlock/B.js +3 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/deadlock/C.js +3 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/deadlock/D.js +3 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/deadlock/E.js +3 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/notdeadlock/A.js +3 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/notdeadlock/B.js +4 -0
- data/app/assets/javascripts/extjs-rails/src/core/examples/src/Sample/notdeadlock/C.js +3 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/EventManager.js +1167 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/EventObject.js +883 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/Ext-more.js +1283 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/Ext.js +736 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/Support.js +662 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/class/Base.js +1085 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/class/Class.js +676 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/class/ClassManager.js +1591 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/class/Loader.js +1423 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractElement.alignment.js +173 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractElement.insertion.js +193 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractElement.js +681 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractElement.position.js +356 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractElement.static.js +474 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractElement.style.js +851 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractElement.traversal.js +180 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractHelper.js +291 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/AbstractQuery.js +72 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/CompositeElement.js +75 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/CompositeElementLite.js +436 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/dom/DomQuery-aria.js +1049 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/env/Browser.js +186 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/env/FeatureDetector.js +274 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/env/OS.js +141 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/lang/Array.js +1205 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/lang/Date.js +1463 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/lang/Error.js +326 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/lang/Function.js +485 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/lang/Number.js +175 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/lang/Object.js +606 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/lang/String.js +333 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/misc/JSON.js +236 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/perf/Accumulator.js +244 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/perf/Monitor.js +197 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/util/DelayedTask.js +71 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/util/Event.js +215 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/util/Format.js +551 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/util/TaskManager.js +417 -0
- data/app/assets/javascripts/extjs-rails/src/core/src/version/Version.js +364 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/README.MD +91 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/bootstrap.js +39 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/build/build-data.js +34 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/build/build.sh +2 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/data.js +27 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/index.html +15 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/other_specs/dom.html +40 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/other_specs/dom/extjs-api.js +12 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/other_specs/dom/platform-api.js +134 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/other_specs/dom/sanity.js +4 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/other_specs/dom/touch-api-out.js +128 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/other_specs/dom/touch-api.js +89 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/other_specs/env/Environment.js +357 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/resources/APITest.js +37 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/resources/jsb3.js +14 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/resources/test-setup.js +137 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/EventManager.js +629 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/Ext-mess.backup +198 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/Ext-more.js +520 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/Ext.js +1550 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/Support.js +250 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/class/Base.js +47 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/class/Class.js +561 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/class/ClassManager.js +555 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/dom/CompositeElementLite.js +409 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/dom/DomHelper.js +444 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/dom/Element.insertion.js +342 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/dom/Element.js +731 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/dom/Element.static.js +201 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/dom/Element.style.js +118 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/dom/Element.traversal.js +336 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/lang/Array.js +1229 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/lang/Date.js +697 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/lang/Error.js +277 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/lang/Function.js +536 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/lang/Number.js +323 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/lang/Object.js +591 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/lang/String.js +451 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/misc/JSON.js +252 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/util/Format.js +521 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/spec/version/Version.js +148 -0
- data/app/assets/javascripts/extjs-rails/src/core/test/unit/specs.html +19 -0
- data/app/assets/javascripts/extjs-rails/src/data/AbstractStore.js +887 -0
- data/app/assets/javascripts/extjs-rails/src/data/ArrayStore.js +74 -0
- data/app/assets/javascripts/extjs-rails/src/data/Batch.js +236 -0
- data/app/assets/javascripts/extjs-rails/src/data/BufferStore.js +13 -0
- data/app/assets/javascripts/extjs-rails/src/data/Connection.js +969 -0
- data/app/assets/javascripts/extjs-rails/src/data/DirectStore.js +50 -0
- data/app/assets/javascripts/extjs-rails/src/data/Errors.js +52 -0
- data/app/assets/javascripts/extjs-rails/src/data/Field.js +341 -0
- data/app/assets/javascripts/extjs-rails/src/data/IdGenerator.js +198 -0
- data/app/assets/javascripts/extjs-rails/src/data/JsonP.js +253 -0
- data/app/assets/javascripts/extjs-rails/src/data/JsonPStore.js +51 -0
- data/app/assets/javascripts/extjs-rails/src/data/JsonStore.js +60 -0
- data/app/assets/javascripts/extjs-rails/src/data/Model.js +1673 -0
- data/app/assets/javascripts/extjs-rails/src/data/NodeInterface.js +1294 -0
- data/app/assets/javascripts/extjs-rails/src/data/NodeStore.js +254 -0
- data/app/assets/javascripts/extjs-rails/src/data/Operation.js +331 -0
- data/app/assets/javascripts/extjs-rails/src/data/Request.js +40 -0
- data/app/assets/javascripts/extjs-rails/src/data/ResultSet.js +56 -0
- data/app/assets/javascripts/extjs-rails/src/data/SequentialIdGenerator.js +61 -0
- data/app/assets/javascripts/extjs-rails/src/data/SortTypes.js +125 -0
- data/app/assets/javascripts/extjs-rails/src/data/Store.js +2609 -0
- data/app/assets/javascripts/extjs-rails/src/data/StoreManager.js +156 -0
- data/app/assets/javascripts/extjs-rails/src/data/Tree.js +290 -0
- data/app/assets/javascripts/extjs-rails/src/data/TreeStore.js +655 -0
- data/app/assets/javascripts/extjs-rails/src/data/Types.js +190 -0
- data/app/assets/javascripts/extjs-rails/src/data/UuidGenerator.js +215 -0
- data/app/assets/javascripts/extjs-rails/src/data/XmlStore.js +76 -0
- data/app/assets/javascripts/extjs-rails/src/data/association/Association.js +243 -0
- data/app/assets/javascripts/extjs-rails/src/data/association/BelongsTo.js +291 -0
- data/app/assets/javascripts/extjs-rails/src/data/association/HasMany.js +289 -0
- data/app/assets/javascripts/extjs-rails/src/data/association/HasOne.js +304 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/Ajax.js +282 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/Client.js +21 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/Direct.js +181 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/JsonP.js +313 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/LocalStorage.js +69 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/Memory.js +156 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/Proxy.js +433 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/Rest.js +173 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/Server.js +460 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/SessionStorage.js +39 -0
- data/app/assets/javascripts/extjs-rails/src/data/proxy/WebStorage.js +546 -0
- data/app/assets/javascripts/extjs-rails/src/data/reader/Array.js +68 -0
- data/app/assets/javascripts/extjs-rails/src/data/reader/Json.js +383 -0
- data/app/assets/javascripts/extjs-rails/src/data/reader/Reader.js +735 -0
- data/app/assets/javascripts/extjs-rails/src/data/reader/Xml.js +292 -0
- data/app/assets/javascripts/extjs-rails/src/data/validations.js +149 -0
- data/app/assets/javascripts/extjs-rails/src/data/writer/Json.js +81 -0
- data/app/assets/javascripts/extjs-rails/src/data/writer/Writer.js +147 -0
- data/app/assets/javascripts/extjs-rails/src/data/writer/Xml.js +88 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DD.js +300 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DDProxy.js +204 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DDTarget.js +171 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DragDrop.js +1101 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DragDropManager.js +1264 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DragSource.js +392 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DragTracker.js +562 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DragZone.js +137 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DropTarget.js +118 -0
- data/app/assets/javascripts/extjs-rails/src/dd/DropZone.js +254 -0
- data/app/assets/javascripts/extjs-rails/src/dd/Registry.js +117 -0
- data/app/assets/javascripts/extjs-rails/src/dd/ScrollManager.js +218 -0
- data/app/assets/javascripts/extjs-rails/src/dd/StatusProxy.js +179 -0
- data/app/assets/javascripts/extjs-rails/src/diag/layout/Context.js +523 -0
- data/app/assets/javascripts/extjs-rails/src/diag/layout/ContextItem.js +179 -0
- data/app/assets/javascripts/extjs-rails/src/direct/Event.js +35 -0
- data/app/assets/javascripts/extjs-rails/src/direct/ExceptionEvent.js +16 -0
- data/app/assets/javascripts/extjs-rails/src/direct/JsonProvider.js +82 -0
- data/app/assets/javascripts/extjs-rails/src/direct/Manager.js +263 -0
- data/app/assets/javascripts/extjs-rails/src/direct/PollingProvider.js +156 -0
- data/app/assets/javascripts/extjs-rails/src/direct/Provider.js +96 -0
- data/app/assets/javascripts/extjs-rails/src/direct/RemotingEvent.js +24 -0
- data/app/assets/javascripts/extjs-rails/src/direct/RemotingMethod.js +100 -0
- data/app/assets/javascripts/extjs-rails/src/direct/RemotingProvider.js +510 -0
- data/app/assets/javascripts/extjs-rails/src/direct/Transaction.js +41 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.alignment.js +378 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.anim.js +962 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.dd.js +40 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.fx.js +194 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.js +1407 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.position.js +501 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.scroll.js +214 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.style.js +792 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Element.traversal.js +8 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Helper.js +466 -0
- data/app/assets/javascripts/extjs-rails/src/dom/Query.js +1067 -0
- data/app/assets/javascripts/extjs-rails/src/draw/Color.js +303 -0
- data/app/assets/javascripts/extjs-rails/src/draw/Component.js +245 -0
- data/app/assets/javascripts/extjs-rails/src/draw/CompositeSprite.js +299 -0
- data/app/assets/javascripts/extjs-rails/src/draw/Draw.js +1217 -0
- data/app/assets/javascripts/extjs-rails/src/draw/Matrix.js +183 -0
- data/app/assets/javascripts/extjs-rails/src/draw/Sprite.js +554 -0
- data/app/assets/javascripts/extjs-rails/src/draw/SpriteDD.js +87 -0
- data/app/assets/javascripts/extjs-rails/src/draw/Surface.js +1001 -0
- data/app/assets/javascripts/extjs-rails/src/draw/Text.js +175 -0
- data/app/assets/javascripts/extjs-rails/src/draw/engine/ImageExporter.js +106 -0
- data/app/assets/javascripts/extjs-rails/src/draw/engine/Svg.js +734 -0
- data/app/assets/javascripts/extjs-rails/src/draw/engine/SvgExporter.js +280 -0
- data/app/assets/javascripts/extjs-rails/src/draw/engine/Vml.js +916 -0
- data/app/assets/javascripts/extjs-rails/src/flash/Component.js +248 -0
- data/app/assets/javascripts/extjs-rails/src/form/Basic.js +1018 -0
- data/app/assets/javascripts/extjs-rails/src/form/CheckboxGroup.js +441 -0
- data/app/assets/javascripts/extjs-rails/src/form/CheckboxManager.js +26 -0
- data/app/assets/javascripts/extjs-rails/src/form/FieldAncestor.js +210 -0
- data/app/assets/javascripts/extjs-rails/src/form/FieldContainer.js +290 -0
- data/app/assets/javascripts/extjs-rails/src/form/FieldSet.js +506 -0
- data/app/assets/javascripts/extjs-rails/src/form/Label.js +110 -0
- data/app/assets/javascripts/extjs-rails/src/form/Labelable.js +764 -0
- data/app/assets/javascripts/extjs-rails/src/form/Panel.js +335 -0
- data/app/assets/javascripts/extjs-rails/src/form/RadioGroup.js +124 -0
- data/app/assets/javascripts/extjs-rails/src/form/RadioManager.js +26 -0
- data/app/assets/javascripts/extjs-rails/src/form/action/Action.js +307 -0
- data/app/assets/javascripts/extjs-rails/src/form/action/DirectLoad.js +107 -0
- data/app/assets/javascripts/extjs-rails/src/form/action/DirectSubmit.js +119 -0
- data/app/assets/javascripts/extjs-rails/src/form/action/Load.js +120 -0
- data/app/assets/javascripts/extjs-rails/src/form/action/StandardSubmit.js +34 -0
- data/app/assets/javascripts/extjs-rails/src/form/action/Submit.js +257 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Base.js +813 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Checkbox.js +505 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/ComboBox.js +1427 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Date.js +578 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Display.js +155 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Field.js +430 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/File.js +265 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Hidden.js +75 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/HtmlEditor.js +1439 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Number.js +380 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Picker.js +321 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Radio.js +279 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Spinner.js +321 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Text.js +727 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/TextArea.js +228 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Time.js +459 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/Trigger.js +469 -0
- data/app/assets/javascripts/extjs-rails/src/form/field/VTypes.js +172 -0
- data/app/assets/javascripts/extjs-rails/src/fx/Anim.js +472 -0
- data/app/assets/javascripts/extjs-rails/src/fx/Animator.js +410 -0
- data/app/assets/javascripts/extjs-rails/src/fx/CubicBezier.js +77 -0
- data/app/assets/javascripts/extjs-rails/src/fx/Easing.js +136 -0
- data/app/assets/javascripts/extjs-rails/src/fx/Manager.js +353 -0
- data/app/assets/javascripts/extjs-rails/src/fx/PropertyHandler.js +381 -0
- data/app/assets/javascripts/extjs-rails/src/fx/Queue.js +123 -0
- data/app/assets/javascripts/extjs-rails/src/fx/target/Component.js +118 -0
- data/app/assets/javascripts/extjs-rails/src/fx/target/CompositeElement.js +46 -0
- data/app/assets/javascripts/extjs-rails/src/fx/target/CompositeElementCSS.js +22 -0
- data/app/assets/javascripts/extjs-rails/src/fx/target/CompositeSprite.js +34 -0
- data/app/assets/javascripts/extjs-rails/src/fx/target/Element.js +83 -0
- data/app/assets/javascripts/extjs-rails/src/fx/target/ElementCSS.js +77 -0
- data/app/assets/javascripts/extjs-rails/src/fx/target/Sprite.js +128 -0
- data/app/assets/javascripts/extjs-rails/src/fx/target/Target.js +36 -0
- data/app/assets/javascripts/extjs-rails/src/grid/CellEditor.js +172 -0
- data/app/assets/javascripts/extjs-rails/src/grid/ColumnComponentLayout.js +34 -0
- data/app/assets/javascripts/extjs-rails/src/grid/ColumnLayout.js +201 -0
- data/app/assets/javascripts/extjs-rails/src/grid/Lockable.js +863 -0
- data/app/assets/javascripts/extjs-rails/src/grid/LockingView.js +169 -0
- data/app/assets/javascripts/extjs-rails/src/grid/PagingScroller.js +539 -0
- data/app/assets/javascripts/extjs-rails/src/grid/Panel.js +393 -0
- data/app/assets/javascripts/extjs-rails/src/grid/RowEditor.js +731 -0
- data/app/assets/javascripts/extjs-rails/src/grid/RowNumberer.js +76 -0
- data/app/assets/javascripts/extjs-rails/src/grid/Scroller.js +5 -0
- data/app/assets/javascripts/extjs-rails/src/grid/View.js +44 -0
- data/app/assets/javascripts/extjs-rails/src/grid/ViewDropZone.js +41 -0
- data/app/assets/javascripts/extjs-rails/src/grid/column/Action.js +318 -0
- data/app/assets/javascripts/extjs-rails/src/grid/column/Boolean.js +82 -0
- data/app/assets/javascripts/extjs-rails/src/grid/column/Column.js +835 -0
- data/app/assets/javascripts/extjs-rails/src/grid/column/Date.js +63 -0
- data/app/assets/javascripts/extjs-rails/src/grid/column/Number.js +52 -0
- data/app/assets/javascripts/extjs-rails/src/grid/column/Template.js +58 -0
- data/app/assets/javascripts/extjs-rails/src/grid/feature/AbstractSummary.js +154 -0
- data/app/assets/javascripts/extjs-rails/src/grid/feature/Chunking.js +77 -0
- data/app/assets/javascripts/extjs-rails/src/grid/feature/Feature.js +158 -0
- data/app/assets/javascripts/extjs-rails/src/grid/feature/Grouping.js +822 -0
- data/app/assets/javascripts/extjs-rails/src/grid/feature/GroupingSummary.js +243 -0
- data/app/assets/javascripts/extjs-rails/src/grid/feature/RowBody.js +116 -0
- data/app/assets/javascripts/extjs-rails/src/grid/feature/RowWrap.js +120 -0
- data/app/assets/javascripts/extjs-rails/src/grid/feature/Summary.js +167 -0
- data/app/assets/javascripts/extjs-rails/src/grid/header/Container.js +965 -0
- data/app/assets/javascripts/extjs-rails/src/grid/header/DragZone.js +69 -0
- data/app/assets/javascripts/extjs-rails/src/grid/header/DropZone.js +265 -0
- data/app/assets/javascripts/extjs-rails/src/grid/plugin/CellEditing.js +453 -0
- data/app/assets/javascripts/extjs-rails/src/grid/plugin/DragDrop.js +254 -0
- data/app/assets/javascripts/extjs-rails/src/grid/plugin/Editing.js +561 -0
- data/app/assets/javascripts/extjs-rails/src/grid/plugin/HeaderReorderer.js +49 -0
- data/app/assets/javascripts/extjs-rails/src/grid/plugin/HeaderResizer.js +292 -0
- data/app/assets/javascripts/extjs-rails/src/grid/plugin/RowEditing.js +339 -0
- data/app/assets/javascripts/extjs-rails/src/grid/property/Grid.js +351 -0
- data/app/assets/javascripts/extjs-rails/src/grid/property/HeaderContainer.js +109 -0
- data/app/assets/javascripts/extjs-rails/src/grid/property/Property.js +36 -0
- data/app/assets/javascripts/extjs-rails/src/grid/property/Store.js +141 -0
- data/app/assets/javascripts/extjs-rails/src/layout/ClassList.js +90 -0
- data/app/assets/javascripts/extjs-rails/src/layout/Context.js +1232 -0
- data/app/assets/javascripts/extjs-rails/src/layout/ContextItem.js +1470 -0
- data/app/assets/javascripts/extjs-rails/src/layout/Layout.js +761 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/Auto.js +220 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/Body.js +80 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/BoundList.js +95 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/Button.js +261 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/Component.js +427 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/Dock.js +1132 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/Draw.js +79 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/FieldSet.js +62 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/ProgressBar.js +54 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/Tab.js +23 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/field/ComboBox.js +52 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/field/Field.js +372 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/field/FieldContainer.js +48 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/field/HtmlEditor.js +54 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/field/Slider.js +58 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/field/Text.js +75 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/field/TextArea.js +51 -0
- data/app/assets/javascripts/extjs-rails/src/layout/component/field/Trigger.js +132 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Absolute.js +121 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Accordion.js +308 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Anchor.js +403 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Auto.js +70 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Border-old-js +1079 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Border.js +816 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Box.js +929 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Card.js +361 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/CheckboxGroup.js +376 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Column.js +234 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Container.js +961 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Editor.js +74 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Fit.js +287 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Form.js +157 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/HBox.js +134 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/Table.js +412 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/VBox.js +139 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/boxOverflow/Menu.js +365 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/boxOverflow/None.js +83 -0
- data/app/assets/javascripts/extjs-rails/src/layout/container/boxOverflow/Scroller.js +475 -0
- data/app/assets/javascripts/extjs-rails/src/menu/CheckItem.js +169 -0
- data/app/assets/javascripts/extjs-rails/src/menu/ColorPicker.js +110 -0
- data/app/assets/javascripts/extjs-rails/src/menu/DatePicker.js +100 -0
- data/app/assets/javascripts/extjs-rails/src/menu/Item.js +553 -0
- data/app/assets/javascripts/extjs-rails/src/menu/KeyNav.js +134 -0
- data/app/assets/javascripts/extjs-rails/src/menu/Manager.js +219 -0
- data/app/assets/javascripts/extjs-rails/src/menu/Menu.js +579 -0
- data/app/assets/javascripts/extjs-rails/src/menu/Separator.js +126 -0
- data/app/assets/javascripts/extjs-rails/src/panel/AbstractPanel.js +323 -0
- data/app/assets/javascripts/extjs-rails/src/panel/DD.js +99 -0
- data/app/assets/javascripts/extjs-rails/src/panel/Header.js +518 -0
- data/app/assets/javascripts/extjs-rails/src/panel/Panel.js +2150 -0
- data/app/assets/javascripts/extjs-rails/src/panel/Proxy.js +131 -0
- data/app/assets/javascripts/extjs-rails/src/panel/Table.js +1018 -0
- data/app/assets/javascripts/extjs-rails/src/panel/Tool.js +304 -0
- data/app/assets/javascripts/extjs-rails/src/picker/Color.js +219 -0
- data/app/assets/javascripts/extjs-rails/src/picker/Date.js +1140 -0
- data/app/assets/javascripts/extjs-rails/src/picker/Month.js +490 -0
- data/app/assets/javascripts/extjs-rails/src/picker/Time.js +165 -0
- data/app/assets/javascripts/extjs-rails/src/resizer/BorderSplitter.js +22 -0
- data/app/assets/javascripts/extjs-rails/src/resizer/BorderSplitterTracker.js +210 -0
- data/app/assets/javascripts/extjs-rails/src/resizer/Handle.js +29 -0
- data/app/assets/javascripts/extjs-rails/src/resizer/ResizeTracker.js +346 -0
- data/app/assets/javascripts/extjs-rails/src/resizer/Resizer.js +477 -0
- data/app/assets/javascripts/extjs-rails/src/resizer/Splitter.js +242 -0
- data/app/assets/javascripts/extjs-rails/src/resizer/SplitterTracker.js +230 -0
- data/app/assets/javascripts/extjs-rails/src/selection/CellModel.js +395 -0
- data/app/assets/javascripts/extjs-rails/src/selection/CheckboxModel.js +234 -0
- data/app/assets/javascripts/extjs-rails/src/selection/DataViewModel.js +160 -0
- data/app/assets/javascripts/extjs-rails/src/selection/Model.js +646 -0
- data/app/assets/javascripts/extjs-rails/src/selection/RowModel.js +499 -0
- data/app/assets/javascripts/extjs-rails/src/selection/TreeModel.js +78 -0
- data/app/assets/javascripts/extjs-rails/src/slider/Multi.js +835 -0
- data/app/assets/javascripts/extjs-rails/src/slider/Single.js +56 -0
- data/app/assets/javascripts/extjs-rails/src/slider/Thumb.js +259 -0
- data/app/assets/javascripts/extjs-rails/src/slider/Tip.js +130 -0
- data/app/assets/javascripts/extjs-rails/src/state/CookieProvider.js +120 -0
- data/app/assets/javascripts/extjs-rails/src/state/LocalStorageProvider.js +72 -0
- data/app/assets/javascripts/extjs-rails/src/state/Manager.js +70 -0
- data/app/assets/javascripts/extjs-rails/src/state/Provider.js +182 -0
- data/app/assets/javascripts/extjs-rails/src/state/Stateful.js +364 -0
- data/app/assets/javascripts/extjs-rails/src/tab/Bar.js +258 -0
- data/app/assets/javascripts/extjs-rails/src/tab/Panel.js +654 -0
- data/app/assets/javascripts/extjs-rails/src/tab/Tab.js +358 -0
- data/app/assets/javascripts/extjs-rails/src/tail.js +10 -0
- data/app/assets/javascripts/extjs-rails/src/tip/QuickTip.js +335 -0
- data/app/assets/javascripts/extjs-rails/src/tip/QuickTipManager.js +239 -0
- data/app/assets/javascripts/extjs-rails/src/tip/Tip.js +160 -0
- data/app/assets/javascripts/extjs-rails/src/tip/ToolTip.js +691 -0
- data/app/assets/javascripts/extjs-rails/src/toolbar/Fill.js +28 -0
- data/app/assets/javascripts/extjs-rails/src/toolbar/Item.js +16 -0
- data/app/assets/javascripts/extjs-rails/src/toolbar/Paging.js +600 -0
- data/app/assets/javascripts/extjs-rails/src/toolbar/Separator.js +23 -0
- data/app/assets/javascripts/extjs-rails/src/toolbar/Spacer.js +33 -0
- data/app/assets/javascripts/extjs-rails/src/toolbar/TextItem.js +57 -0
- data/app/assets/javascripts/extjs-rails/src/toolbar/Toolbar-legacy.js +123 -0
- data/app/assets/javascripts/extjs-rails/src/toolbar/Toolbar.js +447 -0
- data/app/assets/javascripts/extjs-rails/src/tree/Column.js +90 -0
- data/app/assets/javascripts/extjs-rails/src/tree/Panel.js +505 -0
- data/app/assets/javascripts/extjs-rails/src/tree/View.js +658 -0
- data/app/assets/javascripts/extjs-rails/src/tree/ViewDragZone.js +49 -0
- data/app/assets/javascripts/extjs-rails/src/tree/ViewDropZone.js +287 -0
- data/app/assets/javascripts/extjs-rails/src/tree/plugin/TreeViewDragDrop.js +244 -0
- data/app/assets/javascripts/extjs-rails/src/util/AbstractMixedCollection.js +772 -0
- data/app/assets/javascripts/extjs-rails/src/util/Animate.js +426 -0
- data/app/assets/javascripts/extjs-rails/src/util/Bindable.js +102 -0
- data/app/assets/javascripts/extjs-rails/src/util/CSS.js +185 -0
- data/app/assets/javascripts/extjs-rails/src/util/ClickRepeater.js +238 -0
- data/app/assets/javascripts/extjs-rails/src/util/ComponentDragger.js +126 -0
- data/app/assets/javascripts/extjs-rails/src/util/Cookies.js +91 -0
- data/app/assets/javascripts/extjs-rails/src/util/ElementContainer.js +293 -0
- data/app/assets/javascripts/extjs-rails/src/util/Filter.js +159 -0
- data/app/assets/javascripts/extjs-rails/src/util/Floating.js +321 -0
- data/app/assets/javascripts/extjs-rails/src/util/Grouper.js +26 -0
- data/app/assets/javascripts/extjs-rails/src/util/HashMap.js +356 -0
- data/app/assets/javascripts/extjs-rails/src/util/History.js +285 -0
- data/app/assets/javascripts/extjs-rails/src/util/Inflector.js +297 -0
- data/app/assets/javascripts/extjs-rails/src/util/KeyMap.js +427 -0
- data/app/assets/javascripts/extjs-rails/src/util/KeyNav.js +239 -0
- data/app/assets/javascripts/extjs-rails/src/util/LruCache.js +257 -0
- data/app/assets/javascripts/extjs-rails/src/util/Memento.js +131 -0
- data/app/assets/javascripts/extjs-rails/src/util/MixedCollection.js +239 -0
- data/app/assets/javascripts/extjs-rails/src/util/Observable.js +1003 -0
- data/app/assets/javascripts/extjs-rails/src/util/Offset.js +60 -0
- data/app/assets/javascripts/extjs-rails/src/util/Point.js +93 -0
- data/app/assets/javascripts/extjs-rails/src/util/ProtoElement.js +205 -0
- data/app/assets/javascripts/extjs-rails/src/util/Queue.js +76 -0
- data/app/assets/javascripts/extjs-rails/src/util/Region.js +388 -0
- data/app/assets/javascripts/extjs-rails/src/util/Renderable.js +1079 -0
- data/app/assets/javascripts/extjs-rails/src/util/Sortable.js +248 -0
- data/app/assets/javascripts/extjs-rails/src/util/Sorter.js +179 -0
- data/app/assets/javascripts/extjs-rails/src/util/TextMetrics.js +148 -0
- data/app/assets/javascripts/extjs-rails/src/view/AbstractView.js +1103 -0
- data/app/assets/javascripts/extjs-rails/src/view/BoundList.js +207 -0
- data/app/assets/javascripts/extjs-rails/src/view/BoundListKeyNav.js +92 -0
- data/app/assets/javascripts/extjs-rails/src/view/DragZone.js +106 -0
- data/app/assets/javascripts/extjs-rails/src/view/DropZone.js +240 -0
- data/app/assets/javascripts/extjs-rails/src/view/Table.js +1229 -0
- data/app/assets/javascripts/extjs-rails/src/view/TableChunker.js +139 -0
- data/app/assets/javascripts/extjs-rails/src/view/View.js +636 -0
- data/app/assets/javascripts/extjs-rails/src/window/MessageBox.js +880 -0
- data/app/assets/javascripts/extjs-rails/src/window/Window-legacy.js +56 -0
- data/app/assets/javascripts/extjs-rails/src/window/Window.js +793 -0
- data/extjs-rails.gemspec +24 -0
- data/lib/extjs-rails.rb +7 -0
- data/lib/extjs-rails/engine.rb +7 -0
- data/lib/extjs-rails/version.rb +5 -0
- metadata +660 -0
@@ -0,0 +1,361 @@
|
|
1
|
+
/**
|
2
|
+
* This layout manages multiple child Components, each fitted to the Container, where only a single child Component can be
|
3
|
+
* visible at any given time. This layout style is most commonly used for wizards, tab implementations, etc.
|
4
|
+
* This class is intended to be extended or created via the layout:'card' {@link Ext.container.Container#layout} config,
|
5
|
+
* and should generally not need to be created directly via the new keyword.
|
6
|
+
*
|
7
|
+
* The CardLayout's focal method is {@link #setActiveItem}. Since only one panel is displayed at a time,
|
8
|
+
* the only way to move from one Component to the next is by calling setActiveItem, passing the next panel to display
|
9
|
+
* (or its id or index). The layout itself does not provide a user interface for handling this navigation,
|
10
|
+
* so that functionality must be provided by the developer.
|
11
|
+
*
|
12
|
+
* To change the active card of a container, call the setActiveItem method of its layout:
|
13
|
+
*
|
14
|
+
* Ext.create('Ext.panel.Panel', {
|
15
|
+
* layout: 'card',
|
16
|
+
* items: [
|
17
|
+
* { html: 'Card 1' },
|
18
|
+
* { html: 'Card 2' }
|
19
|
+
* ],
|
20
|
+
* renderTo: Ext.getBody()
|
21
|
+
* });
|
22
|
+
*
|
23
|
+
* p.getLayout().setActiveItem(1);
|
24
|
+
*
|
25
|
+
* In the following example, a simplistic wizard setup is demonstrated. A button bar is added
|
26
|
+
* to the footer of the containing panel to provide navigation buttons. The buttons will be handled by a
|
27
|
+
* common navigation routine. Note that other uses of a CardLayout (like a tab control) would require a
|
28
|
+
* completely different implementation. For serious implementations, a better approach would be to extend
|
29
|
+
* CardLayout to provide the custom functionality needed.
|
30
|
+
*
|
31
|
+
* @example
|
32
|
+
* var navigate = function(panel, direction){
|
33
|
+
* // This routine could contain business logic required to manage the navigation steps.
|
34
|
+
* // It would call setActiveItem as needed, manage navigation button state, handle any
|
35
|
+
* // branching logic that might be required, handle alternate actions like cancellation
|
36
|
+
* // or finalization, etc. A complete wizard implementation could get pretty
|
37
|
+
* // sophisticated depending on the complexity required, and should probably be
|
38
|
+
* // done as a subclass of CardLayout in a real-world implementation.
|
39
|
+
* var layout = panel.getLayout();
|
40
|
+
* layout[direction]();
|
41
|
+
* Ext.getCmp('move-prev').setDisabled(!layout.getPrev());
|
42
|
+
* Ext.getCmp('move-next').setDisabled(!layout.getNext());
|
43
|
+
* };
|
44
|
+
*
|
45
|
+
* Ext.create('Ext.panel.Panel', {
|
46
|
+
* title: 'Example Wizard',
|
47
|
+
* width: 300,
|
48
|
+
* height: 200,
|
49
|
+
* layout: 'card',
|
50
|
+
* bodyStyle: 'padding:15px',
|
51
|
+
* defaults: {
|
52
|
+
* // applied to each contained panel
|
53
|
+
* border: false
|
54
|
+
* },
|
55
|
+
* // just an example of one possible navigation scheme, using buttons
|
56
|
+
* bbar: [
|
57
|
+
* {
|
58
|
+
* id: 'move-prev',
|
59
|
+
* text: 'Back',
|
60
|
+
* handler: function(btn) {
|
61
|
+
* navigate(btn.up("panel"), "prev");
|
62
|
+
* },
|
63
|
+
* disabled: true
|
64
|
+
* },
|
65
|
+
* '->', // greedy spacer so that the buttons are aligned to each side
|
66
|
+
* {
|
67
|
+
* id: 'move-next',
|
68
|
+
* text: 'Next',
|
69
|
+
* handler: function(btn) {
|
70
|
+
* navigate(btn.up("panel"), "next");
|
71
|
+
* }
|
72
|
+
* }
|
73
|
+
* ],
|
74
|
+
* // the panels (or "cards") within the layout
|
75
|
+
* items: [{
|
76
|
+
* id: 'card-0',
|
77
|
+
* html: '<h1>Welcome to the Wizard!</h1><p>Step 1 of 3</p>'
|
78
|
+
* },{
|
79
|
+
* id: 'card-1',
|
80
|
+
* html: '<p>Step 2 of 3</p>'
|
81
|
+
* },{
|
82
|
+
* id: 'card-2',
|
83
|
+
* html: '<h1>Congratulations!</h1><p>Step 3 of 3 - Complete</p>'
|
84
|
+
* }],
|
85
|
+
* renderTo: Ext.getBody()
|
86
|
+
* });
|
87
|
+
*/
|
88
|
+
Ext.define('Ext.layout.container.Card', {
|
89
|
+
|
90
|
+
/* Begin Definitions */
|
91
|
+
|
92
|
+
extend: 'Ext.layout.container.Fit',
|
93
|
+
|
94
|
+
alternateClassName: 'Ext.layout.CardLayout',
|
95
|
+
|
96
|
+
alias: 'layout.card',
|
97
|
+
|
98
|
+
/* End Definitions */
|
99
|
+
|
100
|
+
type: 'card',
|
101
|
+
|
102
|
+
hideInactive: true,
|
103
|
+
|
104
|
+
/**
|
105
|
+
* @cfg {Boolean} deferredRender
|
106
|
+
* True to render each contained item at the time it becomes active, false to render all contained items
|
107
|
+
* as soon as the layout is rendered (defaults to false). If there is a significant amount of content or
|
108
|
+
* a lot of heavy controls being rendered into panels that are not displayed by default, setting this to
|
109
|
+
* true might improve performance.
|
110
|
+
*/
|
111
|
+
deferredRender : false,
|
112
|
+
|
113
|
+
getRenderTree: function () {
|
114
|
+
var me = this,
|
115
|
+
activeItem = me.getActiveItem();
|
116
|
+
|
117
|
+
if (activeItem) {
|
118
|
+
|
119
|
+
// If they veto the activate, we have no active item
|
120
|
+
if (activeItem.hasListeners.beforeactivate && activeItem.fireEvent('beforeactivate', activeItem) === false) {
|
121
|
+
|
122
|
+
// We must null our activeItem reference, AND the one in our owning Container.
|
123
|
+
// Because upon layout invalidation, renderChildren will use this.getActiveItem which
|
124
|
+
// uses this.activeItem || this.owner.activeItem
|
125
|
+
activeItem = me.activeItem = me.owner.activeItem = null;
|
126
|
+
}
|
127
|
+
|
128
|
+
// Item is to be the active one. Fire event after it is first layed out
|
129
|
+
else if (activeItem.hasListeners.activate) {
|
130
|
+
activeItem.on({
|
131
|
+
boxready: function() {
|
132
|
+
activeItem.fireEvent('activate', activeItem);
|
133
|
+
},
|
134
|
+
single: true
|
135
|
+
});
|
136
|
+
}
|
137
|
+
|
138
|
+
if (me.deferredRender) {
|
139
|
+
if (activeItem) {
|
140
|
+
return me.getItemsRenderTree([activeItem]);
|
141
|
+
}
|
142
|
+
} else {
|
143
|
+
return me.callParent(arguments);
|
144
|
+
}
|
145
|
+
}
|
146
|
+
},
|
147
|
+
|
148
|
+
renderChildren: function () {
|
149
|
+
var me = this,
|
150
|
+
active = me.getActiveItem();
|
151
|
+
|
152
|
+
if (!me.deferredRender) {
|
153
|
+
me.callParent();
|
154
|
+
} else if (active) {
|
155
|
+
// ensure the active item is configured for the layout
|
156
|
+
me.renderItems([active], me.getRenderTarget());
|
157
|
+
}
|
158
|
+
},
|
159
|
+
|
160
|
+
isValidParent : function(item, target, position) {
|
161
|
+
// Note: Card layout does not care about order within the target because only one is ever visible.
|
162
|
+
// We only care whether the item is a direct child of the target.
|
163
|
+
var itemEl = item.el ? item.el.dom : Ext.getDom(item);
|
164
|
+
return (itemEl && itemEl.parentNode === (target.dom || target)) || false;
|
165
|
+
},
|
166
|
+
|
167
|
+
/**
|
168
|
+
* Return the active (visible) component in the layout.
|
169
|
+
* @returns {Ext.Component}
|
170
|
+
*/
|
171
|
+
getActiveItem: function() {
|
172
|
+
var me = this,
|
173
|
+
// Ensure the calculated result references a Component
|
174
|
+
result = me.parseActiveItem(me.activeItem || (me.owner && me.owner.activeItem));
|
175
|
+
|
176
|
+
// Sanitize the result in case the active item is no longer there.
|
177
|
+
if (result && me.owner.items.indexOf(result) != -1) {
|
178
|
+
me.activeItem = result;
|
179
|
+
} else {
|
180
|
+
me.activeItem = null;
|
181
|
+
}
|
182
|
+
|
183
|
+
return me.activeItem;
|
184
|
+
},
|
185
|
+
|
186
|
+
// @private
|
187
|
+
parseActiveItem: function(item) {
|
188
|
+
if (item && item.isComponent) {
|
189
|
+
return item;
|
190
|
+
} else if (typeof item == 'number' || item === undefined) {
|
191
|
+
return this.getLayoutItems()[item || 0];
|
192
|
+
} else {
|
193
|
+
return this.owner.getComponent(item);
|
194
|
+
}
|
195
|
+
},
|
196
|
+
|
197
|
+
// @private. Called before both dynamic render, and bulk render.
|
198
|
+
// Ensure that the active item starts visible, and inactive ones start invisible
|
199
|
+
configureItem: function(item) {
|
200
|
+
if (item === this.getActiveItem()) {
|
201
|
+
item.hidden = false;
|
202
|
+
} else {
|
203
|
+
item.hidden = true;
|
204
|
+
}
|
205
|
+
this.callParent(arguments);
|
206
|
+
},
|
207
|
+
|
208
|
+
onRemove: function(component) {
|
209
|
+
var me = this;
|
210
|
+
|
211
|
+
if (component === me.activeItem) {
|
212
|
+
me.activeItem = null;
|
213
|
+
}
|
214
|
+
},
|
215
|
+
|
216
|
+
// @private
|
217
|
+
getAnimation: function(newCard, owner) {
|
218
|
+
var newAnim = (newCard || {}).cardSwitchAnimation;
|
219
|
+
if (newAnim === false) {
|
220
|
+
return false;
|
221
|
+
}
|
222
|
+
return newAnim || owner.cardSwitchAnimation;
|
223
|
+
},
|
224
|
+
|
225
|
+
/**
|
226
|
+
* Return the active (visible) component in the layout to the next card
|
227
|
+
* @returns {Ext.Component} The next component or false.
|
228
|
+
*/
|
229
|
+
getNext: function() {
|
230
|
+
//NOTE: Removed the JSDoc for this function's arguments because it is not actually supported in 4.0. This
|
231
|
+
//should come back in 4.1
|
232
|
+
var wrap = arguments[0],
|
233
|
+
items = this.getLayoutItems(),
|
234
|
+
index = Ext.Array.indexOf(items, this.activeItem);
|
235
|
+
|
236
|
+
return items[index + 1] || (wrap ? items[0] : false);
|
237
|
+
},
|
238
|
+
|
239
|
+
/**
|
240
|
+
* Sets the active (visible) component in the layout to the next card
|
241
|
+
* @return {Ext.Component} the activated component or false when nothing activated.
|
242
|
+
*/
|
243
|
+
next: function() {
|
244
|
+
//NOTE: Removed the JSDoc for this function's arguments because it is not actually supported in 4.0. This
|
245
|
+
//should come back in 4.1
|
246
|
+
var anim = arguments[0],
|
247
|
+
wrap = arguments[1];
|
248
|
+
return this.setActiveItem(this.getNext(wrap), anim);
|
249
|
+
},
|
250
|
+
|
251
|
+
/**
|
252
|
+
* Return the active (visible) component in the layout to the previous card
|
253
|
+
* @returns {Ext.Component} The previous component or false.
|
254
|
+
*/
|
255
|
+
getPrev: function() {
|
256
|
+
//NOTE: Removed the JSDoc for this function's arguments because it is not actually supported in 4.0. This
|
257
|
+
//should come back in 4.1
|
258
|
+
var wrap = arguments[0],
|
259
|
+
items = this.getLayoutItems(),
|
260
|
+
index = Ext.Array.indexOf(items, this.activeItem);
|
261
|
+
|
262
|
+
return items[index - 1] || (wrap ? items[items.length - 1] : false);
|
263
|
+
},
|
264
|
+
|
265
|
+
/**
|
266
|
+
* Sets the active (visible) component in the layout to the previous card
|
267
|
+
* @return {Ext.Component} the activated component or false when nothing activated.
|
268
|
+
*/
|
269
|
+
prev: function() {
|
270
|
+
//NOTE: Removed the JSDoc for this function's arguments because it is not actually supported in 4.0. This
|
271
|
+
//should come back in 4.1
|
272
|
+
var anim = arguments[0],
|
273
|
+
wrap = arguments[1];
|
274
|
+
return this.setActiveItem(this.getPrev(wrap), anim);
|
275
|
+
},
|
276
|
+
|
277
|
+
/**
|
278
|
+
* Makes the given card active.
|
279
|
+
*
|
280
|
+
* var card1 = Ext.create('Ext.panel.Panel', {itemId: 'card-1'});
|
281
|
+
* var card2 = Ext.create('Ext.panel.Panel', {itemId: 'card-2'});
|
282
|
+
* var panel = Ext.create('Ext.panel.Panel', {
|
283
|
+
* layout: 'card',
|
284
|
+
* activeItem: 0,
|
285
|
+
* items: [card1, card2]
|
286
|
+
* });
|
287
|
+
* // These are all equivalent
|
288
|
+
* panel.getLayout().setActiveItem(card2);
|
289
|
+
* panel.getLayout().setActiveItem('card-2');
|
290
|
+
* panel.getLayout().setActiveItem(1);
|
291
|
+
*
|
292
|
+
* @param {Ext.Component/Number/String} newCard The component, component {@link Ext.Component#id id},
|
293
|
+
* {@link Ext.Component#itemId itemId}, or index of component.
|
294
|
+
* @return {Ext.Component} the activated component or false when nothing activated.
|
295
|
+
* False is returned also when trying to activate an already active card.
|
296
|
+
*/
|
297
|
+
setActiveItem: function(newCard) {
|
298
|
+
var me = this,
|
299
|
+
owner = me.owner,
|
300
|
+
oldCard = me.activeItem,
|
301
|
+
rendered = owner.rendered,
|
302
|
+
newIndex;
|
303
|
+
|
304
|
+
newCard = me.parseActiveItem(newCard);
|
305
|
+
newIndex = owner.items.indexOf(newCard);
|
306
|
+
|
307
|
+
// If the card is not a child of the owner, then add it.
|
308
|
+
// Without doing a layout!
|
309
|
+
if (newIndex == -1) {
|
310
|
+
newIndex = owner.items.items.length;
|
311
|
+
Ext.suspendLayouts();
|
312
|
+
newCard = owner.add(newCard);
|
313
|
+
Ext.resumeLayouts();
|
314
|
+
}
|
315
|
+
|
316
|
+
// Is this a valid, different card?
|
317
|
+
if (newCard && oldCard != newCard) {
|
318
|
+
// Fire the beforeactivate and beforedeactivate events on the cards
|
319
|
+
if (newCard.fireEvent('beforeactivate', newCard, oldCard) === false) {
|
320
|
+
return false;
|
321
|
+
}
|
322
|
+
if (oldCard && oldCard.fireEvent('beforedeactivate', oldCard, newCard) === false) {
|
323
|
+
return false;
|
324
|
+
}
|
325
|
+
|
326
|
+
if (rendered) {
|
327
|
+
Ext.suspendLayouts();
|
328
|
+
|
329
|
+
// If the card has not been rendered yet, now is the time to do so.
|
330
|
+
if (!newCard.rendered) {
|
331
|
+
me.renderItem(newCard, me.getRenderTarget(), owner.items.length);
|
332
|
+
}
|
333
|
+
|
334
|
+
if (oldCard) {
|
335
|
+
if (me.hideInactive) {
|
336
|
+
oldCard.hide();
|
337
|
+
oldCard.hiddenByLayout = true;
|
338
|
+
}
|
339
|
+
oldCard.fireEvent('deactivate', oldCard, newCard);
|
340
|
+
}
|
341
|
+
// Make sure the new card is shown
|
342
|
+
if (newCard.hidden) {
|
343
|
+
newCard.show();
|
344
|
+
}
|
345
|
+
|
346
|
+
// Layout needs activeItem to be correct, so set it if the show has not been vetoed
|
347
|
+
if (!newCard.hidden) {
|
348
|
+
me.activeItem = newCard;
|
349
|
+
}
|
350
|
+
Ext.resumeLayouts(true);
|
351
|
+
} else {
|
352
|
+
me.activeItem = newCard;
|
353
|
+
}
|
354
|
+
|
355
|
+
newCard.fireEvent('activate', newCard, oldCard);
|
356
|
+
|
357
|
+
return me.activeItem;
|
358
|
+
}
|
359
|
+
return false;
|
360
|
+
}
|
361
|
+
});
|
@@ -0,0 +1,376 @@
|
|
1
|
+
/**
|
2
|
+
* This layout implements the column arrangement for {@link Ext.form.CheckboxGroup} and {@link Ext.form.RadioGroup}.
|
3
|
+
* It groups the component's sub-items into columns based on the component's
|
4
|
+
* {@link Ext.form.CheckboxGroup#columns columns} and {@link Ext.form.CheckboxGroup#vertical} config properties.
|
5
|
+
*/
|
6
|
+
Ext.define('Ext.layout.container.CheckboxGroup', {
|
7
|
+
extend: 'Ext.layout.container.Container',
|
8
|
+
alias: ['layout.checkboxgroup'],
|
9
|
+
|
10
|
+
/**
|
11
|
+
* @cfg {Boolean} [autoFlex=true]
|
12
|
+
* By default, CheckboxGroup allocates all available space to the configured columns meaning that
|
13
|
+
* column are evenly spaced across the container.
|
14
|
+
*
|
15
|
+
* To have each column only be wide enough to fit the container Checkboxes (or Radios), set `autoFlex` to `false`
|
16
|
+
*/
|
17
|
+
autoFlex: true,
|
18
|
+
|
19
|
+
type: 'checkboxgroup',
|
20
|
+
|
21
|
+
childEls: [
|
22
|
+
'innerCt'
|
23
|
+
],
|
24
|
+
|
25
|
+
renderTpl: [
|
26
|
+
'<table id="{ownerId}-innerCt" role="presentation" style="{tableStyle}"><tbody><tr>',
|
27
|
+
'<tpl for="columns">',
|
28
|
+
'<td class="{parent.colCls}" valign="top" style="{style}">',
|
29
|
+
'{% this.renderColumn(out,parent,xindex-1) %}',
|
30
|
+
'</td>',
|
31
|
+
'</tpl>',
|
32
|
+
'</tr></tbody></table>'
|
33
|
+
],
|
34
|
+
|
35
|
+
beginLayout: function(ownerContext) {
|
36
|
+
var me = this,
|
37
|
+
columns,
|
38
|
+
numCols, numChildren,
|
39
|
+
childItems,
|
40
|
+
i, width, cwidth,
|
41
|
+
totalFlex = 0, flexedCols = 0,
|
42
|
+
autoFlex = me.autoFlex,
|
43
|
+
currGen = me.owner.items.generation,
|
44
|
+
innerCtStyle = me.innerCt.dom.style;
|
45
|
+
|
46
|
+
me.callParent(arguments);
|
47
|
+
childItems = ownerContext.childItems;
|
48
|
+
|
49
|
+
// If the child items have changed since the last layout then we need to fixup
|
50
|
+
// the association of items to columns:
|
51
|
+
if (me.lastChildGeneration != currGen) {
|
52
|
+
me.lastChildGeneration = currGen;
|
53
|
+
me.fixColumns();
|
54
|
+
}
|
55
|
+
|
56
|
+
// fixColumns may have updated the element cache, no need to get the columnEls
|
57
|
+
// now...
|
58
|
+
columns = me.columnEls;
|
59
|
+
|
60
|
+
ownerContext.innerCtContext = ownerContext.getEl('innerCt', me);
|
61
|
+
|
62
|
+
// The columns config may be an array of widths. Any value < 1 is taken to be a fraction:
|
63
|
+
if (!ownerContext.widthModel.shrinkWrap) {
|
64
|
+
numCols = columns.length;
|
65
|
+
|
66
|
+
// If columns is an array of numeric widths
|
67
|
+
if (me.columnsArray) {
|
68
|
+
|
69
|
+
// first calculate total flex
|
70
|
+
for (i = 0; i < numCols; i++) {
|
71
|
+
width = me.owner.columns[i];
|
72
|
+
if (width < 1) {
|
73
|
+
totalFlex += width;
|
74
|
+
flexedCols++;
|
75
|
+
}
|
76
|
+
}
|
77
|
+
|
78
|
+
// now apply widths
|
79
|
+
for (i = 0; i < numCols; i++) {
|
80
|
+
width = me.owner.columns[i];
|
81
|
+
if (width < 1) {
|
82
|
+
cwidth = ((width / totalFlex) * 100) + '%';
|
83
|
+
} else {
|
84
|
+
cwidth = width + 'px';
|
85
|
+
}
|
86
|
+
columns[i].style.width = cwidth;
|
87
|
+
}
|
88
|
+
}
|
89
|
+
|
90
|
+
// Otherwise it's the *number* of columns, so distributed the widths evenly
|
91
|
+
else {
|
92
|
+
for (i = 0; i < numCols; i++) {
|
93
|
+
// autoFlex: true will automatically calculate % widths
|
94
|
+
// autoFlex: false allows the table to decide (shrinkWrap, in effect)
|
95
|
+
// on a per-column basis
|
96
|
+
cwidth = autoFlex
|
97
|
+
? (1 / numCols * 100) + '%'
|
98
|
+
: '';
|
99
|
+
columns[i].style.width = cwidth;
|
100
|
+
flexedCols++;
|
101
|
+
}
|
102
|
+
}
|
103
|
+
|
104
|
+
// no flexed cols -- all widths are fixed
|
105
|
+
if (!flexedCols) {
|
106
|
+
innerCtStyle.tableLayout = 'fixed';
|
107
|
+
innerCtStyle.width = '';
|
108
|
+
// some flexed cols -- need to fix some
|
109
|
+
} else if (flexedCols < numCols) {
|
110
|
+
innerCtStyle.tableLayout = 'fixed';
|
111
|
+
innerCtStyle.width = '100%';
|
112
|
+
// let the table decide
|
113
|
+
} else {
|
114
|
+
innerCtStyle.tableLayout = 'auto';
|
115
|
+
// if autoFlex, fill available space, else compact down
|
116
|
+
if (autoFlex) {
|
117
|
+
innerCtStyle.width = '100%';
|
118
|
+
} else {
|
119
|
+
innerCtStyle.width = '';
|
120
|
+
}
|
121
|
+
}
|
122
|
+
|
123
|
+
} else {
|
124
|
+
innerCtStyle.tableLayout = 'auto';
|
125
|
+
innerCtStyle.width = '';
|
126
|
+
}
|
127
|
+
},
|
128
|
+
|
129
|
+
cacheElements: function () {
|
130
|
+
var me = this;
|
131
|
+
|
132
|
+
// Grab defined childEls
|
133
|
+
me.callParent();
|
134
|
+
|
135
|
+
// Grab columns TDs
|
136
|
+
me.columnEls = me.innerCt.query('td.' + me.owner.groupCls);
|
137
|
+
|
138
|
+
// we just rendered so the items are in the correct columns:
|
139
|
+
me.lastChildGeneration = me.owner.items.generation;
|
140
|
+
},
|
141
|
+
|
142
|
+
/*
|
143
|
+
* Just wait for the child items to all lay themselves out in the width we are configured
|
144
|
+
* to make available to them. Then we can measure our height.
|
145
|
+
*/
|
146
|
+
calculate: function(ownerContext) {
|
147
|
+
var me = this,
|
148
|
+
targetContext, widthShrinkWrap, heightShrinkWrap, shrinkWrap, table, targetPadding;
|
149
|
+
|
150
|
+
// The columnEls are widthed using their own width attributes, we just need to wait
|
151
|
+
// for all children to have arranged themselves in that width, and then collect our height.
|
152
|
+
if (!ownerContext.getDomProp('containerChildrenDone')) {
|
153
|
+
me.done = false;
|
154
|
+
} else {
|
155
|
+
targetContext = ownerContext.innerCtContext;
|
156
|
+
widthShrinkWrap = ownerContext.widthModel.shrinkWrap;
|
157
|
+
heightShrinkWrap = ownerContext.heightModel.shrinkWrap;
|
158
|
+
shrinkWrap = heightShrinkWrap || widthShrinkWrap;
|
159
|
+
table = targetContext.el.dom;
|
160
|
+
targetPadding = shrinkWrap && targetContext.getPaddingInfo();
|
161
|
+
|
162
|
+
if (widthShrinkWrap) {
|
163
|
+
ownerContext.setContentWidth(table.offsetWidth + targetPadding.width, true);
|
164
|
+
}
|
165
|
+
|
166
|
+
if (heightShrinkWrap) {
|
167
|
+
ownerContext.setContentHeight(table.offsetHeight + targetPadding.height, true);
|
168
|
+
}
|
169
|
+
}
|
170
|
+
},
|
171
|
+
|
172
|
+
doRenderColumn: function (out, renderData, columnIndex) {
|
173
|
+
// Careful! This method is bolted on to the renderTpl so all we get for context is
|
174
|
+
// the renderData! The "this" pointer is the renderTpl instance!
|
175
|
+
|
176
|
+
var me = renderData.$layout,
|
177
|
+
owner = me.owner,
|
178
|
+
columnCount = renderData.columnCount,
|
179
|
+
items = owner.items.items,
|
180
|
+
itemCount = items.length,
|
181
|
+
item, itemIndex, rowCount, increment, tree;
|
182
|
+
|
183
|
+
// Example:
|
184
|
+
// columnCount = 3
|
185
|
+
// items.length = 10
|
186
|
+
|
187
|
+
if (owner.vertical) {
|
188
|
+
// 0 1 2
|
189
|
+
// +---+---+---+
|
190
|
+
// 0 | 0 | 4 | 8 |
|
191
|
+
// +---+---+---+
|
192
|
+
// 1 | 1 | 5 | 9 |
|
193
|
+
// +---+---+---+
|
194
|
+
// 2 | 2 | 6 | |
|
195
|
+
// +---+---+---+
|
196
|
+
// 3 | 3 | 7 | |
|
197
|
+
// +---+---+---+
|
198
|
+
|
199
|
+
rowCount = Math.ceil(itemCount / columnCount); // = 4
|
200
|
+
itemIndex = columnIndex * rowCount;
|
201
|
+
itemCount = Math.min(itemCount, itemIndex + rowCount);
|
202
|
+
increment = 1;
|
203
|
+
} else {
|
204
|
+
// 0 1 2
|
205
|
+
// +---+---+---+
|
206
|
+
// 0 | 0 | 1 | 2 |
|
207
|
+
// +---+---+---+
|
208
|
+
// 1 | 3 | 4 | 5 |
|
209
|
+
// +---+---+---+
|
210
|
+
// 2 | 6 | 7 | 8 |
|
211
|
+
// +---+---+---+
|
212
|
+
// 3 | 9 | | |
|
213
|
+
// +---+---+---+
|
214
|
+
|
215
|
+
itemIndex = columnIndex;
|
216
|
+
increment = columnCount;
|
217
|
+
}
|
218
|
+
|
219
|
+
for ( ; itemIndex < itemCount; itemIndex += increment) {
|
220
|
+
item = items[itemIndex];
|
221
|
+
me.configureItem(item);
|
222
|
+
tree = item.getRenderTree();
|
223
|
+
Ext.DomHelper.generateMarkup(tree, out);
|
224
|
+
}
|
225
|
+
},
|
226
|
+
|
227
|
+
// Distribute child items between column elements according to row first or
|
228
|
+
// column first order
|
229
|
+
fixColumns: function () {
|
230
|
+
var me = this,
|
231
|
+
owner = me.owner,
|
232
|
+
cfgCols = owner.columns,
|
233
|
+
columns = me.columnEls,
|
234
|
+
items = owner.items.items,
|
235
|
+
columnCount = columns.length,
|
236
|
+
itemCount = items.length,
|
237
|
+
columnIndex, i, rowCount, tr, td, newCount;
|
238
|
+
|
239
|
+
// if running in 'auto' columns mode, and the number of items has increased (add call)
|
240
|
+
// then we need to add a new td to the table
|
241
|
+
if ((!cfgCols || cfgCols == 'auto') && (itemCount > columnCount)) {
|
242
|
+
|
243
|
+
// add column td's for each new item added
|
244
|
+
newCount = itemCount - columnCount;
|
245
|
+
for (i = 0; i < newCount; i++) {
|
246
|
+
tr = me.innerCt.down('tr');
|
247
|
+
tr.createChild({
|
248
|
+
cls: owner.groupCls,
|
249
|
+
tag: 'td',
|
250
|
+
vAlign: 'top'
|
251
|
+
});
|
252
|
+
}
|
253
|
+
me.cacheElements();
|
254
|
+
columns = me.columnEls;
|
255
|
+
columnCount = columns.length;
|
256
|
+
}
|
257
|
+
|
258
|
+
if (owner.vertical) {
|
259
|
+
columnIndex = -1; // first loop will increment this to 0
|
260
|
+
rowCount = Math.ceil(itemCount / columnCount);
|
261
|
+
|
262
|
+
for (i = 0; i < itemCount; ++i) {
|
263
|
+
if (i % rowCount === 0) {
|
264
|
+
++columnIndex;
|
265
|
+
}
|
266
|
+
columns[columnIndex].appendChild(items[i].el.dom);
|
267
|
+
}
|
268
|
+
} else {
|
269
|
+
for (i = 0; i < itemCount; ++i) {
|
270
|
+
columnIndex = i % columnCount;
|
271
|
+
columns[columnIndex].appendChild(items[i].el.dom);
|
272
|
+
}
|
273
|
+
}
|
274
|
+
},
|
275
|
+
|
276
|
+
/**
|
277
|
+
* Returns the number of columns in the checkbox group.
|
278
|
+
* @private
|
279
|
+
*/
|
280
|
+
getColumnCount: function() {
|
281
|
+
var me = this,
|
282
|
+
owner = me.owner,
|
283
|
+
ownerColumns = owner.columns;
|
284
|
+
|
285
|
+
// Our columns config is an array of numeric widths.
|
286
|
+
// Calculate our total width
|
287
|
+
if (me.columnsArray) {
|
288
|
+
return ownerColumns.length;
|
289
|
+
}
|
290
|
+
|
291
|
+
if (Ext.isNumber(ownerColumns)) {
|
292
|
+
return ownerColumns;
|
293
|
+
}
|
294
|
+
return owner.items.length;
|
295
|
+
},
|
296
|
+
|
297
|
+
getItemSizePolicy: function (item) {
|
298
|
+
return this.autoSizePolicy;
|
299
|
+
},
|
300
|
+
|
301
|
+
getRenderData: function () {
|
302
|
+
var me = this,
|
303
|
+
data = me.callParent(),
|
304
|
+
owner = me.owner,
|
305
|
+
i, columns = me.getColumnCount(),
|
306
|
+
width, column, cwidth,
|
307
|
+
autoFlex = me.autoFlex,
|
308
|
+
totalFlex = 0, flexedCols = 0;
|
309
|
+
|
310
|
+
// calculate total flex
|
311
|
+
if (me.columnsArray) {
|
312
|
+
for (i=0; i < columns; i++) {
|
313
|
+
width = me.owner.columns[i];
|
314
|
+
if (width < 1) {
|
315
|
+
totalFlex += width;
|
316
|
+
flexedCols++;
|
317
|
+
}
|
318
|
+
}
|
319
|
+
}
|
320
|
+
|
321
|
+
data.colCls = owner.groupCls;
|
322
|
+
data.columnCount = columns;
|
323
|
+
|
324
|
+
data.columns = [];
|
325
|
+
for (i = 0; i < columns; i++) {
|
326
|
+
column = (data.columns[i] = {});
|
327
|
+
|
328
|
+
if (me.columnsArray) {
|
329
|
+
width = me.owner.columns[i];
|
330
|
+
if (width < 1) {
|
331
|
+
cwidth = ((width / totalFlex) * 100) + '%';
|
332
|
+
} else {
|
333
|
+
cwidth = width + 'px';
|
334
|
+
}
|
335
|
+
column.style = 'width:' + cwidth;
|
336
|
+
} else {
|
337
|
+
column.style = 'width:' + (1 / columns * 100) + '%';
|
338
|
+
flexedCols++;
|
339
|
+
}
|
340
|
+
}
|
341
|
+
|
342
|
+
// If the columns config was an array of column widths, allow table to auto width
|
343
|
+
data.tableStyle =
|
344
|
+
!flexedCols ? 'table-layout:fixed;' :
|
345
|
+
(flexedCols < columns) ? 'table-layout:fixed;width:100%' :
|
346
|
+
(autoFlex) ? 'table-layout:auto;width:100%' : 'table-layout:auto;';
|
347
|
+
|
348
|
+
return data;
|
349
|
+
},
|
350
|
+
|
351
|
+
// Overridden method from AbstractContainer.
|
352
|
+
getRenderTarget: function() {
|
353
|
+
return this.innerCt;
|
354
|
+
},
|
355
|
+
|
356
|
+
initLayout: function () {
|
357
|
+
var me = this,
|
358
|
+
owner = me.owner;
|
359
|
+
|
360
|
+
me.columnsArray = Ext.isArray(owner.columns);
|
361
|
+
me.evenColumns = Ext.isNumber(owner.columns);
|
362
|
+
|
363
|
+
me.callParent();
|
364
|
+
},
|
365
|
+
|
366
|
+
// Always valid. beginLayout ensures the encapsulating elements of all children are in the correct place
|
367
|
+
isValidParent: function() {
|
368
|
+
return true;
|
369
|
+
},
|
370
|
+
|
371
|
+
setupRenderTpl: function (renderTpl) {
|
372
|
+
this.callParent(arguments);
|
373
|
+
|
374
|
+
renderTpl.renderColumn = this.doRenderColumn;
|
375
|
+
}
|
376
|
+
});
|