lanes 0.1.9 → 0.1.9.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/client/fonts/fontawesome-webfont.woff +0 -0
- data/client/fonts/fontawesome-webfont.woff2 +0 -0
- data/client/lanes/Boot.cjsx +9 -0
- data/client/lanes/access/Extension.coffee +18 -4
- data/client/lanes/access/LoginDialog.cjsx +78 -0
- data/client/lanes/access/Roles.coffee +22 -28
- data/client/lanes/access/User.coffee +16 -16
- data/client/lanes/access/index.js +4 -5
- data/client/lanes/access/screens/user-management/Editor.cjsx +20 -0
- data/client/lanes/access/screens/user-management/UserManagement.cjsx +41 -0
- data/client/lanes/access/screens/user-management/index.js +0 -1
- data/client/lanes/components/grid/EditingMixin.cjsx +64 -0
- data/client/lanes/components/grid/Grid.cjsx +139 -0
- data/client/lanes/components/grid/PopOverMixin.cjsx +28 -0
- data/client/lanes/components/grid/PopoverEditor.cjsx +8 -0
- data/client/lanes/components/grid/RowEditor.cjsx +10 -0
- data/client/lanes/components/grid/Toolbar.cjsx +14 -0
- data/client/lanes/components/grid/config.json +1 -1
- data/client/lanes/components/grid/editors.scss +94 -53
- data/client/lanes/components/grid/index.js +2 -7
- data/client/lanes/components/grid/styles.scss +8 -296
- data/client/lanes/components/helpers.coffee +2 -0
- data/client/lanes/components/index.js +2 -1
- data/client/lanes/components/modal/Modal.cjsx +36 -0
- data/client/lanes/components/modal/index.js +1 -2
- data/client/lanes/components/modal/styles.scss +0 -19
- data/client/lanes/components/record-finder/Clause.cjsx +80 -0
- data/client/lanes/components/record-finder/Dialog.cjsx +54 -0
- data/client/lanes/components/record-finder/RecordFinder.cjsx +38 -0
- data/client/lanes/components/record-finder/config.json +1 -1
- data/client/lanes/components/record-finder/index.js +1 -2
- data/client/lanes/components/request-spinner/index.js +1 -0
- data/client/lanes/components/select-field/SelectField.cjsx +78 -0
- data/client/lanes/components/select-field/index.js +2 -1
- data/client/lanes/components/select-field/styles.scss +1 -0
- data/client/lanes/components/shared/CountBadge.cjsx +9 -0
- data/client/lanes/components/shared/ErrorDisplay.cjsx +21 -0
- data/client/lanes/components/shared/FieldMixin.cjsx +71 -0
- data/client/lanes/components/shared/FieldSet.cjsx +58 -0
- data/client/lanes/components/shared/GenericField.cjsx +5 -0
- data/client/lanes/components/shared/Helpers.coffee +9 -0
- data/client/lanes/components/shared/RadioField.cjsx +14 -0
- data/client/lanes/components/shared/Resize.cjsx +152 -0
- data/client/lanes/components/shared/TextArea.cjsx +19 -0
- data/client/lanes/components/shared/TextField.cjsx +25 -0
- data/client/lanes/components/shared/Tooltip.cjsx +10 -0
- data/client/lanes/components/shared/fields.scss +35 -0
- data/client/lanes/components/shared/fieldset.scss +29 -0
- data/client/lanes/components/shared/index.js +3 -0
- data/client/lanes/components/shared/styles.scss +32 -0
- data/client/lanes/components/toolbar/RemoteChangeSets.cjsx +75 -0
- data/client/lanes/components/toolbar/SaveButton.cjsx +3 -0
- data/client/lanes/components/toolbar/Toolbar.cjsx +58 -0
- data/client/lanes/{workspace/styles → components/toolbar}/changes-notification.scss +10 -23
- data/client/lanes/components/toolbar/index.js +3 -0
- data/client/lanes/components/toolbar/styles.scss +51 -0
- data/client/lanes/extension/Extensions.coffee +19 -10
- data/client/lanes/extension/LateLoaded.js.erb +4 -3
- data/client/lanes/index.js +3 -5
- data/client/lanes/index.scss.erb +6 -14
- data/client/lanes/lib/HotReload.coffee +35 -0
- data/client/lanes/lib/MakeBaseClass.coffee +10 -11
- data/client/lanes/lib/development.coffee +3 -0
- data/client/lanes/lib/dom.coffee +49 -0
- data/client/lanes/lib/el.coffee +23 -0
- data/client/lanes/lib/index.js.erb +16 -0
- data/client/lanes/lib/loader.coffee +34 -34
- data/client/lanes/lib/namespace.coffee +1 -1
- data/client/lanes/lib/objToParam.coffee +37 -0
- data/client/lanes/{access/views/.gitkeep → lib/production.coffee} +0 -0
- data/client/lanes/lib/utilFunctions.coffee +44 -26
- data/client/lanes/models/AssociationMap.coffee +51 -38
- data/client/lanes/models/Base.coffee +89 -88
- data/client/lanes/models/ChangeMonitor.coffee +10 -10
- data/client/lanes/models/ChangeSet.coffee +14 -24
- data/client/lanes/models/Collection.coffee +40 -41
- data/client/lanes/models/PubSub.coffee +28 -19
- data/client/lanes/models/Query.coffee +78 -45
- data/client/lanes/models/QueryResults.coffee +93 -0
- data/client/lanes/models/ServerCache.coffee +12 -12
- data/client/lanes/models/Sync.coffee +53 -50
- data/client/lanes/models/User.coffee +31 -17
- data/client/lanes/react/Component.coffee +31 -0
- data/client/lanes/react/DefaultComponentNotFound.cjsx +9 -0
- data/client/lanes/{views → react}/FormBindings.coffee +0 -0
- data/client/lanes/{views → react}/ModelObserver.coffee +0 -0
- data/client/lanes/{views → react}/ModelUpdate.coffee +0 -0
- data/client/lanes/{views → react}/PubSub.coffee +0 -0
- data/client/lanes/react/Root.cjsx +14 -0
- data/client/lanes/react/Router.cjsx +18 -0
- data/client/lanes/react/Screen.coffee +15 -0
- data/client/lanes/{views → react}/TimedHighlight.coffee +0 -0
- data/client/lanes/{views → react}/TimedMask.coffee +0 -0
- data/client/lanes/react/TypeValidators.coffee +21 -0
- data/client/lanes/{lib/create-namespace.js → react/Utils.coffee} +0 -0
- data/client/lanes/react/Viewport.coffee +30 -0
- data/client/lanes/react/index.js +8 -0
- data/client/lanes/react/mixins/Access.coffee +27 -0
- data/client/lanes/react/mixins/Component.coffee +4 -0
- data/client/lanes/react/mixins/Data.coffee +136 -0
- data/client/lanes/react/mixins/MonitorSize.coffee +11 -0
- data/client/lanes/react/mixins/ReadEditingState.coffee +11 -0
- data/client/lanes/react/mixins/RelayEditingState.coffee +17 -0
- data/client/lanes/react/mixins/RelayFieldChange.coffee +11 -0
- data/client/lanes/react/mixins/Screen.coffee +7 -0
- data/client/lanes/react/mixins/Viewport.coffee +11 -0
- data/client/lanes/screens/ChangeListener.coffee +3 -3
- data/client/lanes/screens/Commands.coffee +27 -0
- data/client/lanes/screens/Definitions.coffee +74 -65
- data/client/lanes/screens/all.js.erb +1 -1
- data/client/lanes/screens/index.js +1 -2
- data/client/lanes/screens/mixins/index.js +0 -1
- data/client/lanes/screens/register.js.erb +0 -1
- data/client/lanes/screens/styles.scss +7 -0
- data/client/lanes/styles/bootstrap-custom-grid.scss +67 -37
- data/client/lanes/styles/bootstrap.scss +4 -5
- data/client/lanes/styles/fonts.scss +10 -23
- data/client/lanes/styles/fonts/_animated.scss +34 -0
- data/client/lanes/styles/fonts/_bordered-pulled.scss +16 -0
- data/client/lanes/styles/fonts/_core.scss +13 -0
- data/client/lanes/styles/fonts/_fixed-width.scss +6 -0
- data/client/lanes/styles/fonts/_icons.scss +596 -0
- data/client/lanes/styles/fonts/_larger.scss +13 -0
- data/client/lanes/styles/fonts/_list.scss +19 -0
- data/client/lanes/styles/fonts/_mixins.scss +27 -0
- data/client/lanes/styles/fonts/_path.scss +10 -0
- data/client/lanes/styles/fonts/_rotated-flipped.scss +20 -0
- data/client/lanes/styles/fonts/_stacked.scss +20 -0
- data/client/lanes/styles/fonts/_variables.scss +606 -0
- data/client/lanes/styles/fonts/font-awesome.scss +16 -0
- data/client/lanes/styles/fonts/index.scss +2 -0
- data/client/lanes/styles/global.scss +2 -0
- data/client/lanes/styles/global/fancy-header.scss +14 -0
- data/client/lanes/testing/BeforeEach.coffee +15 -40
- data/client/lanes/testing/Helpers.coffee +27 -0
- data/client/lanes/testing/ModelSaver.coffee +14 -24
- data/client/lanes/testing/StubRouter.coffee +27 -0
- data/client/lanes/testing/TestObjects.coffee +27 -0
- data/client/lanes/testing/index.js +3 -1
- data/client/lanes/vendor/base.js +85256 -0
- data/client/lanes/vendor/commons.js +20579 -0
- data/client/lanes/vendor/development.js +2511 -0
- data/client/lanes/vendor/grid.js +6689 -0
- data/client/lanes/vendor/grid.scss +387 -0
- data/client/lanes/vendor/index.js +3 -0
- data/client/lanes/vendor/message-bus.coffee +264 -0
- data/client/lanes/vendor/widgets.js +8798 -0
- data/client/lanes/vendor/widgets.scss +723 -0
- data/client/lanes/workspace/ActiveScreenSwitcher.cjsx +38 -0
- data/client/lanes/workspace/Extension.coffee +6 -0
- data/client/lanes/workspace/Layout.cjsx +28 -0
- data/client/lanes/workspace/Navbar.cjsx +25 -0
- data/client/lanes/workspace/ScreenView.cjsx +27 -0
- data/client/lanes/workspace/ScreensMenu.cjsx +57 -0
- data/client/lanes/workspace/UIState.coffee +17 -16
- data/client/lanes/workspace/index.js +7 -2
- data/client/lanes/workspace/styles.scss +0 -3
- data/client/lanes/workspace/styles/forms.scss +2 -73
- data/client/lanes/workspace/styles/header.scss +0 -2
- data/client/lanes/workspace/styles/layout.scss +9 -2
- data/client/lanes/workspace/styles/screens.scss +0 -59
- data/client/lanes/workspace/styles/tabs.scss +16 -15
- data/coffeelint.json +49 -0
- data/config.ru +1 -0
- data/config/database.yml +2 -2
- data/config/routes.rb +7 -0
- data/docs/command.md +11 -8
- data/docs/model.md +2 -5
- data/docs/react.md +137 -0
- data/lanes.gemspec +1 -0
- data/lib/lanes.rb +1 -1
- data/lib/lanes/access/authentication_provider.rb +1 -0
- data/lib/lanes/access/config/routes.rb +2 -0
- data/lib/lanes/access/config/screens.rb +15 -12
- data/lib/lanes/access/extension.rb +2 -1
- data/lib/lanes/access/role.rb +8 -4
- data/lib/lanes/api.rb +4 -3
- data/lib/lanes/api/coffeescript_processor.rb +47 -6
- data/lib/lanes/api/controller.rb +4 -3
- data/lib/lanes/api/default_routes.rb +16 -0
- data/lib/lanes/api/javascript_processor.rb +14 -68
- data/lib/lanes/api/pub_sub.rb +17 -3
- data/lib/lanes/api/request_wrapper.rb +2 -2
- data/lib/lanes/api/root.rb +16 -13
- data/lib/lanes/api/routing.rb +0 -18
- data/lib/lanes/api/sprockets_extension.rb +10 -4
- data/lib/lanes/api/test_specs.rb +3 -3
- data/lib/lanes/cli.rb +6 -1
- data/lib/lanes/command/app.rb +7 -11
- data/lib/lanes/command/generate.rb +3 -3
- data/lib/lanes/command/generate_component.rb +28 -0
- data/lib/lanes/command/generate_component.usage +11 -0
- data/lib/lanes/command/generate_screen.rb +24 -7
- data/lib/lanes/command/generate_screen.usage +5 -8
- data/lib/lanes/configuration.rb +3 -2
- data/lib/lanes/extension.rb +12 -18
- data/lib/lanes/extension/definition.rb +20 -8
- data/lib/lanes/guard_tasks.rb +22 -5
- data/lib/lanes/hot_reload_plugin.rb +47 -0
- data/lib/lanes/logger.rb +41 -5
- data/lib/lanes/screen.rb +40 -16
- data/lib/lanes/spec_helper.rb +6 -3
- data/lib/lanes/version.rb +1 -1
- data/lib/lanes/workspace/extension.rb +1 -0
- data/npm-build/{template.js → base.js} +17 -17
- data/{client/lanes/workspace/tab.html → npm-build/common.js} +0 -0
- data/npm-build/compile.coffee +13 -4
- data/npm-build/development.js +7 -0
- data/npm-build/grid.js +11 -0
- data/npm-build/package.json +62 -58
- data/npm-build/react-widgets.js +5 -0
- data/npm-build/react-widgets.less +35 -0
- data/npm-build/webpack.config.js +39 -0
- data/spec/command-reference-files/component/client/appy-app/components/Big.cjsx +4 -0
- data/spec/command-reference-files/component/spec/appy-app/components/BigSpec.coffee +5 -0
- data/spec/command-reference-files/initial/.rubocop.yml +7 -0
- data/spec/command-reference-files/initial/Gemfile +1 -1
- data/spec/command-reference-files/initial/client/appy-app/Extension.coffee +17 -5
- data/spec/command-reference-files/initial/client/appy-app/components/Base.coffee +9 -0
- data/spec/command-reference-files/initial/client/appy-app/index.js +1 -3
- data/spec/command-reference-files/initial/client/appy-app/screens/Base.coffee +8 -2
- data/spec/command-reference-files/initial/coffeelint.json +49 -0
- data/spec/command-reference-files/initial/config.ru +2 -0
- data/spec/command-reference-files/initial/config/screens.rb +10 -0
- data/spec/command-reference-files/initial/lib/appy-app/extension.rb +7 -0
- data/spec/command-reference-files/model/client/appy-app/models/TestTest.coffee +0 -1
- data/spec/command-reference-files/screen/client/appy-app/Extension.coffee +34 -0
- data/spec/command-reference-files/screen/client/appy-app/screens/ready-set-go/ReadySetGo.cjsx +7 -0
- data/spec/command-reference-files/screen/config/screens.rb +19 -9
- data/spec/command-reference-files/screen/spec/appy-app/screens/ready-set-go/ReadySetGoSpec.coffee +3 -3
- data/spec/lanes/components/grid/GridSpec.coffee +26 -26
- data/spec/lanes/models/AssociationMapSpec.coffee +6 -6
- data/spec/lanes/models/BaseSpec.coffee +24 -35
- data/spec/lanes/models/CollectionSpec.coffee +19 -18
- data/spec/lanes/models/EnumMapSpec.coffee +1 -1
- data/spec/lanes/models/PubSubSpec.coffee +17 -15
- data/spec/lanes/models/SyncSpec.coffee +28 -0
- data/spec/lanes/models/UserSpec.coffee +17 -0
- data/spec/lanes/react/mixins/DataSpec.coffee +72 -0
- data/spec/lanes/screens/DefinitionsSpec.coffee +33 -0
- data/spec/lanes/views/BaseSpec.coffee +133 -133
- data/spec/lanes/views/FormBindingsSpec.coffee +30 -30
- data/spec/server/api/coffeescript_processor_spec.rb +2 -2
- data/spec/server/command_spec.rb +3 -3
- data/templates/client/Extension.coffee +17 -5
- data/templates/client/components/BaseComponent.coffee +9 -0
- data/templates/client/components/Component.cjsx +4 -0
- data/templates/client/{views → components}/template.html +0 -0
- data/templates/client/index.js +1 -3
- data/templates/client/models/Model.coffee +0 -1
- data/templates/client/screens/BaseScreen.coffee +9 -0
- data/templates/client/screens/Screen.cjsx +7 -0
- data/templates/config.ru +2 -0
- data/templates/config/screen.rb +10 -10
- data/templates/config/screens.rb +10 -0
- data/templates/lib/namespace/extension.rb +7 -0
- data/templates/spec/client/Screen.coffee +4 -4
- data/templates/spec/client/components/ComponentSpec.coffee +5 -0
- metadata +157 -201
- data/client/fonts/lanes/icomoon.eot +0 -0
- data/client/fonts/lanes/icomoon.svg +0 -160
- data/client/fonts/lanes/icomoon.ttf +0 -0
- data/client/fonts/lanes/icomoon.woff +0 -0
- data/client/fonts/lanes/selection.json +0 -3565
- data/client/lanes/Boot.coffee +0 -50
- data/client/lanes/access/LoginDialog.coffee +0 -46
- data/client/lanes/access/login-dialog.html +0 -16
- data/client/lanes/access/screens/user-management/GridUserEditor.coffee +0 -26
- data/client/lanes/access/screens/user-management/UserManagement.coffee +0 -23
- data/client/lanes/access/screens/user-management/grid-popover-editor.html +0 -33
- data/client/lanes/access/screens/user-management/screen.html +0 -7
- data/client/lanes/components/Base.coffee +0 -39
- data/client/lanes/components/ChoicesInput.coffee +0 -47
- data/client/lanes/components/grid/Editor.coffee +0 -62
- data/client/lanes/components/grid/Grid.coffee +0 -205
- data/client/lanes/components/grid/PopOverEditor.coffee +0 -29
- data/client/lanes/components/grid/RowEditor.coffee +0 -30
- data/client/lanes/components/grid/popover-editor.html +0 -18
- data/client/lanes/components/grid/row-editor.html +0 -16
- data/client/lanes/components/grid/template.html +0 -4
- data/client/lanes/components/grid/vendor/dataTables.scroller.js +0 -1262
- data/client/lanes/components/grid/vendor/index.js +0 -2
- data/client/lanes/components/grid/vendor/jquery.dataTables.js +0 -14839
- data/client/lanes/components/modal/ModalDialog.coffee +0 -68
- data/client/lanes/components/modal/template.html +0 -18
- data/client/lanes/components/multi-select/MultiSelect.coffee +0 -65
- data/client/lanes/components/popover/PopOver.coffee +0 -55
- data/client/lanes/components/popover/index.js +0 -2
- data/client/lanes/components/popover/styles.scss +0 -2
- data/client/lanes/components/popover/template.html +0 -5
- data/client/lanes/components/radio-group/RadioGroup.coffee +0 -47
- data/client/lanes/components/radio-group/index.js +0 -1
- data/client/lanes/components/radio-group/styles.scss +0 -1
- data/client/lanes/components/record-finder/Clause.coffee +0 -37
- data/client/lanes/components/record-finder/Dialog.coffee +0 -45
- data/client/lanes/components/record-finder/RecordFinder.coffee +0 -61
- data/client/lanes/components/record-finder/clause.html +0 -37
- data/client/lanes/components/record-finder/dialog.html +0 -4
- data/client/lanes/components/record-finder/field.html +0 -8
- data/client/lanes/components/select-field/SelectField.coffee +0 -63
- data/client/lanes/components/select2/Select2.coffee +0 -8
- data/client/lanes/components/select2/index.js +0 -2
- data/client/lanes/lib/Templates.coffee +0 -51
- data/client/lanes/lib/debounce.coffee +0 -15
- data/client/lanes/lib/defer.coffee +0 -7
- data/client/lanes/lib/el.js +0 -115
- data/client/lanes/lib/index.js +0 -5
- data/client/lanes/plugins/overlay.coffee +0 -41
- data/client/lanes/screens/Base.coffee +0 -35
- data/client/lanes/screens/Router.coffee +0 -4
- data/client/lanes/screens/mixins/Editing.coffee +0 -38
- data/client/lanes/styles/bootstrap/old/_alerts.scss +0 -68
- data/client/lanes/styles/bootstrap/old/_badges.scss +0 -57
- data/client/lanes/styles/bootstrap/old/_breadcrumbs.scss +0 -26
- data/client/lanes/styles/bootstrap/old/_button-groups.scss +0 -240
- data/client/lanes/styles/bootstrap/old/_buttons.scss +0 -157
- data/client/lanes/styles/bootstrap/old/_carousel.scss +0 -243
- data/client/lanes/styles/bootstrap/old/_close.scss +0 -35
- data/client/lanes/styles/bootstrap/old/_code.scss +0 -68
- data/client/lanes/styles/bootstrap/old/_component-animations.scss +0 -35
- data/client/lanes/styles/bootstrap/old/_dropdowns.scss +0 -215
- data/client/lanes/styles/bootstrap/old/_forms.scss +0 -538
- data/client/lanes/styles/bootstrap/old/_glyphicons.scss +0 -237
- data/client/lanes/styles/bootstrap/old/_grid.scss +0 -84
- data/client/lanes/styles/bootstrap/old/_input-groups.scss +0 -166
- data/client/lanes/styles/bootstrap/old/_jumbotron.scss +0 -48
- data/client/lanes/styles/bootstrap/old/_labels.scss +0 -66
- data/client/lanes/styles/bootstrap/old/_list-group.scss +0 -132
- data/client/lanes/styles/bootstrap/old/_media.scss +0 -56
- data/client/lanes/styles/bootstrap/old/_mixins.scss +0 -39
- data/client/lanes/styles/bootstrap/old/_modals.scss +0 -150
- data/client/lanes/styles/bootstrap/old/_navbar.scss +0 -659
- data/client/lanes/styles/bootstrap/old/_navs.scss +0 -242
- data/client/lanes/styles/bootstrap/old/_normalize.scss +0 -425
- data/client/lanes/styles/bootstrap/old/_pager.scss +0 -55
- data/client/lanes/styles/bootstrap/old/_pagination.scss +0 -88
- data/client/lanes/styles/bootstrap/old/_panels.scss +0 -243
- data/client/lanes/styles/bootstrap/old/_popovers.scss +0 -133
- data/client/lanes/styles/bootstrap/old/_print.scss +0 -101
- data/client/lanes/styles/bootstrap/old/_progress-bars.scss +0 -105
- data/client/lanes/styles/bootstrap/old/_responsive-embed.scss +0 -34
- data/client/lanes/styles/bootstrap/old/_responsive-utilities.scss +0 -174
- data/client/lanes/styles/bootstrap/old/_scaffolding.scss +0 -150
- data/client/lanes/styles/bootstrap/old/_tables.scss +0 -233
- data/client/lanes/styles/bootstrap/old/_theme.scss +0 -258
- data/client/lanes/styles/bootstrap/old/_thumbnails.scss +0 -38
- data/client/lanes/styles/bootstrap/old/_tooltip.scss +0 -95
- data/client/lanes/styles/bootstrap/old/_type.scss +0 -304
- data/client/lanes/styles/bootstrap/old/_utilities.scss +0 -57
- data/client/lanes/styles/bootstrap/old/_variables.scss +0 -850
- data/client/lanes/styles/bootstrap/old/_wells.scss +0 -29
- data/client/lanes/styles/bootstrap/old/bootstrap.scss +0 -50
- data/client/lanes/styles/bootstrap/old/mixins/_alerts.scss +0 -14
- data/client/lanes/styles/bootstrap/old/mixins/_background-variant.scss +0 -11
- data/client/lanes/styles/bootstrap/old/mixins/_border-radius.scss +0 -18
- data/client/lanes/styles/bootstrap/old/mixins/_buttons.scss +0 -50
- data/client/lanes/styles/bootstrap/old/mixins/_center-block.scss +0 -7
- data/client/lanes/styles/bootstrap/old/mixins/_clearfix.scss +0 -22
- data/client/lanes/styles/bootstrap/old/mixins/_forms.scss +0 -84
- data/client/lanes/styles/bootstrap/old/mixins/_gradients.scss +0 -58
- data/client/lanes/styles/bootstrap/old/mixins/_grid-framework.scss +0 -81
- data/client/lanes/styles/bootstrap/old/mixins/_grid.scss +0 -122
- data/client/lanes/styles/bootstrap/old/mixins/_hide-text.scss +0 -21
- data/client/lanes/styles/bootstrap/old/mixins/_image.scss +0 -34
- data/client/lanes/styles/bootstrap/old/mixins/_labels.scss +0 -12
- data/client/lanes/styles/bootstrap/old/mixins/_list-group.scss +0 -31
- data/client/lanes/styles/bootstrap/old/mixins/_nav-divider.scss +0 -10
- data/client/lanes/styles/bootstrap/old/mixins/_nav-vertical-align.scss +0 -9
- data/client/lanes/styles/bootstrap/old/mixins/_opacity.scss +0 -8
- data/client/lanes/styles/bootstrap/old/mixins/_pagination.scss +0 -23
- data/client/lanes/styles/bootstrap/old/mixins/_panels.scss +0 -24
- data/client/lanes/styles/bootstrap/old/mixins/_progress-bar.scss +0 -10
- data/client/lanes/styles/bootstrap/old/mixins/_reset-filter.scss +0 -8
- data/client/lanes/styles/bootstrap/old/mixins/_resize.scss +0 -6
- data/client/lanes/styles/bootstrap/old/mixins/_responsive-visibility.scss +0 -21
- data/client/lanes/styles/bootstrap/old/mixins/_size.scss +0 -10
- data/client/lanes/styles/bootstrap/old/mixins/_tab-focus.scss +0 -9
- data/client/lanes/styles/bootstrap/old/mixins/_table-row.scss +0 -28
- data/client/lanes/styles/bootstrap/old/mixins/_text-emphasis.scss +0 -11
- data/client/lanes/styles/bootstrap/old/mixins/_text-overflow.scss +0 -8
- data/client/lanes/styles/bootstrap/old/mixins/_vendor-prefixes.scss +0 -219
- data/client/lanes/styles/font-definitions.scss +0 -451
- data/client/lanes/testing/TestModels.coffee +0 -23
- data/client/lanes/vendor/bootstrap/affix.js +0 -162
- data/client/lanes/vendor/bootstrap/alert.js +0 -94
- data/client/lanes/vendor/bootstrap/button.js +0 -116
- data/client/lanes/vendor/bootstrap/carousel.js +0 -240
- data/client/lanes/vendor/bootstrap/collapse.js +0 -211
- data/client/lanes/vendor/bootstrap/dropdown.js +0 -161
- data/client/lanes/vendor/bootstrap/modal.js +0 -324
- data/client/lanes/vendor/bootstrap/popover.js +0 -119
- data/client/lanes/vendor/bootstrap/scrollspy.js +0 -175
- data/client/lanes/vendor/bootstrap/tab.js +0 -153
- data/client/lanes/vendor/bootstrap/tooltip.js +0 -478
- data/client/lanes/vendor/bootstrap/transition.js +0 -59
- data/client/lanes/vendor/message-bus.js +0 -285
- data/client/lanes/vendor/modern-stack.js +0 -27
- data/client/lanes/vendor/packaged.js +0 -19533
- data/client/lanes/views/Assets.coffee +0 -9
- data/client/lanes/views/Base.coffee +0 -426
- data/client/lanes/views/Functions.coffee +0 -13
- data/client/lanes/views/Helpers.coffee +0 -76
- data/client/lanes/views/Keys.coffee +0 -59
- data/client/lanes/views/RenderContext.coffee +0 -32
- data/client/lanes/views/SaveNotify.coffee +0 -32
- data/client/lanes/views/Viewport.coffee +0 -18
- data/client/lanes/views/_button.html +0 -3
- data/client/lanes/views/_toolbar.html +0 -23
- data/client/lanes/views/empty-span.html +0 -1
- data/client/lanes/views/index.js +0 -2
- data/client/lanes/views/model-update.html +0 -15
- data/client/lanes/workspace/ActiveScreensSwitcher.coffee +0 -112
- data/client/lanes/workspace/Layout.coffee +0 -29
- data/client/lanes/workspace/Navbar.coffee +0 -31
- data/client/lanes/workspace/Pages.coffee +0 -39
- data/client/lanes/workspace/ScreensMenu.coffee +0 -126
- data/client/lanes/workspace/WorkspaceView.coffee +0 -8
- data/client/lanes/workspace/layout.html +0 -4
- data/client/lanes/workspace/menu.html +0 -356
- data/client/lanes/workspace/menu_toggle.html +0 -9
- data/client/lanes/workspace/navbar.html +0 -17
- data/client/lanes/workspace/pages.html +0 -6
- data/client/lanes/workspace/screens-menu.html +0 -11
- data/client/lanes/workspace/screens-switcher.html +0 -7
- data/docs/view.md +0 -292
- data/lib/lanes/command/generate_view.rb +0 -38
- data/lib/lanes/command/generate_view.usage +0 -13
- data/spec/command-reference-files/initial/client/appy-app/Router.coffee +0 -4
- data/spec/command-reference-files/initial/client/appy-app/controllers/.gitkeep +0 -0
- data/spec/command-reference-files/initial/client/appy-app/views/.gitkeep +0 -0
- data/spec/command-reference-files/initial/client/appy-app/views/Base.coffee +0 -5
- data/spec/command-reference-files/initial/spec/appy-app/screens/Base.coffee +0 -5
- data/spec/command-reference-files/screen/client/appy-app/screens/ready-set-go/ReadySetGo.coffee +0 -6
- data/spec/command-reference-files/screen/client/appy-app/screens/ready-set-go/layout.html +0 -3
- data/spec/command-reference-files/view/client/appy-app/views/BigView.coffee +0 -10
- data/spec/command-reference-files/view/spec/appy-app/views/BigViewSpec.coffee +0 -5
- data/templates/client/Router.coffee +0 -4
- data/templates/client/components/Component.coffee +0 -1
- data/templates/client/screens/Base.coffee +0 -3
- data/templates/client/screens/Screen.coffee +0 -11
- data/templates/client/screens/layout.html +0 -3
- data/templates/client/views/.gitkeep +0 -0
- data/templates/client/views/BaseView.coffee +0 -5
- data/templates/client/views/View.coffee +0 -10
- data/templates/spec/client/views/ViewSpec.coffee +0 -5
@@ -8,23 +8,29 @@ class ModelType extends Lanes.Models.State
|
|
8
8
|
id: 'string'
|
9
9
|
records: 'object'
|
10
10
|
|
11
|
-
subscribe: (
|
12
|
-
|
13
|
-
|
14
|
-
|
11
|
+
subscribe: (config) ->
|
12
|
+
model = config.models[0]
|
13
|
+
channel = "/#{_.result(model, 'api_path')}/#{model.id}"
|
14
|
+
Lanes.Vendor.MessageBus.subscribe(channel, (changes) ->
|
15
|
+
for model in config.models
|
16
|
+
model.addChangeSet(changes)
|
15
17
|
)
|
16
18
|
channel
|
17
19
|
|
18
|
-
add: (model)->
|
20
|
+
add: (model) ->
|
19
21
|
if (config = @records[model.id])
|
20
|
-
config.model
|
22
|
+
config.models.push(model) unless _.include(config.models, model)
|
21
23
|
else
|
22
|
-
|
24
|
+
config = { models: [model] }
|
25
|
+
config.channel = this.subscribe(config)
|
26
|
+
@records[model.id] = config
|
23
27
|
|
24
|
-
remove: (model)->
|
28
|
+
remove: (model) ->
|
25
29
|
if ( config = @records[model.id] )
|
26
|
-
|
27
|
-
|
30
|
+
_.remove(config.models, (m) -> m == model)
|
31
|
+
if _.isEmpty(config.models)
|
32
|
+
Lanes.Vendor.MessageBus.unsubscribe( config.channel )
|
33
|
+
delete @records[model.id]
|
28
34
|
|
29
35
|
|
30
36
|
class ModelTypesCollection extends Lanes.Models.BasicCollection
|
@@ -32,8 +38,8 @@ class ModelTypesCollection extends Lanes.Models.BasicCollection
|
|
32
38
|
constructor: -> super
|
33
39
|
model: ModelType
|
34
40
|
|
35
|
-
forModel: (model)->
|
36
|
-
path = _.result(model,'api_path')
|
41
|
+
forModel: (model) ->
|
42
|
+
path = _.result(model, 'api_path')
|
37
43
|
models = this.get(path) || this.add(id: path)
|
38
44
|
|
39
45
|
|
@@ -41,24 +47,27 @@ Lanes.Models.PubSub = {
|
|
41
47
|
|
42
48
|
types: new ModelTypesCollection
|
43
49
|
|
44
|
-
forModel: (model)->
|
50
|
+
# forModel: (model) ->
|
45
51
|
|
46
|
-
add: (model)->
|
52
|
+
add: (model) ->
|
47
53
|
return unless model.isPersistent?()
|
48
54
|
@types.forModel(model).add(model)
|
49
55
|
|
50
|
-
remove: (model)->
|
56
|
+
remove: (model) ->
|
51
57
|
return unless model && model.isPersistent?()
|
52
58
|
@types.forModel(model).remove(model)
|
53
59
|
|
54
|
-
instanceFor: ( model_klass, id )->
|
55
|
-
|
60
|
+
instanceFor: ( model_klass, id ) ->
|
61
|
+
path = _.result(model_klass.prototype, 'api_path')
|
62
|
+
@types.get(path)?.records[id]?.models[0]
|
56
63
|
|
57
64
|
clear: ->
|
58
65
|
@types = new ModelTypesCollection
|
59
66
|
|
60
67
|
initialize: ->
|
61
68
|
Lanes.Vendor.MessageBus.start()
|
62
|
-
Lanes.Vendor.MessageBus.callbackInterval =
|
63
|
-
|
69
|
+
Lanes.Vendor.MessageBus.callbackInterval = 2000
|
70
|
+
Lanes.Vendor.MessageBus.subscribe("/file-change", (changes) ->
|
71
|
+
Lanes.lib.HotReload.initiate(changes)
|
72
|
+
)
|
64
73
|
}
|
@@ -1,24 +1,32 @@
|
|
1
1
|
class Field extends Lanes.Models.Base
|
2
2
|
|
3
|
-
constructor: (attributes)->
|
3
|
+
constructor: (attributes) ->
|
4
4
|
super( _.defaults( attributes, {
|
5
|
-
title: _.titleize(attributes.id)
|
5
|
+
title: _.titleize(_.humanize(attributes.id))
|
6
6
|
}))
|
7
7
|
|
8
8
|
session:
|
9
9
|
id: 'string'
|
10
10
|
title: 'string'
|
11
|
+
visible: type: 'boolean', default: true
|
11
12
|
selected: 'boolean'
|
13
|
+
flex: type: 'number', default: 1
|
14
|
+
textAlign: type: 'string', default: 'left'
|
12
15
|
|
13
16
|
derived:
|
17
|
+
default_value: deps: ['id'], fn: ->
|
18
|
+
switch @model_field.type
|
19
|
+
when 'integer' then 0
|
20
|
+
else ''
|
14
21
|
model_field:
|
15
|
-
deps: ['id'], fn
|
22
|
+
deps: ['id'], fn: ->
|
16
23
|
this.collection.query.modelClass::_definition[@id]
|
17
24
|
type:
|
18
25
|
deps: ['model_field'], fn: ->
|
19
|
-
@model_field?.type
|
26
|
+
type = @model_field?.type || 'string'
|
27
|
+
if type == "code" then "string" else type
|
20
28
|
|
21
|
-
validValue: (value)->
|
29
|
+
validValue: (value) ->
|
22
30
|
if this.type == 'n'
|
23
31
|
! _.isNaN( parseFloat(value) )
|
24
32
|
else
|
@@ -27,17 +35,21 @@ class Field extends Lanes.Models.Base
|
|
27
35
|
|
28
36
|
class AvailableFields extends Lanes.Models.Collection
|
29
37
|
|
30
|
-
|
38
|
+
model: Field
|
39
|
+
|
40
|
+
constructor: (models, options) ->
|
31
41
|
@query = options.query
|
42
|
+
this.on('change', (changing) ->
|
43
|
+
return unless changing.selected
|
44
|
+
for model in @models
|
45
|
+
model.selected = false unless model == changing
|
46
|
+
)
|
32
47
|
super
|
33
|
-
|
34
|
-
model: Field
|
48
|
+
@visible = @subcollection(where: {visible: true})
|
35
49
|
|
36
50
|
|
37
51
|
class Operator extends Lanes.Models.Base
|
38
52
|
|
39
|
-
addStandardProperties: Lanes.emptyFn
|
40
|
-
|
41
53
|
session:
|
42
54
|
id: 'string'
|
43
55
|
name: 'string'
|
@@ -47,7 +59,7 @@ class Operator extends Lanes.Models.Base
|
|
47
59
|
|
48
60
|
derived:
|
49
61
|
valid:
|
50
|
-
deps: ['types','field']
|
62
|
+
deps: ['types', 'field']
|
51
63
|
fn: ->
|
52
64
|
!this.types || ( this.field && _.contains(this.types, this.field.type) )
|
53
65
|
|
@@ -60,11 +72,15 @@ class Operators extends Lanes.Models.Collection
|
|
60
72
|
this.add([
|
61
73
|
{ id: 'like', name: 'Starts With', types:['string'] }
|
62
74
|
{ id: 'eq', name: 'Equals' }
|
63
|
-
{ id: 'lt', name: 'Less Than', types:['integer','bigdec','number'] }
|
64
|
-
{ id: 'gt', name: 'More Than', types:['integer','bigdec','number'] }
|
75
|
+
{ id: 'lt', name: 'Less Than', types:['integer', 'bigdec', 'number'] }
|
76
|
+
{ id: 'gt', name: 'More Than', types:['integer', 'bigdec', 'number'] }
|
65
77
|
])
|
66
|
-
|
67
|
-
|
78
|
+
this.on('change', (changing) ->
|
79
|
+
return unless changing.selected
|
80
|
+
for model in @models
|
81
|
+
model.selected = false unless model == changing
|
82
|
+
)
|
83
|
+
setField: (field) ->
|
68
84
|
this.invoke('set', 'field', field)
|
69
85
|
selected = this.findWhere(selected: true)
|
70
86
|
if selected && !selected.valid
|
@@ -72,6 +88,7 @@ class Operators extends Lanes.Models.Collection
|
|
72
88
|
this.findWhere(valid:true).selected = true
|
73
89
|
|
74
90
|
|
91
|
+
|
75
92
|
class Clause extends Lanes.Models.Base
|
76
93
|
|
77
94
|
session:
|
@@ -85,39 +102,40 @@ class Clause extends Lanes.Models.Base
|
|
85
102
|
collection: AvailableFields, options: ->
|
86
103
|
query: this.collection.query
|
87
104
|
|
88
|
-
|
89
105
|
derived:
|
90
106
|
description:
|
91
|
-
deps: ['field','operator']
|
92
|
-
fn: -> "#{@field.title} #{@operator
|
107
|
+
deps: ['field', 'operator']
|
108
|
+
fn: -> "#{@field.title} #{@operator?.id}"
|
93
109
|
|
94
110
|
isValid:
|
95
111
|
deps: ['field', 'operator', 'value']
|
96
112
|
fn: -> this.field.validValue(@value)
|
97
113
|
|
98
|
-
|
114
|
+
query:
|
115
|
+
fn: -> @collection.query
|
116
|
+
|
117
|
+
constructor: (options) ->
|
99
118
|
super
|
100
119
|
this.fields.reset(options.available_fields.models)
|
101
120
|
@operators.field = @fields.first()
|
102
121
|
@fields.on('change:selected', this.setField, this)
|
103
122
|
@operators.on('change:selected', this.setOperator, this)
|
104
123
|
|
105
|
-
@fields.
|
124
|
+
@fields.findWhere(visible: true)?.selected = true
|
106
125
|
@operators.at(0).selected = true
|
107
126
|
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
this[type].get(val).selected=true
|
127
|
+
setFromView: (type, val) ->
|
128
|
+
if type == "fields" || type == "operators"
|
129
|
+
this[type].get(val).selected = true
|
112
130
|
else
|
113
131
|
super
|
114
132
|
|
115
|
-
setField: (field)->
|
133
|
+
setField: (field) ->
|
116
134
|
return unless field.selected
|
117
135
|
@operators.setField( field )
|
118
136
|
this.field = field
|
119
137
|
|
120
|
-
setOperator: (operator)->
|
138
|
+
setOperator: (operator) ->
|
121
139
|
return unless operator.selected
|
122
140
|
this.operator = operator
|
123
141
|
|
@@ -128,7 +146,7 @@ class Clause extends Lanes.Models.Base
|
|
128
146
|
param = {}
|
129
147
|
op = this.operator.id
|
130
148
|
value = this.get('value')
|
131
|
-
value +='%' if 'like' == op
|
149
|
+
value += '%' if 'like' == op
|
132
150
|
value = parseFloat(value) if @field.type == "n"
|
133
151
|
param[ this.field.id ] = if 'eq' == op then value else { op: op, value: value }
|
134
152
|
param
|
@@ -138,12 +156,11 @@ class Clauses extends Lanes.Models.Collection
|
|
138
156
|
|
139
157
|
model: Clause
|
140
158
|
|
141
|
-
initialize:(models,options)->
|
159
|
+
initialize:(models, options) ->
|
142
160
|
super
|
143
161
|
@query = options.query
|
144
162
|
@fields = options.query.fields
|
145
163
|
|
146
|
-
|
147
164
|
class Lanes.Models.Query extends Lanes.Models.Base
|
148
165
|
|
149
166
|
session:
|
@@ -151,44 +168,60 @@ class Lanes.Models.Query extends Lanes.Models.Base
|
|
151
168
|
clauses: 'collection'
|
152
169
|
modelClass: 'function'
|
153
170
|
initialField: 'state'
|
171
|
+
idIndex: 'number'
|
172
|
+
initialFieldIndex: 'number'
|
173
|
+
pageSize: 'number'
|
154
174
|
|
155
175
|
derived:
|
176
|
+
results:
|
177
|
+
fn: -> new Lanes.Models.QueryResults(this, pageSize: @pageSize)
|
156
178
|
collection_class:
|
157
179
|
deps:['modelClass'], fn: -> @modelClass?.Collection
|
158
180
|
url:
|
159
181
|
deps:['modelClass'], fn: -> @modelClass?::urlRoot()
|
160
182
|
|
161
|
-
constructor: (options={})->
|
183
|
+
constructor: (options = {}) ->
|
162
184
|
super
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
185
|
+
idName = @modelClass::idAttribute
|
186
|
+
@loadAssociations = options.loadAssociations
|
187
|
+
@fields = new AvailableFields([], query: this)
|
188
|
+
for col, i in options.fields
|
189
|
+
rec = if _.isObject(col) then col else { id: col }
|
190
|
+
@fields.add rec
|
191
|
+
@idIndex = i if rec.id == idName
|
192
|
+
unless @idIndex?
|
193
|
+
@idIndex = @fields.length
|
194
|
+
@fields.add(id: idName)
|
167
195
|
@clauses = new Clauses([], query: this )
|
168
|
-
this.listenTo(@clauses,'change remove reset', ->
|
196
|
+
this.listenTo(@clauses, 'change remove reset', ->
|
197
|
+
@results.reset()
|
169
198
|
this.trigger('change', arguments...)
|
170
199
|
)
|
171
|
-
|
200
|
+
if @initialFieldIndex
|
201
|
+
@initialField = this.fields.at(@initialFieldIndex)
|
202
|
+
@initialField ||= this.fields.findWhere(id: "code") ||
|
203
|
+
this.fields.findWhere(id: "visibleId") ||
|
204
|
+
this.fields.first()
|
172
205
|
this.addNewClause()
|
173
206
|
this
|
174
207
|
|
208
|
+
execute: ->
|
209
|
+
this.trigger('execute')
|
210
|
+
|
175
211
|
isValid: ->
|
176
212
|
! @clauses.findWhere( isValid: false )
|
177
213
|
|
178
|
-
|
214
|
+
loadModelWithAssociations: (model) ->
|
215
|
+
model.withAssociations(@loadAssociations...)
|
216
|
+
|
217
|
+
loadSingle: (code, options = {}) ->
|
179
218
|
options.query = {}
|
180
219
|
options.query[ @initialField.id ] = code
|
220
|
+
options.include = @loadAssociations
|
181
221
|
@modelClass.fetch(options)
|
182
222
|
|
183
223
|
defaultField: ->
|
184
224
|
@fields.findWhere( field: @initialField )
|
185
225
|
|
186
|
-
asParams: ->
|
187
|
-
params = {}
|
188
|
-
@clauses.each (clause)->
|
189
|
-
_.extend( params, clause.toParam() ) if clause.isValid
|
190
|
-
|
191
|
-
params
|
192
|
-
|
193
226
|
addNewClause: ->
|
194
|
-
@clauses.add(
|
227
|
+
@clauses.add(query: this, available_fields: @fields, field: @initialField)
|
@@ -0,0 +1,93 @@
|
|
1
|
+
class Page
|
2
|
+
|
3
|
+
constructor: (@pageNum, @result, options = {}) ->
|
4
|
+
query = {}
|
5
|
+
@rows = []
|
6
|
+
@result.query.clauses.each (clause) ->
|
7
|
+
_.extend( query, clause.toParam() ) if clause.isValid
|
8
|
+
options = {
|
9
|
+
format: 'array', total_count: 't'
|
10
|
+
start: @pageNum * @result.pageSize, limit: @result.pageSize,
|
11
|
+
query: query, url: @result.query.url,
|
12
|
+
fields: @result.query.fields.pluck('id')
|
13
|
+
}
|
14
|
+
|
15
|
+
Lanes.Models.Sync.perform('GET', options).then (resp) =>
|
16
|
+
@result.total = resp.total
|
17
|
+
@rows = resp.data
|
18
|
+
delete @pending
|
19
|
+
@result.onPageLoad(@)
|
20
|
+
|
21
|
+
# N.B. for convenience the index for the methods below is the absolute index for all results
|
22
|
+
# not the index just for this page. It's converted and the appropriate row returned
|
23
|
+
rowAt: (index) ->
|
24
|
+
index = index % @result.pageSize
|
25
|
+
@rows[index] || []
|
26
|
+
|
27
|
+
modelAt: (index) ->
|
28
|
+
row = @rowAt(index)
|
29
|
+
@modelCache ||= {}
|
30
|
+
@modelCache[ @idForRow(row)] ||= (
|
31
|
+
attrs = {}
|
32
|
+
for field, i in @result.query.fields.models
|
33
|
+
attrs[field.id] = row[i]
|
34
|
+
new @result.query.modelClass(attrs)
|
35
|
+
)
|
36
|
+
|
37
|
+
idForRow: (row) ->
|
38
|
+
row[@result.query.idIndex]
|
39
|
+
|
40
|
+
|
41
|
+
|
42
|
+
class Lanes.Models.QueryResults
|
43
|
+
|
44
|
+
constructor: (q, options = {}) ->
|
45
|
+
@cid = _.uniqueId()
|
46
|
+
@query = q
|
47
|
+
@pageSize = options.pageSize || 20
|
48
|
+
@pages = {}
|
49
|
+
|
50
|
+
reset: ->
|
51
|
+
@pages = {}
|
52
|
+
|
53
|
+
pageForIndex: (index) ->
|
54
|
+
pageNum = Math.floor(index / @pageSize)
|
55
|
+
@pages[pageNum] ||= new Page(pageNum, this)
|
56
|
+
|
57
|
+
rowAt: (index, options = {}) ->
|
58
|
+
row = @pageForIndex(index).rowAt(index)
|
59
|
+
if options.visibleOnly
|
60
|
+
@visibleIndexes ||= _.compact @query.fields.map (f, i) -> if f.visible then i else null
|
61
|
+
row[fieldIndex] for fieldIndex in @visibleIndexes
|
62
|
+
else
|
63
|
+
row
|
64
|
+
|
65
|
+
modelAt: (index) ->
|
66
|
+
@pageForIndex(index).modelAt(index)
|
67
|
+
|
68
|
+
|
69
|
+
saveModelChanges: (model) ->
|
70
|
+
page = @pageForIndex
|
71
|
+
@_calculateCache() unless @idCache
|
72
|
+
row = @idCache[model.id]
|
73
|
+
for field, i in @query.fields.models
|
74
|
+
row[i] = model[field.id]
|
75
|
+
model
|
76
|
+
|
77
|
+
addBlankRow: ->
|
78
|
+
model = new @query.modelClass()
|
79
|
+
row = []
|
80
|
+
for field, i in @query.fields.models
|
81
|
+
row[i] = model[field.id]
|
82
|
+
@rows.unshift row
|
83
|
+
|
84
|
+
ensureLoaded: ->
|
85
|
+
@pageForIndex(0) if _.isEmpty(@pages)
|
86
|
+
return null
|
87
|
+
|
88
|
+
onPageLoad: (page) ->
|
89
|
+
@query.trigger('load', @query)
|
90
|
+
|
91
|
+
|
92
|
+
Object.defineProperty Lanes.Models.QueryResults.prototype, 'length',
|
93
|
+
get: -> @total || 0
|
@@ -1,16 +1,16 @@
|
|
1
1
|
class CacheEntry
|
2
2
|
|
3
|
-
constructor: (@collection, @options, @key)->
|
3
|
+
constructor: (@collection, @options, @key) ->
|
4
4
|
@duration = Lanes.Vendor.Moment.duration(@collection.cacheDuration...)
|
5
|
-
_.bindAll(this,'setFromServer')
|
5
|
+
_.bindAll(this, 'setFromServer')
|
6
6
|
@successCallback = @options.success
|
7
7
|
@options.success = this.setFromServer
|
8
8
|
Lanes.Models.Sync.perform('read', this, @options)
|
9
9
|
|
10
10
|
url: ->
|
11
|
-
_.result(@collection,'url')
|
11
|
+
_.result(@collection, 'url')
|
12
12
|
|
13
|
-
setFromServer: (reply, status, req)->
|
13
|
+
setFromServer: (reply, status, req) ->
|
14
14
|
if reply?.data?
|
15
15
|
Lanes.Models.ServerCache.store(@key, reply.data, @duration.asMilliseconds())
|
16
16
|
@successCallback?.apply(@options.scope, arguments)
|
@@ -23,23 +23,23 @@ class CacheEntry
|
|
23
23
|
Lanes.Models.ServerCache = {
|
24
24
|
CACHE: {}
|
25
25
|
|
26
|
-
store: (key, data, ms)->
|
26
|
+
store: (key, data, ms) ->
|
27
27
|
this.CACHE[key] = data
|
28
28
|
setTimeout(->
|
29
29
|
delete Lanes.Models.ServerCache.CACHE[key]
|
30
30
|
, ms)
|
31
31
|
|
32
|
-
computeCacheKey: (collection, options)->
|
32
|
+
computeCacheKey: (collection, options) ->
|
33
33
|
url = _.result(collection, "url")
|
34
34
|
query = {}
|
35
35
|
for key, value of options
|
36
36
|
query[ Lanes.Models.Sync.paramsMap[key] ] = value if Lanes.Models.Sync.paramsMap[key]
|
37
|
-
url + Lanes
|
37
|
+
url + Lanes.lib.objToParam(query)
|
38
38
|
|
39
|
-
fetchRecord: (record, options)->
|
39
|
+
fetchRecord: (record, options) ->
|
40
40
|
key = record.urlRoot()
|
41
41
|
|
42
|
-
if data_set=this.CACHE[key]
|
42
|
+
if data_set = this.CACHE[key]
|
43
43
|
found = false
|
44
44
|
for data in data_set
|
45
45
|
if record.id == data.id
|
@@ -52,12 +52,12 @@ Lanes.Models.ServerCache = {
|
|
52
52
|
|
53
53
|
false
|
54
54
|
|
55
|
-
fetchCollection: (collection, options)->
|
55
|
+
fetchCollection: (collection, options) ->
|
56
56
|
key = this.computeCacheKey(collection, options)
|
57
57
|
if this.CACHE[key]
|
58
58
|
collection.setFromServer(this.CACHE[key], options)
|
59
|
-
options.success.call(options.scope, {data: this.CACHE[key]}, "sucess", {})
|
60
59
|
else
|
61
|
-
new CacheEntry(collection,options, key)
|
60
|
+
new CacheEntry(collection, options, key)
|
61
|
+
return _.Promise.resolve(collection)
|
62
62
|
|
63
63
|
}
|