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
@@ -0,0 +1,23 @@
|
|
1
|
+
_.mixin(
|
2
|
+
el: (name, attrs) ->
|
3
|
+
unless _.isObject(attrs)
|
4
|
+
attrs = {}
|
5
|
+
unless _.isString(attrs['class'])
|
6
|
+
attrs['class'] = ''
|
7
|
+
unless _.isString(attrs.id)
|
8
|
+
attrs.id = ''
|
9
|
+
class_pattern = /\.([\w\d-]+)/g
|
10
|
+
id_pattern = /\#([\w-\d]+)/g
|
11
|
+
(name.match(class_pattern) or []).forEach (clss) ->
|
12
|
+
attrs['class'] += ' ' + clss
|
13
|
+
return
|
14
|
+
(name.match(id_pattern) or []).forEach (id) ->
|
15
|
+
attrs.id += ' ' + id
|
16
|
+
return
|
17
|
+
name = name.replace(class_pattern, '').replace(id_pattern, '').trim()
|
18
|
+
node = _.dom document.createElement(name)
|
19
|
+
for name, value of attrs
|
20
|
+
node.setAttribute(name, value)
|
21
|
+
|
22
|
+
node.el
|
23
|
+
)
|
@@ -0,0 +1,16 @@
|
|
1
|
+
//= require ./noConflict
|
2
|
+
//= require ./namespace
|
3
|
+
//= require ./utilFunctions
|
4
|
+
//= require ./objToParam
|
5
|
+
//= require ./ModuleSupport
|
6
|
+
//= require ./loader
|
7
|
+
//= require ./MakeBaseClass
|
8
|
+
//= require ./el
|
9
|
+
//= require ./dom
|
10
|
+
//= require ./promise_helpers
|
11
|
+
//= require ./results
|
12
|
+
<% if Lanes.env.development?
|
13
|
+
require_asset "./development"
|
14
|
+
else
|
15
|
+
require_asset "./production"
|
16
|
+
end %>
|
@@ -4,10 +4,10 @@ GECKO = /Gecko\//.test(navigator.userAgent)
|
|
4
4
|
|
5
5
|
class Loader
|
6
6
|
|
7
|
-
constructor: (urls,cb)->
|
8
|
-
finished=0
|
7
|
+
constructor: (urls, cb) ->
|
8
|
+
finished = 0
|
9
9
|
completed = {}
|
10
|
-
onComplete = (url,success,error=false)->
|
10
|
+
onComplete = (url, success, error = false) ->
|
11
11
|
finished += 1
|
12
12
|
completed[url] = { success: success == true, error: error }
|
13
13
|
cb(completed) if finished == urls.length
|
@@ -15,28 +15,29 @@ class Loader
|
|
15
15
|
this.head = document.querySelector('head')
|
16
16
|
this.body = document.body
|
17
17
|
|
18
|
-
_.each(urls, (url)->
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
18
|
+
_.each(urls, (url) ->
|
19
|
+
url += "?#{parseInt(Math.random() * 100000)}"
|
20
|
+
if /.css($|\?)/.test(url)
|
21
|
+
this.loadCSS(url, onComplete)
|
22
|
+
else
|
23
|
+
this.loadJS(url, onComplete)
|
24
|
+
, this)
|
24
25
|
|
25
26
|
|
26
27
|
loadCSS: (url, fn) ->
|
27
28
|
getStylesheet = ->
|
28
|
-
|
29
|
-
|
30
|
-
|
29
|
+
Array::filter.call(document.styleSheets, (stylesheet) ->
|
30
|
+
stylesheet.ownerNode is node
|
31
|
+
).shift()
|
31
32
|
poll = ->
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
33
|
+
return if called
|
34
|
+
stylesheet = getStylesheet()
|
35
|
+
return setTimeout(poll, 250) if not stylesheet or not stylesheet.cssRules
|
36
|
+
return setTimeout(poll, 250) if not stylesheet or not stylesheet.rules or not stylesheet.rules.length
|
37
|
+
called = true
|
38
|
+
fn(url, true)
|
38
39
|
exists = Array::some.call(document.styleSheets, (stylesheet) ->
|
39
|
-
|
40
|
+
stylesheet.href is url
|
40
41
|
)
|
41
42
|
return fn(url, true) if exists
|
42
43
|
called = false
|
@@ -48,19 +49,19 @@ class Loader
|
|
48
49
|
rel: "stylesheet"
|
49
50
|
)
|
50
51
|
|
51
|
-
onloaded=(success,err)->
|
52
|
+
onloaded = (success, err) ->
|
52
53
|
return if called
|
53
54
|
called = true
|
54
55
|
fn(url, success, err)
|
55
|
-
node.onload =
|
56
|
-
node.onerror = (err)-> onloaded(false,err)
|
56
|
+
node.onload = -> onloaded(true, false)
|
57
|
+
node.onerror = (err) -> onloaded(false, err)
|
57
58
|
node.onreadystatechange = ->
|
58
59
|
return if not (/loaded|complete/.test(node.readyState)) or called
|
59
|
-
called=true
|
60
|
+
called = true
|
60
61
|
fn(url, true)
|
61
62
|
@head.appendChild node
|
62
63
|
# GECKO cannot query the node immediatly after it's created
|
63
|
-
if GECKO then _.delay(poll,250) else poll()
|
64
|
+
if GECKO then _.delay(poll, 250) else poll()
|
64
65
|
|
65
66
|
|
66
67
|
|
@@ -72,27 +73,26 @@ class Loader
|
|
72
73
|
charset: "utf-8"
|
73
74
|
async: false
|
74
75
|
)
|
75
|
-
onloaded=(success,err)->
|
76
|
+
onloaded = (success, err) ->
|
76
77
|
return if called
|
77
78
|
called = true
|
78
79
|
fn(url, success, err)
|
79
|
-
node.onload =
|
80
|
-
node.onerror = (err)-> onloaded(false,err)
|
81
|
-
|
80
|
+
node.onload = -> onloaded(true, false)
|
81
|
+
node.onerror = (err) -> onloaded(false, err)
|
82
82
|
node.onreadystatechange = ->
|
83
83
|
return if not (/loaded|complete/.test(node.readyState)) or called
|
84
84
|
called = true
|
85
|
-
fn(url,true)
|
85
|
+
fn(url, true)
|
86
86
|
this.body.appendChild(node)
|
87
87
|
|
88
88
|
|
89
|
-
Lanes.lib.RequestAssets = (urls...)->
|
89
|
+
Lanes.lib.RequestAssets = (urls...) ->
|
90
90
|
urls = urls[0] if urls.length == 1 && _.isArray(urls[0])
|
91
|
-
for url,i in urls
|
91
|
+
for url, i in urls
|
92
92
|
urls[i] = Lanes.config.assets_path_prefix.concat( '/', urls[i] )
|
93
|
-
new _.Promise( (resolve,reject)->
|
94
|
-
new Loader(urls, (completed)->
|
95
|
-
failures = _.pick(completed, (status,url)-> !status.success )
|
93
|
+
new _.Promise( (resolve, reject) ->
|
94
|
+
new Loader(urls, (completed) ->
|
95
|
+
failures = _.pick(completed, (status, url) -> !status.success )
|
96
96
|
if _.isEmpty(failures)
|
97
97
|
resolve(completed)
|
98
98
|
else
|
@@ -8,5 +8,5 @@ Lanes.namespace = (target, name, block) ->
|
|
8
8
|
target = target[item] or= {} for item in name.split '.'
|
9
9
|
block( target, top ) if typeof block == 'function'
|
10
10
|
|
11
|
-
for ns in ['Components', 'Models.Mixins', '
|
11
|
+
for ns in ['Components', 'Models.Mixins', 'React.Mixins', 'Screens.Mixins', 'Vendor', 'Templates', 'Extensions','lib']
|
12
12
|
Lanes.namespace(ns)
|
@@ -0,0 +1,37 @@
|
|
1
|
+
Lanes.lib.objToParam = (a) ->
|
2
|
+
add = (s, k, v) ->
|
3
|
+
v = if _.isFunction(v)
|
4
|
+
v()
|
5
|
+
else if v == null or v == undefined
|
6
|
+
''
|
7
|
+
else
|
8
|
+
v
|
9
|
+
s[s.length] = k + '=' + encodeURIComponent(v)
|
10
|
+
return
|
11
|
+
|
12
|
+
buildParams = (prefix, obj, s) ->
|
13
|
+
i = undefined
|
14
|
+
len = undefined
|
15
|
+
key = undefined
|
16
|
+
if _.isArray(obj)
|
17
|
+
i = 0
|
18
|
+
len = obj.length
|
19
|
+
while i < len
|
20
|
+
val = (if _.isObject(obj[i]) then i else '')
|
21
|
+
buildParams "#{prefix}[#{val}]", obj[i], s
|
22
|
+
i++
|
23
|
+
else if obj and _.isObject(obj)
|
24
|
+
for key, value of obj
|
25
|
+
if obj.hasOwnProperty(key)
|
26
|
+
if prefix
|
27
|
+
buildParams "#{prefix}[#{key}]", value, s, add
|
28
|
+
else
|
29
|
+
buildParams key, value, s, add
|
30
|
+
else if prefix
|
31
|
+
add s, prefix, obj
|
32
|
+
else
|
33
|
+
for key, value of obj
|
34
|
+
add(s, key, value)
|
35
|
+
s
|
36
|
+
|
37
|
+
buildParams('', a, []).join('&').replace /%20/g, '+'
|
File without changes
|
@@ -1,75 +1,91 @@
|
|
1
1
|
Lanes.emptyFn = ->
|
2
2
|
|
3
|
-
Lanes.fatal = (args...)->
|
3
|
+
Lanes.fatal = (args...) ->
|
4
4
|
Lanes.warn(args...)
|
5
5
|
throw new Error(args...)
|
6
6
|
|
7
|
-
Lanes.warn = (msg...)->
|
7
|
+
Lanes.warn = (msg...) ->
|
8
8
|
return unless console
|
9
9
|
if msg[0] instanceof Error
|
10
10
|
console.warn(msg[0].stack)
|
11
11
|
else console.warn(msg...)
|
12
12
|
null
|
13
13
|
|
14
|
-
Lanes.log = (msg...)->
|
14
|
+
Lanes.log = (msg...) ->
|
15
15
|
return unless console
|
16
16
|
if msg[0] instanceof Error
|
17
17
|
console.warn(msg[0].stack)
|
18
18
|
else console.log(msg...)
|
19
19
|
null
|
20
20
|
|
21
|
-
distillTypes = (type, ns)->
|
22
|
-
_.reduce( type.split( '.' ), ( ( memo, val )-> return if memo then memo[ val ] else null ), ns )
|
21
|
+
distillTypes = (type, ns) ->
|
22
|
+
_.reduce( type.split( '.' ), ( ( memo, val ) -> return if memo then memo[ val ] else null ), ns )
|
23
23
|
|
24
24
|
Lanes.u = {
|
25
25
|
|
26
|
-
|
26
|
+
objectForPath: (path) ->
|
27
|
+
parts = path.replace(/\.js$/, '').split('/')
|
28
|
+
last = null
|
29
|
+
_.reduce( parts, (memo, val) ->
|
30
|
+
last = memo[val] || memo[ _.classify(val) ] || last
|
31
|
+
, Lanes)
|
32
|
+
|
33
|
+
objectPath: (FILE) ->
|
27
34
|
FILE.path
|
28
35
|
|
29
|
-
path: (FILE)->
|
36
|
+
path: (FILE) ->
|
30
37
|
FILE.path.join("/")
|
31
38
|
|
32
|
-
dirname: (FILE)->
|
33
|
-
FILE.path[0...FILE.path.length-1].join("/")
|
39
|
+
dirname: (FILE) ->
|
40
|
+
FILE.path[0...FILE.path.length - 1].join("/")
|
34
41
|
|
35
|
-
findObject:(name, subPath, file=FILE) ->
|
42
|
+
findObject:(name, subPath, file = FILE) ->
|
36
43
|
if _.isObject(name)
|
37
44
|
name
|
38
45
|
else
|
39
46
|
file.namespace[subPath]?[name] || Lanes[subPath]?[name] || Lanes.u.getPath(name)
|
40
47
|
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
_.classify(comp);
|
48
|
+
findRelative: (name, file) ->
|
49
|
+
parts = _.map(file.path.slice(0, file.path.length - 1), (comp) ->
|
50
|
+
_.classify(comp)
|
45
51
|
)
|
46
|
-
obj = _.reduce( parts, ( ( memo, val )-> return if memo then memo[ val ] else null ), Lanes )
|
52
|
+
obj = _.reduce( parts, ( ( memo, val ) -> return if memo then memo[ val ] else null ), Lanes )
|
47
53
|
obj?[name]
|
48
54
|
|
49
55
|
# Can be called one of two ways:
|
50
56
|
# With ns being a string, which will attempt to deref it then deref name inside it
|
51
57
|
# or with ns being an object, which will dref name inside it
|
52
|
-
getPath: ( name, ns='Lanes' ) ->
|
58
|
+
getPath: ( name, ns = 'Lanes' ) ->
|
53
59
|
return name unless _.isString(name)
|
54
60
|
ns = "Lanes.#{ns}" if _.isString(ns) && !ns.match("Lanes")
|
55
61
|
object = distillTypes(name, window)
|
56
62
|
if ! object
|
57
|
-
ns=if _.isObject(ns) then ns else distillTypes(ns, window)
|
58
|
-
object=distillTypes(name, ns )
|
63
|
+
ns = if _.isObject(ns) then ns else distillTypes(ns, window)
|
64
|
+
object = distillTypes(name, ns )
|
59
65
|
object
|
60
66
|
|
61
67
|
# Like underscore's results but allows passing
|
62
68
|
# arguments to the function if it's called
|
63
|
-
resultsFor:( scope, method, args... )->
|
69
|
+
resultsFor:( scope, method, args... ) ->
|
64
70
|
if _.isString(method)
|
65
71
|
if _.isFunction(scope[method])
|
66
|
-
scope[method].apply(scope,args)
|
72
|
+
scope[method].apply(scope, args)
|
67
73
|
else
|
68
74
|
scope[method]
|
69
75
|
else if _.isFunction(method)
|
70
|
-
method.apply(scope,args)
|
76
|
+
method.apply(scope, args)
|
71
77
|
else
|
72
78
|
method
|
79
|
+
|
80
|
+
closestEl: (el, name) ->
|
81
|
+
# Traverse the DOM up with a while loop
|
82
|
+
while ! _.dom(el).hasClass(name)
|
83
|
+
# Increment the loop to the parent node
|
84
|
+
el = el.parentNode
|
85
|
+
return null unless el
|
86
|
+
|
87
|
+
return el
|
88
|
+
|
73
89
|
}
|
74
90
|
|
75
91
|
# Can be called one of two ways:
|
@@ -86,19 +102,21 @@ Lanes.u = {
|
|
86
102
|
# else
|
87
103
|
# file.namespace[subPath]?[name] || Lanes[subPath]?[name] || Lanes.getPath(name)
|
88
104
|
|
89
|
-
lcDash = (char, match, index)->
|
105
|
+
lcDash = (char, match, index) ->
|
90
106
|
return ( if index == 0 then '' else '_' ) + char.toLowerCase()
|
91
107
|
|
92
108
|
_.mixin({
|
93
|
-
dasherize: (str)->
|
94
|
-
_.trim(str).replace(/([A-Z])/g,lcDash).replace(/[-_\s]+/g, '-').toLowerCase()
|
109
|
+
dasherize: (str) ->
|
110
|
+
_.trim(str).replace(/([A-Z])/g, lcDash).replace(/[-_\s]+/g, '-').toLowerCase()
|
95
111
|
|
112
|
+
field2title: (field) ->
|
113
|
+
_.titleize _.humanize field
|
96
114
|
|
97
|
-
toSentence: (words=[], comma=', ', nd=' and ')->
|
115
|
+
toSentence: (words = [], comma = ', ', nd = ' and ') ->
|
98
116
|
last = words.pop()
|
99
117
|
if last
|
100
118
|
if words.length
|
101
|
-
[words.join(comma),last].join(nd)
|
119
|
+
[words.join(comma), last].join(nd)
|
102
120
|
else
|
103
121
|
last
|
104
122
|
else
|
@@ -4,101 +4,114 @@
|
|
4
4
|
# and contains utility functions to operate on them #
|
5
5
|
# ------------------------------------------------------------------ #
|
6
6
|
class Lanes.Models.AssocationMap
|
7
|
-
constructor: (@klass)->
|
7
|
+
constructor: (@klass) ->
|
8
8
|
@klass::derived ||= {}
|
9
9
|
@definitions = @klass::associations
|
10
10
|
@definitions['created_by'] ||= { model: 'Lanes.Models.User', readOnly: true }
|
11
11
|
@definitions['updated_by'] ||= { model: 'Lanes.Models.User', readOnly: true }
|
12
12
|
for name, options of @definitions
|
13
|
-
@klass::derived[name] = this.derivedDefinition(name,options)
|
13
|
+
@klass::derived[name] = this.derivedDefinition(name, options)
|
14
14
|
|
15
|
-
getClassFor: (name)->
|
15
|
+
getClassFor: (name) ->
|
16
16
|
definition = @definitions[name]
|
17
17
|
object = definition.model || definition.collection
|
18
18
|
Lanes.u.findObject(object, 'Models', @klass::FILE)
|
19
19
|
|
20
|
-
getOptions: (name, definition, model)->
|
20
|
+
getOptions: (name, definition, model) ->
|
21
21
|
options = { parent: model }
|
22
22
|
if definition.options
|
23
|
-
_.extend(options, Lanes.u.resultsFor(model,definition.options))
|
23
|
+
_.extend(options, Lanes.u.resultsFor(model, definition.options))
|
24
24
|
options
|
25
25
|
|
26
26
|
# will be called in the scope of the parent model
|
27
|
-
createModel: (association, name, definition, fk, pk, target_class)->
|
27
|
+
createModel: (association, name, definition, fk, pk, target_class) ->
|
28
28
|
target_class ||= association.getClassFor(name)
|
29
|
-
options = association.getOptions(name,definition,this)
|
29
|
+
options = association.getOptions(name, definition, this)
|
30
30
|
model_id = this.get(pk)
|
31
31
|
if model_id && model_id == this._cache[name]?.id
|
32
32
|
this._cache[name]
|
33
33
|
else
|
34
|
-
target_class
|
34
|
+
new target_class(options)
|
35
|
+
|
36
|
+
# returns a collection for the given association.
|
37
|
+
collectionFor: (name) ->
|
38
|
+
klass = @getClassFor(name)
|
39
|
+
if klass::isModel
|
40
|
+
klass.Collection
|
41
|
+
else
|
42
|
+
klass
|
43
|
+
|
35
44
|
|
36
45
|
# will be called in the scope of the parent model
|
37
|
-
createCollection: (association, name, definition, fk, pk, target_class)->
|
46
|
+
createCollection: (association, name, definition, fk, pk, target_class) ->
|
38
47
|
target_class ||= association.getClassFor(name)
|
39
|
-
options = association.getOptions(name,definition,this)
|
48
|
+
options = association.getOptions(name, definition, this)
|
40
49
|
options.filter ||= {}
|
41
|
-
options.filter[fk]=this.get(pk)
|
50
|
+
options.filter[fk] = this.get(pk)
|
42
51
|
|
43
52
|
if target_class::isCollection
|
44
|
-
new target_class(options.models||[],options)
|
53
|
+
new target_class(options.models || [], options)
|
45
54
|
else
|
46
|
-
options.model=target_class
|
47
|
-
new Lanes.Models.AssociationCollection(options.models||[],options)
|
55
|
+
options.model = target_class
|
56
|
+
new Lanes.Models.AssociationCollection(options. models || [], options)
|
48
57
|
# returns the definition for the derived property
|
49
|
-
derivedDefinition: (name,definition)->
|
50
|
-
defaultCreator=if definition.model then this.createModel else this.createCollection
|
58
|
+
derivedDefinition: (name, definition) ->
|
59
|
+
defaultCreator = if definition.model then this.createModel else this.createCollection
|
51
60
|
args = [ this, name, definition, this.fk(name), this.pk(name) ]
|
52
61
|
createFn = if definition.default
|
53
|
-
-> definition.default.apply(this,args) || defaultCreator.apply(this,args)
|
62
|
+
-> definition.default.apply(this, args) || defaultCreator.apply(this, args)
|
54
63
|
else
|
55
64
|
defaultCreator
|
56
65
|
{ deps: [this.pk(name)], fn: _.partial(createFn, args...) }
|
57
66
|
|
58
67
|
|
59
68
|
# Sets the assocations for "model"
|
60
|
-
set: (model, data)->
|
69
|
+
set: (model, data) ->
|
61
70
|
this._set(model, data, 'set')
|
71
|
+
for name, value of data
|
72
|
+
if @definitions[name] && value?.isModel && !value.isNew()
|
73
|
+
model[@pk(name)] = if value then value.getId() else null
|
62
74
|
|
63
|
-
setFromServer: (model, data)->
|
75
|
+
setFromServer: (model, data) ->
|
64
76
|
this._set(model, data, 'setFromServer')
|
65
77
|
|
66
|
-
_set: (model, data, fn_name)->
|
78
|
+
_set: (model, data, fn_name) ->
|
67
79
|
for name, value of data
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
association
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
80
|
+
continue unless @definitions[name]
|
81
|
+
association = model[name]
|
82
|
+
unless _.isObject(value)
|
83
|
+
association.clear()
|
84
|
+
continue
|
85
|
+
attributes = if _.isFunction(value.serialize) then value.serialize() else value
|
86
|
+
association[fn_name]( attributes )
|
87
|
+
# if we're replaceing the model's contents with another, copy the dirty status as well
|
88
|
+
if association.isModel
|
89
|
+
model.set(this.pk(name), association.id) unless association.isNew
|
90
|
+
association.isDirty = value.isDirty if value.isModel
|
76
91
|
|
77
|
-
pk: (name)->
|
92
|
+
pk: (name) ->
|
78
93
|
def = @definitions[name]
|
79
94
|
return null unless name
|
80
95
|
def.pk || ( if def.model then "#{name}_id" else "id" )
|
81
96
|
|
82
|
-
fk: (name)->
|
97
|
+
fk: (name) ->
|
83
98
|
def = @definitions[name]
|
84
99
|
return null unless name
|
85
100
|
def.fk || ( if def.model then "id" else "#{name}_id" )
|
86
101
|
|
87
102
|
# returns the data from all assocations for saving
|
88
|
-
dataForSave: (model,options)->
|
103
|
+
dataForSave: (model, options) ->
|
89
104
|
ret = {}
|
90
|
-
options.saveDepth = ( if options.saveDepth then options.saveDepth+1 else 1 )
|
105
|
+
options.saveDepth = ( if options.saveDepth then options.saveDepth + 1 else 1 )
|
91
106
|
return ret if options.saveDepth > 5
|
92
107
|
for name, options of @definitions
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
ret[name] = data
|
97
|
-
|
108
|
+
break if options.readOnly
|
109
|
+
assoc = model[name]
|
110
|
+
ret[name] = assoc.dataForSave(options) if _.result(assoc, 'isDirty')
|
98
111
|
ret
|
99
112
|
|
100
113
|
# return a list of assocations from "name" that are not loaded
|
101
|
-
nonLoaded: (model, names)->
|
114
|
+
nonLoaded: (model, names) ->
|
102
115
|
list = []
|
103
116
|
for name in names
|
104
117
|
if _.has(@definitions, name) && model[name].isNew()
|