extjs-rails 4.1.0.alpha1
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.
- 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,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Private utility class that manages the internal Shadow cache.
|
|
3
|
+
* @private
|
|
4
|
+
*/
|
|
5
|
+
Ext.define('Ext.ShadowPool', {
|
|
6
|
+
singleton: true,
|
|
7
|
+
requires: ['Ext.DomHelper'],
|
|
8
|
+
|
|
9
|
+
markup: (function() {
|
|
10
|
+
return Ext.String.format(
|
|
11
|
+
'<div class="{0}{1}-shadow" role="presentation"></div>',
|
|
12
|
+
Ext.baseCSSPrefix,
|
|
13
|
+
Ext.isIE && !Ext.supports.CSS3BoxShadow ? 'ie' : 'css'
|
|
14
|
+
);
|
|
15
|
+
}()),
|
|
16
|
+
|
|
17
|
+
shadows: [],
|
|
18
|
+
|
|
19
|
+
pull: function() {
|
|
20
|
+
var sh = this.shadows.shift();
|
|
21
|
+
if (!sh) {
|
|
22
|
+
sh = Ext.get(Ext.DomHelper.insertHtml("beforeBegin", document.body.firstChild, this.markup));
|
|
23
|
+
sh.autoBoxAdjust = false;
|
|
24
|
+
}
|
|
25
|
+
return sh;
|
|
26
|
+
},
|
|
27
|
+
|
|
28
|
+
push: function(sh) {
|
|
29
|
+
this.shadows.push(sh);
|
|
30
|
+
},
|
|
31
|
+
|
|
32
|
+
reset: function() {
|
|
33
|
+
var shadows = [].concat(this.shadows),
|
|
34
|
+
s,
|
|
35
|
+
sLen = shadows.length;
|
|
36
|
+
|
|
37
|
+
for (s = 0; s < sLen; s++) {
|
|
38
|
+
shadows[s].remove();
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
this.shadows = [];
|
|
42
|
+
}
|
|
43
|
+
});
|
|
@@ -0,0 +1,331 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Represents an HTML fragment template. Templates may be {@link #compile precompiled} for greater performance.
|
|
3
|
+
*
|
|
4
|
+
* An instance of this class may be created by passing to the constructor either a single argument, or multiple
|
|
5
|
+
* arguments:
|
|
6
|
+
*
|
|
7
|
+
* # Single argument: String/Array
|
|
8
|
+
*
|
|
9
|
+
* The single argument may be either a String or an Array:
|
|
10
|
+
*
|
|
11
|
+
* - String:
|
|
12
|
+
*
|
|
13
|
+
* var t = new Ext.Template("<div>Hello {0}.</div>");
|
|
14
|
+
* t.{@link #append}('some-element', ['foo']);
|
|
15
|
+
*
|
|
16
|
+
* - Array:
|
|
17
|
+
*
|
|
18
|
+
* An Array will be combined with `join('')`.
|
|
19
|
+
*
|
|
20
|
+
* var t = new Ext.Template([
|
|
21
|
+
* '<div name="{id}">',
|
|
22
|
+
* '<span class="{cls}">{name:trim} {value:ellipsis(10)}</span>',
|
|
23
|
+
* '</div>',
|
|
24
|
+
* ]);
|
|
25
|
+
* t.{@link #compile}();
|
|
26
|
+
* t.{@link #append}('some-element', {id: 'myid', cls: 'myclass', name: 'foo', value: 'bar'});
|
|
27
|
+
*
|
|
28
|
+
* # Multiple arguments: String, Object, Array, ...
|
|
29
|
+
*
|
|
30
|
+
* Multiple arguments will be combined with `join('')`.
|
|
31
|
+
*
|
|
32
|
+
* var t = new Ext.Template(
|
|
33
|
+
* '<div name="{id}">',
|
|
34
|
+
* '<span class="{cls}">{name} {value}</span>',
|
|
35
|
+
* '</div>',
|
|
36
|
+
* // a configuration object:
|
|
37
|
+
* {
|
|
38
|
+
* compiled: true, // {@link #compile} immediately
|
|
39
|
+
* }
|
|
40
|
+
* );
|
|
41
|
+
*
|
|
42
|
+
* # Notes
|
|
43
|
+
*
|
|
44
|
+
* - For a list of available format functions, see {@link Ext.util.Format}.
|
|
45
|
+
* - `disableFormats` reduces `{@link #apply}` time when no formatting is required.
|
|
46
|
+
*/
|
|
47
|
+
Ext.define('Ext.Template', {
|
|
48
|
+
|
|
49
|
+
/* Begin Definitions */
|
|
50
|
+
|
|
51
|
+
requires: ['Ext.dom.Helper', 'Ext.util.Format'],
|
|
52
|
+
|
|
53
|
+
inheritableStatics: {
|
|
54
|
+
/**
|
|
55
|
+
* Creates a template from the passed element's value (_display:none_ textarea, preferred) or innerHTML.
|
|
56
|
+
* @param {String/HTMLElement} el A DOM element or its id
|
|
57
|
+
* @param {Object} config (optional) Config object
|
|
58
|
+
* @return {Ext.Template} The created template
|
|
59
|
+
* @static
|
|
60
|
+
* @inheritable
|
|
61
|
+
*/
|
|
62
|
+
from: function(el, config) {
|
|
63
|
+
el = Ext.getDom(el);
|
|
64
|
+
return new this(el.value || el.innerHTML, config || '');
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
|
|
68
|
+
/* End Definitions */
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Creates new template.
|
|
72
|
+
*
|
|
73
|
+
* @param {String...} html List of strings to be concatenated into template.
|
|
74
|
+
* Alternatively an array of strings can be given, but then no config object may be passed.
|
|
75
|
+
* @param {Object} config (optional) Config object
|
|
76
|
+
*/
|
|
77
|
+
constructor: function(html) {
|
|
78
|
+
var me = this,
|
|
79
|
+
args = arguments,
|
|
80
|
+
buffer = [],
|
|
81
|
+
i = 0,
|
|
82
|
+
length = args.length,
|
|
83
|
+
value;
|
|
84
|
+
|
|
85
|
+
me.initialConfig = {};
|
|
86
|
+
|
|
87
|
+
// Allow an array to be passed here so we can
|
|
88
|
+
// pass an array of strings and an object
|
|
89
|
+
// at the end
|
|
90
|
+
if (length === 1 && Ext.isArray(html)) {
|
|
91
|
+
args = html;
|
|
92
|
+
length = args.length;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
if (length > 1) {
|
|
96
|
+
for (; i < length; i++) {
|
|
97
|
+
value = args[i];
|
|
98
|
+
if (typeof value == 'object') {
|
|
99
|
+
Ext.apply(me.initialConfig, value);
|
|
100
|
+
Ext.apply(me, value);
|
|
101
|
+
} else {
|
|
102
|
+
buffer.push(value);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
} else {
|
|
106
|
+
buffer.push(html);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// @private
|
|
110
|
+
me.html = buffer.join('');
|
|
111
|
+
|
|
112
|
+
if (me.compiled) {
|
|
113
|
+
me.compile();
|
|
114
|
+
}
|
|
115
|
+
},
|
|
116
|
+
|
|
117
|
+
/**
|
|
118
|
+
* @property {Boolean} isTemplate
|
|
119
|
+
* `true` in this class to identify an object as an instantiated Template, or subclass thereof.
|
|
120
|
+
*/
|
|
121
|
+
isTemplate: true,
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* @cfg {Boolean} compiled
|
|
125
|
+
* True to immediately compile the template. Defaults to false.
|
|
126
|
+
*/
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* @cfg {Boolean} disableFormats
|
|
130
|
+
* True to disable format functions in the template. If the template doesn't contain
|
|
131
|
+
* format functions, setting disableFormats to true will reduce apply time. Defaults to false.
|
|
132
|
+
*/
|
|
133
|
+
disableFormats: false,
|
|
134
|
+
|
|
135
|
+
re: /\{([\w\-]+)(?:\:([\w\.]*)(?:\((.*?)?\))?)?\}/g,
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Returns an HTML fragment of this template with the specified values applied.
|
|
139
|
+
*
|
|
140
|
+
* @param {Object/Array} values The template values. Can be an array if your params are numeric:
|
|
141
|
+
*
|
|
142
|
+
* var tpl = new Ext.Template('Name: {0}, Age: {1}');
|
|
143
|
+
* tpl.apply(['John', 25]);
|
|
144
|
+
*
|
|
145
|
+
* or an object:
|
|
146
|
+
*
|
|
147
|
+
* var tpl = new Ext.Template('Name: {name}, Age: {age}');
|
|
148
|
+
* tpl.apply({name: 'John', age: 25});
|
|
149
|
+
*
|
|
150
|
+
* @return {String} The HTML fragment
|
|
151
|
+
*/
|
|
152
|
+
apply: function(values) {
|
|
153
|
+
var me = this,
|
|
154
|
+
useFormat = me.disableFormats !== true,
|
|
155
|
+
fm = Ext.util.Format,
|
|
156
|
+
tpl = me,
|
|
157
|
+
ret;
|
|
158
|
+
|
|
159
|
+
if (me.compiled) {
|
|
160
|
+
return me.compiled(values).join('');
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
function fn(m, name, format, args) {
|
|
164
|
+
if (format && useFormat) {
|
|
165
|
+
if (args) {
|
|
166
|
+
args = [values[name]].concat(Ext.functionFactory('return ['+ args +'];')());
|
|
167
|
+
} else {
|
|
168
|
+
args = [values[name]];
|
|
169
|
+
}
|
|
170
|
+
if (format.substr(0, 5) == "this.") {
|
|
171
|
+
return tpl[format.substr(5)].apply(tpl, args);
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
return fm[format].apply(fm, args);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
return values[name] !== undefined ? values[name] : "";
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
ret = me.html.replace(me.re, fn);
|
|
183
|
+
return ret;
|
|
184
|
+
},
|
|
185
|
+
|
|
186
|
+
/**
|
|
187
|
+
* Appends the result of this template to the provided output array.
|
|
188
|
+
* @param {Object/Array} values The template values. See {@link #apply}.
|
|
189
|
+
* @param {Array} out The array to which output is pushed.
|
|
190
|
+
* @return {Array} The given out array.
|
|
191
|
+
*/
|
|
192
|
+
applyOut: function(values, out) {
|
|
193
|
+
var me = this;
|
|
194
|
+
|
|
195
|
+
if (me.compiled) {
|
|
196
|
+
out.push.apply(out, me.compiled(values));
|
|
197
|
+
} else {
|
|
198
|
+
out.push(me.apply(values));
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
return out;
|
|
202
|
+
},
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* @method applyTemplate
|
|
206
|
+
* @member Ext.Template
|
|
207
|
+
* Alias for {@link #apply}.
|
|
208
|
+
* @inheritdoc Ext.Template#apply
|
|
209
|
+
*/
|
|
210
|
+
applyTemplate: function () {
|
|
211
|
+
return this.apply.apply(this, arguments);
|
|
212
|
+
},
|
|
213
|
+
|
|
214
|
+
/**
|
|
215
|
+
* Sets the HTML used as the template and optionally compiles it.
|
|
216
|
+
* @param {String} html
|
|
217
|
+
* @param {Boolean} compile (optional) True to compile the template.
|
|
218
|
+
* @return {Ext.Template} this
|
|
219
|
+
*/
|
|
220
|
+
set: function(html, compile) {
|
|
221
|
+
var me = this;
|
|
222
|
+
me.html = html;
|
|
223
|
+
me.compiled = null;
|
|
224
|
+
return compile ? me.compile() : me;
|
|
225
|
+
},
|
|
226
|
+
|
|
227
|
+
compileARe: /\\/g,
|
|
228
|
+
compileBRe: /(\r\n|\n)/g,
|
|
229
|
+
compileCRe: /'/g,
|
|
230
|
+
|
|
231
|
+
/**
|
|
232
|
+
* Compiles the template into an internal function, eliminating the RegEx overhead.
|
|
233
|
+
* @return {Ext.Template} this
|
|
234
|
+
*/
|
|
235
|
+
compile: function() {
|
|
236
|
+
var me = this,
|
|
237
|
+
fm = Ext.util.Format,
|
|
238
|
+
useFormat = me.disableFormats !== true,
|
|
239
|
+
body, bodyReturn;
|
|
240
|
+
|
|
241
|
+
function fn(m, name, format, args) {
|
|
242
|
+
if (format && useFormat) {
|
|
243
|
+
args = args ? ',' + args: "";
|
|
244
|
+
if (format.substr(0, 5) != "this.") {
|
|
245
|
+
format = "fm." + format + '(';
|
|
246
|
+
}
|
|
247
|
+
else {
|
|
248
|
+
format = 'this.' + format.substr(5) + '(';
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
else {
|
|
252
|
+
args = '';
|
|
253
|
+
format = "(values['" + name + "'] == undefined ? '' : ";
|
|
254
|
+
}
|
|
255
|
+
return "'," + format + "values['" + name + "']" + args + ") ,'";
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
bodyReturn = me.html.replace(me.compileARe, '\\\\').replace(me.compileBRe, '\\n').replace(me.compileCRe, "\\'").replace(me.re, fn);
|
|
259
|
+
body = "this.compiled = function(values){ return ['" + bodyReturn + "'];};";
|
|
260
|
+
eval(body);
|
|
261
|
+
return me;
|
|
262
|
+
},
|
|
263
|
+
|
|
264
|
+
/**
|
|
265
|
+
* Applies the supplied values to the template and inserts the new node(s) as the first child of el.
|
|
266
|
+
*
|
|
267
|
+
* @param {String/HTMLElement/Ext.Element} el The context element
|
|
268
|
+
* @param {Object/Array} values The template values. See {@link #applyTemplate} for details.
|
|
269
|
+
* @param {Boolean} returnElement (optional) true to return a Ext.Element.
|
|
270
|
+
* @return {HTMLElement/Ext.Element} The new node or Element
|
|
271
|
+
*/
|
|
272
|
+
insertFirst: function(el, values, returnElement) {
|
|
273
|
+
return this.doInsert('afterBegin', el, values, returnElement);
|
|
274
|
+
},
|
|
275
|
+
|
|
276
|
+
/**
|
|
277
|
+
* Applies the supplied values to the template and inserts the new node(s) before el.
|
|
278
|
+
*
|
|
279
|
+
* @param {String/HTMLElement/Ext.Element} el The context element
|
|
280
|
+
* @param {Object/Array} values The template values. See {@link #applyTemplate} for details.
|
|
281
|
+
* @param {Boolean} returnElement (optional) true to return a Ext.Element.
|
|
282
|
+
* @return {HTMLElement/Ext.Element} The new node or Element
|
|
283
|
+
*/
|
|
284
|
+
insertBefore: function(el, values, returnElement) {
|
|
285
|
+
return this.doInsert('beforeBegin', el, values, returnElement);
|
|
286
|
+
},
|
|
287
|
+
|
|
288
|
+
/**
|
|
289
|
+
* Applies the supplied values to the template and inserts the new node(s) after el.
|
|
290
|
+
*
|
|
291
|
+
* @param {String/HTMLElement/Ext.Element} el The context element
|
|
292
|
+
* @param {Object/Array} values The template values. See {@link #applyTemplate} for details.
|
|
293
|
+
* @param {Boolean} returnElement (optional) true to return a Ext.Element.
|
|
294
|
+
* @return {HTMLElement/Ext.Element} The new node or Element
|
|
295
|
+
*/
|
|
296
|
+
insertAfter: function(el, values, returnElement) {
|
|
297
|
+
return this.doInsert('afterEnd', el, values, returnElement);
|
|
298
|
+
},
|
|
299
|
+
|
|
300
|
+
/**
|
|
301
|
+
* Applies the supplied `values` to the template and appends the new node(s) to the specified `el`.
|
|
302
|
+
*
|
|
303
|
+
* For example usage see {@link Ext.Template Ext.Template class docs}.
|
|
304
|
+
*
|
|
305
|
+
* @param {String/HTMLElement/Ext.Element} el The context element
|
|
306
|
+
* @param {Object/Array} values The template values. See {@link #applyTemplate} for details.
|
|
307
|
+
* @param {Boolean} returnElement (optional) true to return an Ext.Element.
|
|
308
|
+
* @return {HTMLElement/Ext.Element} The new node or Element
|
|
309
|
+
*/
|
|
310
|
+
append: function(el, values, returnElement) {
|
|
311
|
+
return this.doInsert('beforeEnd', el, values, returnElement);
|
|
312
|
+
},
|
|
313
|
+
|
|
314
|
+
doInsert: function(where, el, values, returnElement) {
|
|
315
|
+
var newNode = Ext.DomHelper.insertHtml(where, Ext.getDom(el), this.apply(values));
|
|
316
|
+
return returnElement ? Ext.get(newNode) : newNode;
|
|
317
|
+
},
|
|
318
|
+
|
|
319
|
+
/**
|
|
320
|
+
* Applies the supplied values to the template and overwrites the content of el with the new node(s).
|
|
321
|
+
*
|
|
322
|
+
* @param {String/HTMLElement/Ext.Element} el The context element
|
|
323
|
+
* @param {Object/Array} values The template values. See {@link #applyTemplate} for details.
|
|
324
|
+
* @param {Boolean} returnElement (optional) true to return a Ext.Element.
|
|
325
|
+
* @return {HTMLElement/Ext.Element} The new node or Element
|
|
326
|
+
*/
|
|
327
|
+
overwrite: function(el, values, returnElement) {
|
|
328
|
+
var newNode = Ext.DomHelper.overwrite(Ext.getDom(el), this.apply(values));
|
|
329
|
+
return returnElement ? Ext.get(newNode) : newNode;
|
|
330
|
+
}
|
|
331
|
+
});
|
|
@@ -0,0 +1,365 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A template class that supports advanced functionality like:
|
|
3
|
+
*
|
|
4
|
+
* - Autofilling arrays using templates and sub-templates
|
|
5
|
+
* - Conditional processing with basic comparison operators
|
|
6
|
+
* - Basic math function support
|
|
7
|
+
* - Execute arbitrary inline code with special built-in template variables
|
|
8
|
+
* - Custom member functions
|
|
9
|
+
* - Many special tags and built-in operators that aren't defined as part of the API, but are supported in the templates that can be created
|
|
10
|
+
*
|
|
11
|
+
* XTemplate provides the templating mechanism built into {@link Ext.view.View}.
|
|
12
|
+
*
|
|
13
|
+
* The {@link Ext.Template} describes the acceptable parameters to pass to the constructor. The following examples
|
|
14
|
+
* demonstrate all of the supported features.
|
|
15
|
+
*
|
|
16
|
+
* # Sample Data
|
|
17
|
+
*
|
|
18
|
+
* This is the data object used for reference in each code example:
|
|
19
|
+
*
|
|
20
|
+
* var data = {
|
|
21
|
+
* name: 'Don Griffin',
|
|
22
|
+
* title: 'Senior Technomage',
|
|
23
|
+
* company: 'Sencha Inc.',
|
|
24
|
+
* drinks: ['Coffee', 'Water', 'More Coffee'],
|
|
25
|
+
* kids: [
|
|
26
|
+
* { name: 'Aubrey', age: 17 },
|
|
27
|
+
* { name: 'Joshua', age: 13 },
|
|
28
|
+
* { name: 'Cale', age: 10 },
|
|
29
|
+
* { name: 'Nikol', age: 5 },
|
|
30
|
+
* { name: 'Solomon', age: 0 }
|
|
31
|
+
* ]
|
|
32
|
+
* };
|
|
33
|
+
*
|
|
34
|
+
* # Auto filling of arrays
|
|
35
|
+
*
|
|
36
|
+
* The **tpl** tag and the **for** operator are used to process the provided data object:
|
|
37
|
+
*
|
|
38
|
+
* - If the value specified in for is an array, it will auto-fill, repeating the template block inside the tpl
|
|
39
|
+
* tag for each item in the array.
|
|
40
|
+
* - If for="." is specified, the data object provided is examined.
|
|
41
|
+
* - While processing an array, the special variable {#} will provide the current array index + 1 (starts at 1, not 0).
|
|
42
|
+
*
|
|
43
|
+
* Examples:
|
|
44
|
+
*
|
|
45
|
+
* <tpl for=".">...</tpl> // loop through array at root node
|
|
46
|
+
* <tpl for="foo">...</tpl> // loop through array at foo node
|
|
47
|
+
* <tpl for="foo.bar">...</tpl> // loop through array at foo.bar node
|
|
48
|
+
*
|
|
49
|
+
* Using the sample data above:
|
|
50
|
+
*
|
|
51
|
+
* var tpl = new Ext.XTemplate(
|
|
52
|
+
* '<p>Kids: ',
|
|
53
|
+
* '<tpl for=".">', // process the data.kids node
|
|
54
|
+
* '<p>{#}. {name}</p>', // use current array index to autonumber
|
|
55
|
+
* '</tpl></p>'
|
|
56
|
+
* );
|
|
57
|
+
* tpl.overwrite(panel.body, data.kids); // pass the kids property of the data object
|
|
58
|
+
*
|
|
59
|
+
* An example illustrating how the **for** property can be leveraged to access specified members of the provided data
|
|
60
|
+
* object to populate the template:
|
|
61
|
+
*
|
|
62
|
+
* var tpl = new Ext.XTemplate(
|
|
63
|
+
* '<p>Name: {name}</p>',
|
|
64
|
+
* '<p>Title: {title}</p>',
|
|
65
|
+
* '<p>Company: {company}</p>',
|
|
66
|
+
* '<p>Kids: ',
|
|
67
|
+
* '<tpl for="kids">', // interrogate the kids property within the data
|
|
68
|
+
* '<p>{name}</p>',
|
|
69
|
+
* '</tpl></p>'
|
|
70
|
+
* );
|
|
71
|
+
* tpl.overwrite(panel.body, data); // pass the root node of the data object
|
|
72
|
+
*
|
|
73
|
+
* Flat arrays that contain values (and not objects) can be auto-rendered using the special **`{.}`** variable inside a
|
|
74
|
+
* loop. This variable will represent the value of the array at the current index:
|
|
75
|
+
*
|
|
76
|
+
* var tpl = new Ext.XTemplate(
|
|
77
|
+
* '<p>{name}\'s favorite beverages:</p>',
|
|
78
|
+
* '<tpl for="drinks">',
|
|
79
|
+
* '<div> - {.}</div>',
|
|
80
|
+
* '</tpl>'
|
|
81
|
+
* );
|
|
82
|
+
* tpl.overwrite(panel.body, data);
|
|
83
|
+
*
|
|
84
|
+
* When processing a sub-template, for example while looping through a child array, you can access the parent object's
|
|
85
|
+
* members via the **parent** object:
|
|
86
|
+
*
|
|
87
|
+
* var tpl = new Ext.XTemplate(
|
|
88
|
+
* '<p>Name: {name}</p>',
|
|
89
|
+
* '<p>Kids: ',
|
|
90
|
+
* '<tpl for="kids">',
|
|
91
|
+
* '<tpl if="age > 1">',
|
|
92
|
+
* '<p>{name}</p>',
|
|
93
|
+
* '<p>Dad: {parent.name}</p>',
|
|
94
|
+
* '</tpl>',
|
|
95
|
+
* '</tpl></p>'
|
|
96
|
+
* );
|
|
97
|
+
* tpl.overwrite(panel.body, data);
|
|
98
|
+
*
|
|
99
|
+
* # Conditional processing with basic comparison operators
|
|
100
|
+
*
|
|
101
|
+
* The **tpl** tag and the **if** operator are used to provide conditional checks for deciding whether or not to render
|
|
102
|
+
* specific parts of the template.
|
|
103
|
+
*
|
|
104
|
+
* Using the sample data above:
|
|
105
|
+
*
|
|
106
|
+
* var tpl = new Ext.XTemplate(
|
|
107
|
+
* '<p>Name: {name}</p>',
|
|
108
|
+
* '<p>Kids: ',
|
|
109
|
+
* '<tpl for="kids">',
|
|
110
|
+
* '<tpl if="age > 1">',
|
|
111
|
+
* '<p>{name}</p>',
|
|
112
|
+
* '</tpl>',
|
|
113
|
+
* '</tpl></p>'
|
|
114
|
+
* );
|
|
115
|
+
* tpl.overwrite(panel.body, data);
|
|
116
|
+
*
|
|
117
|
+
* More advanced conditionals are also supported:
|
|
118
|
+
*
|
|
119
|
+
* var tpl = new Ext.XTemplate(
|
|
120
|
+
* '<p>Name: {name}</p>',
|
|
121
|
+
* '<p>Kids: ',
|
|
122
|
+
* '<tpl for="kids">',
|
|
123
|
+
* '<p>{name} is a ',
|
|
124
|
+
* '<tpl if="age >= 13">',
|
|
125
|
+
* '<p>teenager</p>',
|
|
126
|
+
* '<tpl elseif="age >= 2">',
|
|
127
|
+
* '<p>kid</p>',
|
|
128
|
+
* '<tpl else">',
|
|
129
|
+
* '<p>baby</p>',
|
|
130
|
+
* '</tpl>',
|
|
131
|
+
* '</tpl></p>'
|
|
132
|
+
* );
|
|
133
|
+
*
|
|
134
|
+
* var tpl = new Ext.XTemplate(
|
|
135
|
+
* '<p>Name: {name}</p>',
|
|
136
|
+
* '<p>Kids: ',
|
|
137
|
+
* '<tpl for="kids">',
|
|
138
|
+
* '<p>{name} is a ',
|
|
139
|
+
* '<tpl switch="name">',
|
|
140
|
+
* '<tpl case="Aubrey" case="Nikol">',
|
|
141
|
+
* '<p>girl</p>',
|
|
142
|
+
* '<tpl default">',
|
|
143
|
+
* '<p>boy</p>',
|
|
144
|
+
* '</tpl>',
|
|
145
|
+
* '</tpl></p>'
|
|
146
|
+
* );
|
|
147
|
+
*
|
|
148
|
+
* A `break` is implied between each case and default, however, multiple cases can be listed
|
|
149
|
+
* in a single <tpl> tag.
|
|
150
|
+
*
|
|
151
|
+
* # Using double quotes
|
|
152
|
+
*
|
|
153
|
+
* Examples:
|
|
154
|
+
*
|
|
155
|
+
* var tpl = new Ext.XTemplate(
|
|
156
|
+
* "<tpl if='age > 1 && age < 10'>Child</tpl>",
|
|
157
|
+
* "<tpl if='age >= 10 && age < 18'>Teenager</tpl>",
|
|
158
|
+
* "<tpl if='this.isGirl(name)'>...</tpl>",
|
|
159
|
+
* '<tpl if="id == \'download\'">...</tpl>',
|
|
160
|
+
* "<tpl if='needsIcon'><img src='{icon}' class='{iconCls}'/></tpl>",
|
|
161
|
+
* "<tpl if='name == \"Don\"'>Hello</tpl>"
|
|
162
|
+
* );
|
|
163
|
+
*
|
|
164
|
+
* # Basic math support
|
|
165
|
+
*
|
|
166
|
+
* The following basic math operators may be applied directly on numeric data values:
|
|
167
|
+
*
|
|
168
|
+
* + - * /
|
|
169
|
+
*
|
|
170
|
+
* For example:
|
|
171
|
+
*
|
|
172
|
+
* var tpl = new Ext.XTemplate(
|
|
173
|
+
* '<p>Name: {name}</p>',
|
|
174
|
+
* '<p>Kids: ',
|
|
175
|
+
* '<tpl for="kids">',
|
|
176
|
+
* '<tpl if="age > 1">', // <-- Note that the > is encoded
|
|
177
|
+
* '<p>{#}: {name}</p>', // <-- Auto-number each item
|
|
178
|
+
* '<p>In 5 Years: {age+5}</p>', // <-- Basic math
|
|
179
|
+
* '<p>Dad: {parent.name}</p>',
|
|
180
|
+
* '</tpl>',
|
|
181
|
+
* '</tpl></p>'
|
|
182
|
+
* );
|
|
183
|
+
* tpl.overwrite(panel.body, data);
|
|
184
|
+
*
|
|
185
|
+
* # Execute arbitrary inline code with special built-in template variables
|
|
186
|
+
*
|
|
187
|
+
* Anything between `{[ ... ]}` is considered code to be executed in the scope of the template.
|
|
188
|
+
* The expression is evaluated and the result is included in the generated result. There are
|
|
189
|
+
* some special variables available in that code:
|
|
190
|
+
*
|
|
191
|
+
* - **out**: The output array into which the template is being appended (using `push` to later
|
|
192
|
+
* `join`).
|
|
193
|
+
* - **values**: The values in the current scope. If you are using scope changing sub-templates,
|
|
194
|
+
* you can change what values is.
|
|
195
|
+
* - **parent**: The scope (values) of the ancestor template.
|
|
196
|
+
* - **xindex**: If you are in a looping template, the index of the loop you are in (1-based).
|
|
197
|
+
* - **xcount**: If you are in a looping template, the total length of the array you are looping.
|
|
198
|
+
*
|
|
199
|
+
* This example demonstrates basic row striping using an inline code block and the xindex variable:
|
|
200
|
+
*
|
|
201
|
+
* var tpl = new Ext.XTemplate(
|
|
202
|
+
* '<p>Name: {name}</p>',
|
|
203
|
+
* '<p>Company: {[values.company.toUpperCase() + ", " + values.title]}</p>',
|
|
204
|
+
* '<p>Kids: ',
|
|
205
|
+
* '<tpl for="kids">',
|
|
206
|
+
* '<div class="{[xindex % 2 === 0 ? "even" : "odd"]}">',
|
|
207
|
+
* '{name}',
|
|
208
|
+
* '</div>',
|
|
209
|
+
* '</tpl></p>'
|
|
210
|
+
* );
|
|
211
|
+
*
|
|
212
|
+
* Any code contained in "verbatim" blocks (using "{% ... %}") will be inserted directly in
|
|
213
|
+
* the generated code for the template. These blocks are not included in the output. This
|
|
214
|
+
* can be used for simple things like break/continue in a loop, or control structures or
|
|
215
|
+
* method calls (when they don't produce output). The `this` references the template instance.
|
|
216
|
+
*
|
|
217
|
+
* var tpl = new Ext.XTemplate(
|
|
218
|
+
* '<p>Name: {name}</p>',
|
|
219
|
+
* '<p>Company: {[values.company.toUpperCase() + ", " + values.title]}</p>',
|
|
220
|
+
* '<p>Kids: ',
|
|
221
|
+
* '<tpl for="kids">',
|
|
222
|
+
* '{% if (xindex % 2 === 0) continue; %}',
|
|
223
|
+
* '{name}',
|
|
224
|
+
* '{% if (xindex > 100) break; %}',
|
|
225
|
+
* '</div>',
|
|
226
|
+
* '</tpl></p>'
|
|
227
|
+
* );
|
|
228
|
+
*
|
|
229
|
+
* # Template member functions
|
|
230
|
+
*
|
|
231
|
+
* One or more member functions can be specified in a configuration object passed into the XTemplate constructor for
|
|
232
|
+
* more complex processing:
|
|
233
|
+
*
|
|
234
|
+
* var tpl = new Ext.XTemplate(
|
|
235
|
+
* '<p>Name: {name}</p>',
|
|
236
|
+
* '<p>Kids: ',
|
|
237
|
+
* '<tpl for="kids">',
|
|
238
|
+
* '<tpl if="this.isGirl(name)">',
|
|
239
|
+
* '<p>Girl: {name} - {age}</p>',
|
|
240
|
+
* '<tpl else>',
|
|
241
|
+
* '<p>Boy: {name} - {age}</p>',
|
|
242
|
+
* '</tpl>',
|
|
243
|
+
* '<tpl if="this.isBaby(age)">',
|
|
244
|
+
* '<p>{name} is a baby!</p>',
|
|
245
|
+
* '</tpl>',
|
|
246
|
+
* '</tpl></p>',
|
|
247
|
+
* {
|
|
248
|
+
* // XTemplate configuration:
|
|
249
|
+
* disableFormats: true,
|
|
250
|
+
* // member functions:
|
|
251
|
+
* isGirl: function(name){
|
|
252
|
+
* return name == 'Sara Grace';
|
|
253
|
+
* },
|
|
254
|
+
* isBaby: function(age){
|
|
255
|
+
* return age < 1;
|
|
256
|
+
* }
|
|
257
|
+
* }
|
|
258
|
+
* );
|
|
259
|
+
* tpl.overwrite(panel.body, data);
|
|
260
|
+
*/
|
|
261
|
+
Ext.define('Ext.XTemplate', {
|
|
262
|
+
extend: 'Ext.Template',
|
|
263
|
+
|
|
264
|
+
requires: 'Ext.XTemplateCompiler',
|
|
265
|
+
|
|
266
|
+
/**
|
|
267
|
+
* @cfg {Boolean} compiled
|
|
268
|
+
* Only applies to {@link Ext.Template}, XTemplates are compiled automatically on the
|
|
269
|
+
* first call to {@link #apply} or {@link #applyOut}.
|
|
270
|
+
*/
|
|
271
|
+
|
|
272
|
+
/**
|
|
273
|
+
* @cfg {String/Array} definitions
|
|
274
|
+
* Optional. A statement, or array of statements which set up `var`s which may then
|
|
275
|
+
* be accessed within the scope of the generated function.
|
|
276
|
+
*/
|
|
277
|
+
|
|
278
|
+
apply: function(values) {
|
|
279
|
+
return this.applyOut(values, []).join('');
|
|
280
|
+
},
|
|
281
|
+
|
|
282
|
+
applyOut: function(values, out) {
|
|
283
|
+
var me = this,
|
|
284
|
+
compiler;
|
|
285
|
+
|
|
286
|
+
if (!me.fn) {
|
|
287
|
+
compiler = new Ext.XTemplateCompiler({
|
|
288
|
+
useFormat: me.disableFormats !== true,
|
|
289
|
+
definitions: me.definitions
|
|
290
|
+
});
|
|
291
|
+
|
|
292
|
+
me.fn = compiler.compile(me.html);
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
try {
|
|
296
|
+
me.fn.call(me, out, values, {}, 1, 1);
|
|
297
|
+
} catch (e) {
|
|
298
|
+
//<debug>
|
|
299
|
+
Ext.log('Error: ' + e.message);
|
|
300
|
+
//</debug>
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
return out;
|
|
304
|
+
},
|
|
305
|
+
|
|
306
|
+
/**
|
|
307
|
+
* Does nothing. XTemplates are compiled automatically, so this function simply returns this.
|
|
308
|
+
* @return {Ext.XTemplate} this
|
|
309
|
+
*/
|
|
310
|
+
compile: function() {
|
|
311
|
+
return this;
|
|
312
|
+
},
|
|
313
|
+
|
|
314
|
+
statics: {
|
|
315
|
+
/**
|
|
316
|
+
* Gets an `XTemplate` from an object (an instance of an {@link Ext#define}'d class).
|
|
317
|
+
* Many times, templates are configured high in the class hierarchy and are to be
|
|
318
|
+
* shared by all classes that derive from that base. To further complicate matters,
|
|
319
|
+
* these templates are seldom actual instances but are rather configurations. For
|
|
320
|
+
* example:
|
|
321
|
+
*
|
|
322
|
+
* Ext.define('MyApp.Class', {
|
|
323
|
+
* someTpl: [
|
|
324
|
+
* 'tpl text here'
|
|
325
|
+
* ]
|
|
326
|
+
* });
|
|
327
|
+
*
|
|
328
|
+
* The goal being to share that template definition with all instances and even
|
|
329
|
+
* instances of derived classes, until `someTpl` is overridden. This method will
|
|
330
|
+
* "upgrade" these configurations to be real `XTemplate` instances *in place* (to
|
|
331
|
+
* avoid creating one instance per object).
|
|
332
|
+
*
|
|
333
|
+
* @param {Object} instance The object from which to get the `XTemplate` (must be
|
|
334
|
+
* an instance of an {@link Ext#define}'d class).
|
|
335
|
+
* @param {String} name The name of the property by which to get the `XTemplate`.
|
|
336
|
+
* @return {Ext.XTemplate} The `XTemplate` instance or null if not found.
|
|
337
|
+
* @protected
|
|
338
|
+
*/
|
|
339
|
+
getTpl: function (instance, name) {
|
|
340
|
+
var tpl = instance[name], // go for it! 99% of the time we will get it!
|
|
341
|
+
proto;
|
|
342
|
+
|
|
343
|
+
if (tpl && !tpl.isTemplate) { // tpl is just a configuration (not an instance)
|
|
344
|
+
// create the template instance from the configuration:
|
|
345
|
+
tpl = Ext.ClassManager.dynInstantiate('Ext.XTemplate', tpl);
|
|
346
|
+
|
|
347
|
+
// and replace the reference with the new instance:
|
|
348
|
+
if (instance.hasOwnProperty(name)) { // the tpl is on the instance
|
|
349
|
+
instance[name] = tpl;
|
|
350
|
+
} else { // must be somewhere in the prototype chain
|
|
351
|
+
for (proto = instance.self.prototype; proto; proto = proto.superclass) {
|
|
352
|
+
if (proto.hasOwnProperty(name)) {
|
|
353
|
+
proto[name] = tpl;
|
|
354
|
+
break;
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
// else !tpl (no such tpl) or the tpl is an instance already... either way, tpl
|
|
360
|
+
// is ready to return
|
|
361
|
+
|
|
362
|
+
return tpl || null;
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
});
|