@angular-wave/angular.ts 0.9.4 → 0.9.6
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.
- package/@types/index.d.ts +1 -84
- package/{src/index.ts → @types/namespace.d.ts} +4 -24
- package/@types/router/template-factory.d.ts +2 -2
- package/dist/angular-ts.esm.js +3 -3
- package/dist/angular-ts.umd.js +3 -3
- package/dist/angular-ts.umd.min.js +1 -1
- package/package.json +9 -2
- package/.github/workflows/ci.yml +0 -104
- package/.github/workflows/gh-pages.yml +0 -75
- package/.husky/pre-commit +0 -5
- package/.prettierignore +0 -9
- package/CHANGELOG.md +0 -17667
- package/CODE_OF_CONDUCT.md +0 -3
- package/CONTRIBUTING.md +0 -247
- package/DEVELOPERS.md +0 -499
- package/Makefile +0 -60
- package/RELEASE.md +0 -86
- package/TRIAGING.md +0 -127
- package/docs/.cspell.yml +0 -8
- package/docs/.github/dependabot.yml +0 -14
- package/docs/.nvmrc +0 -1
- package/docs/CONTRIBUTING.md +0 -28
- package/docs/Dockerfile +0 -4
- package/docs/LICENSE +0 -201
- package/docs/README.md +0 -217
- package/docs/assets/icons/logo.svg +0 -1
- package/docs/assets/scss/_variables_project.scss +0 -12
- package/docs/assets/scss/_variables_project_after_bs.scss +0 -8
- package/docs/assets/scss/index.scss +0 -48
- package/docs/config.yaml +0 -15
- package/docs/content/_index.md +0 -28
- package/docs/content/docs/_index.md +0 -61
- package/docs/content/docs/directive/_index.md +0 -4
- package/docs/content/docs/directive/app.md +0 -11
- package/docs/content/docs/directive/aria.md +0 -0
- package/docs/content/docs/directive/bind.md +0 -72
- package/docs/content/docs/directive/blur.md +0 -38
- package/docs/content/docs/directive/channel.md +0 -37
- package/docs/content/docs/directive/class-even.md +0 -47
- package/docs/content/docs/directive/class-odd.md +0 -48
- package/docs/content/docs/directive/class.md +0 -64
- package/docs/content/docs/directive/click.md +0 -41
- package/docs/content/docs/directive/cloak.md +0 -74
- package/docs/content/docs/directive/copy.md +0 -38
- package/docs/content/docs/directive/cut.md +0 -40
- package/docs/content/docs/directive/dblclick.md +0 -41
- package/docs/content/docs/directive/focus.md +0 -38
- package/docs/content/docs/directive/get.md +0 -203
- package/docs/content/docs/directive/include.md +0 -7
- package/docs/content/docs/directive/keydown.md +0 -38
- package/docs/content/docs/directive/keyup.md +0 -38
- package/docs/content/docs/directive/load.md +0 -43
- package/docs/content/docs/directive/mousedown.md +0 -38
- package/docs/content/docs/directive/mouseenter.md +0 -38
- package/docs/content/docs/directive/mouseleave.md +0 -38
- package/docs/content/docs/directive/mousemove.md +0 -38
- package/docs/content/docs/directive/mouseout.md +0 -38
- package/docs/content/docs/directive/mouseover.md +0 -38
- package/docs/content/docs/directive/mouseup.md +0 -38
- package/docs/content/docs/directive/non-bindable.md +0 -28
- package/docs/content/docs/filter/_index.md +0 -4
- package/docs/content/docs/filter/filter.md +0 -78
- package/docs/content/docs/filter/json.md +0 -19
- package/docs/content/docs/filter/limit-to.md +0 -30
- package/docs/content/docs/filter/order-by.md +0 -123
- package/docs/content/docs/provider/_index.md +0 -4
- package/docs/content/docs/provider/eventBusProvider.md +0 -35
- package/docs/content/docs/provider/locationProvider.md +0 -26
- package/docs/content/docs/provider/logProvider.md +0 -59
- package/docs/content/docs/provider/sceProvider.md +0 -194
- package/docs/content/docs/provider/templateCacheProvider.md +0 -100
- package/docs/content/docs/provider/templateRequestProvider.md +0 -5
- package/docs/content/docs/service/_index.md +0 -4
- package/docs/content/docs/service/compile.md +0 -5
- package/docs/content/docs/service/controller.md +0 -5
- package/docs/content/docs/service/eventBus.md +0 -56
- package/docs/content/docs/service/http.md +0 -161
- package/docs/content/docs/service/interpolation.md +0 -5
- package/docs/content/docs/service/location.md +0 -57
- package/docs/content/docs/service/log.md +0 -113
- package/docs/content/docs/service/parse.md +0 -5
- package/docs/content/docs/service/rootElement.md +0 -5
- package/docs/content/docs/service/rootScope.md +0 -5
- package/docs/content/docs/service/sce.md +0 -194
- package/docs/content/docs/service/templateCache.md +0 -64
- package/docs/content/docs/service/templateRequest.md +0 -5
- package/docs/content/docs/service/url.md +0 -5
- package/docs/content/docs/values/_index.md +0 -4
- package/docs/content/docs/values/document.md +0 -29
- package/docs/content/docs/values/window.md +0 -29
- package/docs/docker-compose.yaml +0 -12
- package/docs/docsy.work +0 -5
- package/docs/docsy.work.sum +0 -0
- package/docs/go.mod +0 -5
- package/docs/go.sum +0 -6
- package/docs/hugo-disabled.toml +0 -220
- package/docs/hugo.yaml +0 -200
- package/docs/layouts/404.html +0 -13
- package/docs/layouts/_markup/render-heading.html +0 -1
- package/docs/layouts/partials/hooks/head-end.html +0 -3
- package/docs/layouts/shortcodes/showcss.html +0 -2
- package/docs/layouts/shortcodes/showhtml.html +0 -2
- package/docs/layouts/shortcodes/showjs.html +0 -2
- package/docs/layouts/shortcodes/showraw.html +0 -1
- package/docs/layouts/shortcodes/version.html +0 -1
- package/docs/package-lock.json +0 -2293
- package/docs/package.json +0 -53
- package/docs/static/examples/counter/counter-test.html +0 -13
- package/docs/static/examples/counter/counter.html +0 -5
- package/docs/static/examples/counter/counter.test.js +0 -28
- package/docs/static/examples/document/document.html +0 -3
- package/docs/static/examples/eventbus/eventbus-test.html +0 -15
- package/docs/static/examples/eventbus/eventbus.html +0 -13
- package/docs/static/examples/eventbus/eventbus.js +0 -15
- package/docs/static/examples/eventbus/eventbus.test.js +0 -19
- package/docs/static/examples/i18n/i18n.html +0 -77
- package/docs/static/examples/ng-bind/ng-bind.html +0 -9
- package/docs/static/examples/ng-blur/ng-blur.html +0 -9
- package/docs/static/examples/ng-channel/ng-channel-test.html +0 -17
- package/docs/static/examples/ng-channel/ng-channel.html +0 -24
- package/docs/static/examples/ng-channel/ng-channel.test.js +0 -31
- package/docs/static/examples/ng-class/ng-class.html +0 -71
- package/docs/static/examples/ng-class-even/ng-class-even.html +0 -8
- package/docs/static/examples/ng-class-odd/ng-class-odd.html +0 -8
- package/docs/static/examples/ng-click/ng-click.html +0 -6
- package/docs/static/examples/ng-copy/ng-copy.html +0 -6
- package/docs/static/examples/ng-cut/ng-cut.html +0 -6
- package/docs/static/examples/ng-dblclick/ng-dblclick.html +0 -10
- package/docs/static/examples/ng-focus/ng-focus.html +0 -9
- package/docs/static/examples/ng-keydown/ng-keydown.html +0 -9
- package/docs/static/examples/ng-keyup/ng-keyup.html +0 -9
- package/docs/static/examples/ng-load/ng-load.html +0 -8
- package/docs/static/examples/ng-mousedown/ng-mousedown.html +0 -6
- package/docs/static/examples/ng-mouseenter/ng-mouseenter.html +0 -4
- package/docs/static/examples/ng-mouseleave/ng-mouseleave.html +0 -4
- package/docs/static/examples/ng-mousemove/ng-mousemove.html +0 -4
- package/docs/static/examples/ng-mouseout/ng-mouseout.html +0 -4
- package/docs/static/examples/ng-mouseover/ng-mouseover.html +0 -4
- package/docs/static/examples/ng-mouseup/ng-mouseup.html +0 -4
- package/docs/static/examples/ng-non-bindable/ng-non-bindable-test.html +0 -13
- package/docs/static/examples/ng-non-bindable/ng-non-bindable.html +0 -3
- package/docs/static/examples/ng-non-bindable/ng-non-bindable.test.js +0 -11
- package/docs/static/examples/window/window.html +0 -4
- package/docs/static/typedoc/.nojekyll +0 -1
- package/docs/static/typedoc/assets/hierarchy.js +0 -1
- package/docs/static/typedoc/assets/highlight.css +0 -29
- package/docs/static/typedoc/assets/icons.js +0 -18
- package/docs/static/typedoc/assets/icons.svg +0 -1
- package/docs/static/typedoc/assets/main.js +0 -60
- package/docs/static/typedoc/assets/navigation.js +0 -1
- package/docs/static/typedoc/assets/search.js +0 -1
- package/docs/static/typedoc/assets/style.css +0 -1633
- package/docs/static/typedoc/classes/Location.html +0 -55
- package/docs/static/typedoc/classes/LocationProvider.html +0 -20
- package/docs/static/typedoc/classes/LogProvider.html +0 -6
- package/docs/static/typedoc/classes/PubSub.html +0 -71
- package/docs/static/typedoc/classes/PubSubProvider.html +0 -4
- package/docs/static/typedoc/classes/TemplateCacheProvider.html +0 -5
- package/docs/static/typedoc/hierarchy.html +0 -1
- package/docs/static/typedoc/index.html +0 -1
- package/docs/static/typedoc/interfaces/DefaultPorts.html +0 -5
- package/docs/static/typedoc/interfaces/Html5Mode.html +0 -23
- package/docs/static/typedoc/interfaces/HttpHeadersGetter.html +0 -1
- package/docs/static/typedoc/interfaces/HttpProviderDefaults.html +0 -31
- package/docs/static/typedoc/interfaces/HttpRequestConfigHeaders.html +0 -6
- package/docs/static/typedoc/interfaces/HttpRequestTransformer.html +0 -1
- package/docs/static/typedoc/interfaces/HttpResponse.html +0 -7
- package/docs/static/typedoc/interfaces/HttpResponseTransformer.html +0 -1
- package/docs/static/typedoc/interfaces/HttpService.html +0 -38
- package/docs/static/typedoc/interfaces/LogService.html +0 -12
- package/docs/static/typedoc/interfaces/RequestConfig.html +0 -48
- package/docs/static/typedoc/interfaces/RequestShortcutConfig.html +0 -38
- package/docs/static/typedoc/interfaces/ServiceProvider.html +0 -5
- package/docs/static/typedoc/interfaces/UrlParts.html +0 -9
- package/docs/static/typedoc/types/HttpParamSerializer.html +0 -2
- package/docs/static/typedoc/types/HttpParams.html +0 -2
- package/docs/static/typedoc/types/HttpPromise.html +0 -1
- package/docs/static/typedoc/types/HttpResponseStatus.html +0 -1
- package/docs/static/typedoc/types/LogCall.html +0 -2
- package/docs/static/typedoc/types/LogServiceFactory.html +0 -2
- package/docs/static/typedoc/types/UrlChangeListener.html +0 -5
- package/docs/static/typedoc/variables/EventBus.html +0 -1
- package/docs/static/version.js +0 -13
- package/docs/test-results/.last-run.json +0 -4
- package/docs/test-results/static-examples-counter-counter-counter-example/error-context.md +0 -50
- package/eslint.config.js +0 -26
- package/images/android-chrome-192x192.png +0 -0
- package/images/android-chrome-512x512.png +0 -0
- package/images/apple-touch-icon.png +0 -0
- package/images/favicon-16x16.png +0 -0
- package/images/favicon-32x32.png +0 -0
- package/images/favicon.ico +0 -0
- package/images/site.webmanifest +0 -19
- package/index.html +0 -86
- package/legacy.d.ts +0 -1678
- package/playwright.config.ts +0 -81
- package/public/jasmine/boot0.js +0 -66
- package/public/jasmine/boot1.js +0 -134
- package/public/jasmine/jasmine-html.js +0 -970
- package/public/jasmine/jasmine.css +0 -323
- package/public/jasmine/jasmine.js +0 -11406
- package/public/public/README.md +0 -1
- package/public/public/circle.html +0 -1
- package/public/public/jasmine-helper.css +0 -9
- package/public/public/my_child_directive.html +0 -1
- package/public/public/my_directive.html +0 -1
- package/public/public/my_other_directive.html +0 -1
- package/public/public/test.html +0 -1
- package/rollup.config.js +0 -51
- package/src/angular.js +0 -286
- package/src/angular.spec.js +0 -1191
- package/src/animations/animate-cache.js +0 -80
- package/src/animations/animate-children-directive.js +0 -32
- package/src/animations/animate-children-directive.md +0 -80
- package/src/animations/animate-css-driver.js +0 -284
- package/src/animations/animate-css.html +0 -58
- package/src/animations/animate-css.js +0 -915
- package/src/animations/animate-css.md +0 -263
- package/src/animations/animate-js-driver.js +0 -60
- package/src/animations/animate-js.html +0 -47
- package/src/animations/animate-js.js +0 -371
- package/src/animations/animate-queue.js +0 -859
- package/src/animations/animate-runner.js +0 -193
- package/src/animations/animate-swap.js +0 -33
- package/src/animations/animate-swap.md +0 -88
- package/src/animations/animate.html +0 -19
- package/src/animations/animate.js +0 -546
- package/src/animations/animate.md +0 -933
- package/src/animations/animate.spec.js +0 -490
- package/src/animations/animation.js +0 -519
- package/src/animations/animations.test.js +0 -10
- package/src/animations/interface.ts +0 -19
- package/src/animations/raf-scheduler.html +0 -19
- package/src/animations/raf-scheduler.js +0 -92
- package/src/animations/raf-scheduler.spec.js +0 -98
- package/src/animations/shared.js +0 -341
- package/src/binding.html +0 -19
- package/src/binding.spec.js +0 -474
- package/src/binding.test.js +0 -10
- package/src/core/compile/attributes.js +0 -337
- package/src/core/compile/compile.html +0 -19
- package/src/core/compile/compile.js +0 -3271
- package/src/core/compile/compile.md +0 -1128
- package/src/core/compile/compile.spec.js +0 -15574
- package/src/core/compile/compile.test.js +0 -12
- package/src/core/controller/controller.html +0 -22
- package/src/core/controller/controller.js +0 -193
- package/src/core/controller/controller.spec.js +0 -334
- package/src/core/controller/controller.test.js +0 -12
- package/src/core/controller/interface.ts +0 -6
- package/src/core/core.html +0 -20
- package/src/core/core.test.js +0 -12
- package/src/core/di/injector.html +0 -19
- package/src/core/di/injector.js +0 -307
- package/src/core/di/injector.md +0 -740
- package/src/core/di/injector.spec.js +0 -2310
- package/src/core/di/injector.test.js +0 -12
- package/src/core/di/internal-injector.js +0 -286
- package/src/core/di/ng-module.html +0 -19
- package/src/core/di/ng-module.js +0 -229
- package/src/core/di/ng-module.spec.js +0 -263
- package/src/core/di/ng-module.test.js +0 -12
- package/src/core/filter/filter.html +0 -19
- package/src/core/filter/filter.js +0 -55
- package/src/core/filter/filter.md +0 -132
- package/src/core/filter/filter.spec.js +0 -149
- package/src/core/filter/filter.test.js +0 -12
- package/src/core/interpolate/interface.ts +0 -14
- package/src/core/interpolate/interpolate.html +0 -22
- package/src/core/interpolate/interpolate.js +0 -410
- package/src/core/interpolate/interpolate.spec.js +0 -601
- package/src/core/interpolate/interpolate.test.js +0 -12
- package/src/core/parse/ast/ast-node.ts +0 -81
- package/src/core/parse/ast/ast.html +0 -19
- package/src/core/parse/ast/ast.js +0 -574
- package/src/core/parse/ast/ast.spec.js +0 -1453
- package/src/core/parse/ast/ast.test.js +0 -10
- package/src/core/parse/ast-type.js +0 -23
- package/src/core/parse/interface.ts +0 -84
- package/src/core/parse/interpreter.js +0 -915
- package/src/core/parse/lexer/lexer.html +0 -19
- package/src/core/parse/lexer/lexer.js +0 -338
- package/src/core/parse/lexer/lexer.spec.js +0 -303
- package/src/core/parse/lexer/lexer.test.js +0 -10
- package/src/core/parse/lexer/token.ts +0 -22
- package/src/core/parse/parse.html +0 -19
- package/src/core/parse/parse.js +0 -337
- package/src/core/parse/parse.md +0 -57
- package/src/core/parse/parse.spec.js +0 -2107
- package/src/core/parse/parse.test.js +0 -10
- package/src/core/parse/parser/parser.html +0 -19
- package/src/core/parse/parser/parser.js +0 -64
- package/src/core/parse/parser/parser.spec.js +0 -8
- package/src/core/parse/parser/parser.test.js +0 -10
- package/src/core/prop.spec.js +0 -775
- package/src/core/root-element.spec.js +0 -14
- package/src/core/sanitize/interface.ts +0 -10
- package/src/core/sanitize/sanitize-uri.js +0 -75
- package/src/core/sanitize/sanitize-uri.spec.js +0 -249
- package/src/core/sanitize/sanitize-uri.test.js +0 -12
- package/src/core/sanitize/sanitize.html +0 -22
- package/src/core/scope/scope.html +0 -19
- package/src/core/scope/scope.js +0 -1252
- package/src/core/scope/scope.spec.js +0 -3000
- package/src/core/scope/scope.test.js +0 -12
- package/src/directive/aria/aria.html +0 -19
- package/src/directive/aria/aria.js +0 -382
- package/src/directive/aria/aria.md +0 -145
- package/src/directive/aria/aria.spec.js +0 -1241
- package/src/directive/aria/aria.test.js +0 -12
- package/src/directive/attrs/attrs.html +0 -19
- package/src/directive/attrs/attrs.js +0 -106
- package/src/directive/attrs/attrs.md +0 -224
- package/src/directive/attrs/attrs.spec.js +0 -71
- package/src/directive/attrs/attrs.test.js +0 -12
- package/src/directive/attrs/boolean.html +0 -19
- package/src/directive/attrs/boolean.spec.js +0 -137
- package/src/directive/attrs/boolean.test.js +0 -12
- package/src/directive/attrs/element-style.html +0 -22
- package/src/directive/attrs/element-style.spec.js +0 -85
- package/src/directive/attrs/element-style.test.js +0 -12
- package/src/directive/attrs/src.html +0 -19
- package/src/directive/attrs/src.spec.js +0 -163
- package/src/directive/attrs/src.test.js +0 -12
- package/src/directive/bind/bind-html.spec.js +0 -36
- package/src/directive/bind/bind.html +0 -20
- package/src/directive/bind/bind.js +0 -78
- package/src/directive/bind/bind.md +0 -142
- package/src/directive/bind/bind.spec.js +0 -314
- package/src/directive/bind/bind.test.js +0 -12
- package/src/directive/channel/channel.html +0 -19
- package/src/directive/channel/channel.js +0 -30
- package/src/directive/channel/channel.spec.js +0 -67
- package/src/directive/channel/channel.test.js +0 -10
- package/src/directive/class/class-test.html +0 -23
- package/src/directive/class/class.html +0 -19
- package/src/directive/class/class.js +0 -184
- package/src/directive/class/class.spec.js +0 -704
- package/src/directive/class/class.test.js +0 -12
- package/src/directive/cloak/cloak.html +0 -19
- package/src/directive/cloak/cloak.js +0 -11
- package/src/directive/cloak/cloak.spec.js +0 -44
- package/src/directive/cloak/cloak.test.js +0 -12
- package/src/directive/controller/controller.html +0 -22
- package/src/directive/controller/controller.js +0 -11
- package/src/directive/controller/controller.md +0 -46
- package/src/directive/controller/controller.spec.js +0 -175
- package/src/directive/controller/controller.test.js +0 -12
- package/src/directive/events/click.spec.js +0 -35
- package/src/directive/events/event.spec.js +0 -267
- package/src/directive/events/events-test.html +0 -36
- package/src/directive/events/events.html +0 -20
- package/src/directive/events/events.js +0 -65
- package/src/directive/events/events.md +0 -125
- package/src/directive/events/events.test.js +0 -12
- package/src/directive/form/form.html +0 -19
- package/src/directive/form/form.js +0 -669
- package/src/directive/form/form.spec.js +0 -1515
- package/src/directive/form/form.test.js +0 -12
- package/src/directive/http/delete.spec.js +0 -23
- package/src/directive/http/form-router-test.html +0 -44
- package/src/directive/http/form-test.html +0 -18
- package/src/directive/http/get.spec.js +0 -488
- package/src/directive/http/http.html +0 -22
- package/src/directive/http/http.js +0 -342
- package/src/directive/http/http.test.js +0 -12
- package/src/directive/http/interface.ts +0 -36
- package/src/directive/http/post-example.html +0 -30
- package/src/directive/http/post.spec.js +0 -521
- package/src/directive/http/put.spec.js +0 -23
- package/src/directive/if/if-animate-css.html +0 -57
- package/src/directive/if/if-animate-svg.html +0 -25
- package/src/directive/if/if.html +0 -19
- package/src/directive/if/if.js +0 -72
- package/src/directive/if/if.md +0 -76
- package/src/directive/if/if.spec.js +0 -293
- package/src/directive/if/if.test.js +0 -114
- package/src/directive/include/include.html +0 -19
- package/src/directive/include/include.js +0 -151
- package/src/directive/include/include.md +0 -87
- package/src/directive/include/include.spec.js +0 -734
- package/src/directive/include/include.test.js +0 -12
- package/src/directive/init/init.html +0 -19
- package/src/directive/init/init.js +0 -22
- package/src/directive/init/init.md +0 -41
- package/src/directive/init/init.spec.js +0 -68
- package/src/directive/init/init.test.js +0 -12
- package/src/directive/inject/inject.html +0 -19
- package/src/directive/inject/inject.js +0 -35
- package/src/directive/inject/inject.spec.js +0 -108
- package/src/directive/inject/inject.test.js +0 -12
- package/src/directive/input/input-example.html +0 -15
- package/src/directive/input/input.html +0 -19
- package/src/directive/input/input.js +0 -1078
- package/src/directive/input/input.md +0 -706
- package/src/directive/input/input.spec.js +0 -3700
- package/src/directive/input/input.test.js +0 -12
- package/src/directive/messages/messages.html +0 -22
- package/src/directive/messages/messages.js +0 -349
- package/src/directive/messages/messages.md +0 -543
- package/src/directive/messages/messages.spec.js +0 -1083
- package/src/directive/messages/messages.test.js +0 -12
- package/src/directive/model/change.md +0 -25
- package/src/directive/model/model.html +0 -19
- package/src/directive/model/model.js +0 -1170
- package/src/directive/model/model.spec.js +0 -1976
- package/src/directive/model/model.test.js +0 -12
- package/src/directive/model-options/model-option.test.js +0 -12
- package/src/directive/model-options/model-options.html +0 -22
- package/src/directive/model-options/model-options.js +0 -142
- package/src/directive/model-options/model-options.md +0 -407
- package/src/directive/model-options/model-options.spec.js +0 -1022
- package/src/directive/non-bindable/non-bindable.html +0 -22
- package/src/directive/non-bindable/non-bindable.js +0 -9
- package/src/directive/non-bindable/non-bindable.spec.js +0 -59
- package/src/directive/non-bindable/non-bindable.test.js +0 -12
- package/src/directive/observe/observe-demo.html +0 -184
- package/src/directive/observe/observe.html +0 -19
- package/src/directive/observe/observe.js +0 -41
- package/src/directive/observe/observe.spec.js +0 -106
- package/src/directive/observe/observe.test.js +0 -10
- package/src/directive/on/on.html +0 -19
- package/src/directive/on/on.spec.js +0 -215
- package/src/directive/on/on.test.js +0 -12
- package/src/directive/options/options-example.html +0 -17
- package/src/directive/options/options.html +0 -22
- package/src/directive/options/options.js +0 -542
- package/src/directive/options/options.md +0 -179
- package/src/directive/options/options.spec.js +0 -3554
- package/src/directive/options/options.test.js +0 -12
- package/src/directive/ref/href.html +0 -19
- package/src/directive/ref/href.spec.js +0 -141
- package/src/directive/ref/href.test.js +0 -19
- package/src/directive/ref/ref.html +0 -19
- package/src/directive/ref/ref.js +0 -89
- package/src/directive/ref/ref.spec.js +0 -546
- package/src/directive/repeat/repeat.html +0 -19
- package/src/directive/repeat/repeat.js +0 -333
- package/src/directive/repeat/repeat.md +0 -330
- package/src/directive/repeat/repeat.spec.js +0 -1209
- package/src/directive/repeat/repeat.test.js +0 -12
- package/src/directive/script/script.html +0 -19
- package/src/directive/script/script.js +0 -17
- package/src/directive/script/script.md +0 -11
- package/src/directive/script/script.spec.js +0 -47
- package/src/directive/script/script.test.js +0 -12
- package/src/directive/select/select.html +0 -19
- package/src/directive/select/select.js +0 -594
- package/src/directive/select/select.md +0 -74
- package/src/directive/select/select.spec.js +0 -2566
- package/src/directive/select/select.test.js +0 -12
- package/src/directive/setter/setter.html +0 -19
- package/src/directive/setter/setter.js +0 -59
- package/src/directive/setter/setter.spec.js +0 -100
- package/src/directive/setter/setter.test.js +0 -12
- package/src/directive/show-hide/show-hide.html +0 -22
- package/src/directive/show-hide/show-hide.js +0 -65
- package/src/directive/show-hide/show-hide.md +0 -255
- package/src/directive/show-hide/show-hide.spec.js +0 -268
- package/src/directive/show-hide/show-hide.test.js +0 -12
- package/src/directive/style/style.html +0 -19
- package/src/directive/style/style.js +0 -27
- package/src/directive/style/style.md +0 -23
- package/src/directive/style/style.spec.js +0 -183
- package/src/directive/style/style.test.js +0 -12
- package/src/directive/switch/switch.html +0 -19
- package/src/directive/switch/switch.js +0 -133
- package/src/directive/switch/switch.md +0 -66
- package/src/directive/switch/switch.spec.js +0 -509
- package/src/directive/switch/switch.test.js +0 -12
- package/src/directive/transclude/transclude.js +0 -122
- package/src/directive/validators/validators.html +0 -22
- package/src/directive/validators/validators.js +0 -346
- package/src/directive/validators/validators.spec.js +0 -740
- package/src/directive/validators/validators.test.js +0 -12
- package/src/filters/filter.js +0 -213
- package/src/filters/filter.spec.js +0 -719
- package/src/filters/filters.html +0 -22
- package/src/filters/filters.js +0 -239
- package/src/filters/filters.spec.js +0 -36
- package/src/filters/filters.test.js +0 -12
- package/src/filters/interface.ts +0 -9
- package/src/filters/limit-to.js +0 -55
- package/src/filters/limit-to.spec.js +0 -252
- package/src/filters/order-by.js +0 -181
- package/src/filters/order-by.spec.js +0 -883
- package/src/index.js +0 -6
- package/src/index.spec.js +0 -11
- package/src/injection-tokens.js +0 -81
- package/src/interface.ts +0 -430
- package/src/ng.js +0 -291
- package/src/ng.spec.js +0 -45
- package/src/router/common/trace.js +0 -240
- package/src/router/directives/component-example.html +0 -37
- package/src/router/directives/state-directives.html +0 -22
- package/src/router/directives/state-directives.js +0 -393
- package/src/router/directives/state-directives.md +0 -435
- package/src/router/directives/state-directives.spec.js +0 -1091
- package/src/router/directives/state-directives.test.js +0 -10
- package/src/router/directives/view-directive.js +0 -489
- package/src/router/directives/view-directive.spec.js +0 -1921
- package/src/router/directives/view-directive.test.js +0 -10
- package/src/router/directives/view-directives.html +0 -22
- package/src/router/glob/glob.html +0 -19
- package/src/router/glob/glob.js +0 -102
- package/src/router/glob/glob.spec.js +0 -108
- package/src/router/glob/glob.test.js +0 -12
- package/src/router/hooks/core-resolvables.js +0 -38
- package/src/router/hooks/ignored-transition.js +0 -25
- package/src/router/hooks/invalid-transition.js +0 -14
- package/src/router/hooks/lazy-load.js +0 -104
- package/src/router/hooks/on-enter-exit-retain.js +0 -55
- package/src/router/hooks/redirect-to.js +0 -38
- package/src/router/hooks/resolve.js +0 -57
- package/src/router/hooks/update-globals.js +0 -34
- package/src/router/hooks/url.js +0 -34
- package/src/router/hooks/views.js +0 -41
- package/src/router/params/interface.ts +0 -626
- package/src/router/params/param-factory.js +0 -23
- package/src/router/params/param-type.js +0 -133
- package/src/router/params/param-types.js +0 -153
- package/src/router/params/param.js +0 -243
- package/src/router/params/state-params.js +0 -36
- package/src/router/path/path-node.js +0 -78
- package/src/router/path/path-utils.js +0 -207
- package/src/router/resolve/interface.ts +0 -208
- package/src/router/resolve/resolvable.js +0 -123
- package/src/router/resolve/resolve-context.js +0 -190
- package/src/router/router-test-hashbang.html +0 -45
- package/src/router/router-test.html +0 -41
- package/src/router/router.html +0 -22
- package/src/router/router.js +0 -54
- package/src/router/router.test.js +0 -12
- package/src/router/services.spec.js +0 -52
- package/src/router/state/interface.ts +0 -1007
- package/src/router/state/state-builder.js +0 -376
- package/src/router/state/state-builder.spec.js +0 -86
- package/src/router/state/state-matcher.js +0 -64
- package/src/router/state/state-object.js +0 -118
- package/src/router/state/state-queue-manager.js +0 -95
- package/src/router/state/state-registry.js +0 -262
- package/src/router/state/state-service.js +0 -687
- package/src/router/state/state.html +0 -23
- package/src/router/state/state.spec.js +0 -1002
- package/src/router/state/state.test.js +0 -12
- package/src/router/state/target-state.js +0 -162
- package/src/router/state/views.js +0 -195
- package/src/router/state-filter.spec.js +0 -139
- package/src/router/state-filters.js +0 -46
- package/src/router/template-factory.html +0 -19
- package/src/router/template-factory.js +0 -249
- package/src/router/template-factory.spec.js +0 -146
- package/src/router/template-factory.test.js +0 -12
- package/src/router/transition/hook-builder.js +0 -137
- package/src/router/transition/hook-registry.js +0 -181
- package/src/router/transition/interface.js +0 -18
- package/src/router/transition/interface.ts +0 -922
- package/src/router/transition/reject-factory.js +0 -122
- package/src/router/transition/transition-event-type.js +0 -26
- package/src/router/transition/transition-hook.js +0 -199
- package/src/router/transition/transition-service.js +0 -297
- package/src/router/transition/transition.js +0 -653
- package/src/router/url/url-config.js +0 -155
- package/src/router/url/url-matcher.js +0 -532
- package/src/router/url/url-rule.js +0 -231
- package/src/router/url/url-rules.js +0 -350
- package/src/router/url/url-service.js +0 -446
- package/src/router/url/url-service.spec.js +0 -1288
- package/src/router/url/url.html +0 -19
- package/src/router/url/url.test.js +0 -12
- package/src/router/view/interface.ts +0 -51
- package/src/router/view/view.html +0 -19
- package/src/router/view/view.js +0 -262
- package/src/router/view/view.spec.js +0 -100
- package/src/router/view/view.test.js +0 -12
- package/src/router/view-hook.spec.js +0 -215
- package/src/router/view-scroll.js +0 -33
- package/src/router/view-scroll.spec.js +0 -72
- package/src/services/anchor-scroll/anchor-scroll.html +0 -76
- package/src/services/anchor-scroll/anchor-scroll.js +0 -147
- package/src/services/exception/exception-handler.js +0 -75
- package/src/services/exception/interface.ts +0 -7
- package/src/services/http/http.html +0 -23
- package/src/services/http/http.js +0 -1109
- package/src/services/http/http.spec.js +0 -4320
- package/src/services/http/http.test.js +0 -11
- package/src/services/http/interface.ts +0 -256
- package/src/services/http/template-request.spec.js +0 -220
- package/src/services/location/interface.ts +0 -70
- package/src/services/location/location.html +0 -22
- package/src/services/location/location.js +0 -1006
- package/src/services/location/location.spec.js +0 -3792
- package/src/services/location/location.test.js +0 -12
- package/src/services/log/interface.ts +0 -39
- package/src/services/log/log.html +0 -19
- package/src/services/log/log.js +0 -74
- package/src/services/log/log.spec.js +0 -64
- package/src/services/log/log.test.js +0 -12
- package/src/services/pubsub/pubsub.html +0 -19
- package/src/services/pubsub/pubsub.js +0 -349
- package/src/services/pubsub/pubsub.spec.js +0 -400
- package/src/services/pubsub/pubsub.test.js +0 -12
- package/src/services/sce/sce.html +0 -19
- package/src/services/sce/sce.js +0 -852
- package/src/services/sce/sce.spec.js +0 -617
- package/src/services/sce/sce.test.js +0 -12
- package/src/services/template-cache/template-cache.html +0 -22
- package/src/services/template-cache/template-cache.js +0 -15
- package/src/services/template-cache/template-cache.spec.js +0 -134
- package/src/services/template-cache/template-cache.test.js +0 -12
- package/src/services/template-request/interface.ts +0 -23
- package/src/services/template-request/template-request.js +0 -142
- package/src/shared/cache.js +0 -7
- package/src/shared/common.js +0 -365
- package/src/shared/common.spec.js +0 -294
- package/src/shared/constants.js +0 -21
- package/src/shared/dom.js +0 -716
- package/src/shared/hof.js +0 -157
- package/src/shared/hof.spec.js +0 -60
- package/src/shared/interface.ts +0 -21
- package/src/shared/min-err.spec.js +0 -178
- package/src/shared/noderef.js +0 -225
- package/src/shared/predicates.js +0 -34
- package/src/shared/queue.js +0 -105
- package/src/shared/queue.spec.js +0 -80
- package/src/shared/shared.html +0 -24
- package/src/shared/shared.test.js +0 -12
- package/src/shared/strings.js +0 -142
- package/src/shared/strings.spec.js +0 -40
- package/src/shared/test-utils.js +0 -47
- package/src/shared/url-utils/interface.ts +0 -54
- package/src/shared/url-utils/url-utils.html +0 -22
- package/src/shared/url-utils/url-utils.js +0 -122
- package/src/shared/url-utils/url-utils.spec.js +0 -148
- package/src/shared/url-utils/url-utils.test.js +0 -12
- package/src/shared/utils.js +0 -1255
- package/src/shared/utils.spec.js +0 -178
- package/src/src.html +0 -21
- package/src/src.test.js +0 -10
- package/tsconfig.json +0 -19
- package/tsconfig.types.json +0 -14
- package/typedoc.json +0 -8
- package/utils/express.js +0 -203
- package/utils/version.cjs +0 -23
- package/vite.config.js +0 -14
|
@@ -1,1078 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
addDateMinutes,
|
|
3
|
-
convertTimezoneToLocal,
|
|
4
|
-
equals,
|
|
5
|
-
isDate,
|
|
6
|
-
isDefined,
|
|
7
|
-
isNumber,
|
|
8
|
-
isNumberNaN,
|
|
9
|
-
isObject,
|
|
10
|
-
isProxy,
|
|
11
|
-
isString,
|
|
12
|
-
isUndefined,
|
|
13
|
-
lowercase,
|
|
14
|
-
nextUid,
|
|
15
|
-
timezoneToOffset,
|
|
16
|
-
trim,
|
|
17
|
-
} from "../../shared/utils.js";
|
|
18
|
-
import { ngModelMinErr } from "./../model/model";
|
|
19
|
-
|
|
20
|
-
// Regex code was initially obtained from SO prior to modification: https://stackoverflow.com/questions/3143070/javascript-regex-iso-datetime#answer-3143231
|
|
21
|
-
export const ISO_DATE_REGEXP =
|
|
22
|
-
/^\d{4,}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+(?:[+-][0-2]\d:[0-5]\d|Z)$/;
|
|
23
|
-
// See valid URLs in RFC3987 (http://tools.ietf.org/html/rfc3987)
|
|
24
|
-
// Note: We are being more lenient, because browsers are too.
|
|
25
|
-
// 1. Scheme
|
|
26
|
-
// 2. Slashes
|
|
27
|
-
// 3. Username
|
|
28
|
-
// 4. Password
|
|
29
|
-
// 5. Hostname
|
|
30
|
-
// 6. Port
|
|
31
|
-
// 7. Path
|
|
32
|
-
// 8. Query
|
|
33
|
-
// 9. Fragment
|
|
34
|
-
// 1111111111111111 222 333333 44444 55555555555555555555555 666 77777777 8888888 999
|
|
35
|
-
export const URL_REGEXP =
|
|
36
|
-
/^[a-z][a-z\d.+-]*:\/*(?:[^:@]+(?::[^@]+)?@)?(?:[^\s:/?#]+|\[[a-f\d:]+])(?::\d+)?(?:\/[^?#]*)?(?:\?[^#]*)?(?:#.*)?$/i;
|
|
37
|
-
|
|
38
|
-
export const EMAIL_REGEXP =
|
|
39
|
-
/^(?=.{1,254}$)(?=.{1,64}@)[-!#$%&'*+/0-9=?A-Z^_`a-z{|}~]+(\.[-!#$%&'*+/0-9=?A-Z^_`a-z{|}~]+)*@[A-Za-z0-9]([A-Za-z0-9-]{0,61}[A-Za-z0-9])?(\.[A-Za-z0-9]([A-Za-z0-9-]{0,61}[A-Za-z0-9])?)*$/;
|
|
40
|
-
const NUMBER_REGEXP = /^\s*([-+])?(\d+|(\d*(\.\d*)))([eE][+-]?\d+)?\s*$/;
|
|
41
|
-
const DATE_REGEXP = /^(\d{4,})-(\d{2})-(\d{2})$/;
|
|
42
|
-
const DATETIMELOCAL_REGEXP =
|
|
43
|
-
/^(\d{4,})-(\d\d)-(\d\d)T(\d\d):(\d\d)(?::(\d\d)(\.\d{1,3})?)?$/;
|
|
44
|
-
const WEEK_REGEXP = /^(\d{4,})-W(\d\d)$/;
|
|
45
|
-
const MONTH_REGEXP = /^(\d{4,})-(\d\d)$/;
|
|
46
|
-
const TIME_REGEXP = /^(\d\d):(\d\d)(?::(\d\d)(\.\d{1,3})?)?$/;
|
|
47
|
-
// The name of a form control's ValidityState property.
|
|
48
|
-
// This is used so that it's possible for internal tests to create mock ValidityStates.
|
|
49
|
-
export const VALIDITY_STATE_PROPERTY = "validity";
|
|
50
|
-
|
|
51
|
-
const PARTIAL_VALIDATION_EVENTS = "keydown wheel mousedown";
|
|
52
|
-
/**
|
|
53
|
-
* @type {Map<string, boolean>}
|
|
54
|
-
*/
|
|
55
|
-
const PARTIAL_VALIDATION_TYPES = new Map();
|
|
56
|
-
"date,datetime-local,month,time,week".split(",").forEach((type) => {
|
|
57
|
-
PARTIAL_VALIDATION_TYPES.set(type, true);
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
const inputType = {
|
|
61
|
-
text: textInputType,
|
|
62
|
-
date: createDateInputType(
|
|
63
|
-
"date",
|
|
64
|
-
DATE_REGEXP,
|
|
65
|
-
createDateParser(DATE_REGEXP, ["yyyy", "MM", "dd"]),
|
|
66
|
-
),
|
|
67
|
-
"datetime-local": createDateInputType(
|
|
68
|
-
"datetimelocal",
|
|
69
|
-
DATETIMELOCAL_REGEXP,
|
|
70
|
-
createDateParser(DATETIMELOCAL_REGEXP, [
|
|
71
|
-
"yyyy",
|
|
72
|
-
"MM",
|
|
73
|
-
"dd",
|
|
74
|
-
"HH",
|
|
75
|
-
"mm",
|
|
76
|
-
"ss",
|
|
77
|
-
"sss",
|
|
78
|
-
]),
|
|
79
|
-
),
|
|
80
|
-
time: createDateInputType(
|
|
81
|
-
"time",
|
|
82
|
-
TIME_REGEXP,
|
|
83
|
-
createDateParser(TIME_REGEXP, ["HH", "mm", "ss", "sss"]),
|
|
84
|
-
),
|
|
85
|
-
week: createDateInputType("week", WEEK_REGEXP, weekParser),
|
|
86
|
-
month: createDateInputType(
|
|
87
|
-
"month",
|
|
88
|
-
MONTH_REGEXP,
|
|
89
|
-
createDateParser(MONTH_REGEXP, ["yyyy", "MM"]),
|
|
90
|
-
),
|
|
91
|
-
number: numberInputType,
|
|
92
|
-
url: urlInputType,
|
|
93
|
-
email: emailInputType,
|
|
94
|
-
radio: radioInputType,
|
|
95
|
-
range: rangeInputType,
|
|
96
|
-
checkbox: checkboxInputType,
|
|
97
|
-
hidden: () => {},
|
|
98
|
-
button: () => {},
|
|
99
|
-
submit: () => {},
|
|
100
|
-
reset: () => {},
|
|
101
|
-
file: () => {},
|
|
102
|
-
};
|
|
103
|
-
|
|
104
|
-
function stringBasedInputType(ctrl) {
|
|
105
|
-
ctrl.$formatters.push((value) =>
|
|
106
|
-
ctrl.$isEmpty(value) ? value : value.toString(),
|
|
107
|
-
);
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
function textInputType(scope, element, attr, ctrl) {
|
|
111
|
-
baseInputType(scope, element, attr, ctrl);
|
|
112
|
-
stringBasedInputType(ctrl);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
function baseInputType(scope, element, attr, ctrl) {
|
|
116
|
-
const type = element.type.toLowerCase();
|
|
117
|
-
let composing = false;
|
|
118
|
-
// In composition mode, users are still inputting intermediate text buffer,
|
|
119
|
-
// hold the listener until composition is done.
|
|
120
|
-
// More about composition events: https://developer.mozilla.org/en-US/docs/Web/API/CompositionEvent
|
|
121
|
-
element.addEventListener("compositionstart", () => {
|
|
122
|
-
composing = true;
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
element.addEventListener("compositionend", () => {
|
|
126
|
-
composing = false;
|
|
127
|
-
listener();
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
let timeout;
|
|
131
|
-
|
|
132
|
-
let listener = function (ev) {
|
|
133
|
-
if (timeout) {
|
|
134
|
-
clearTimeout(timeout);
|
|
135
|
-
timeout = null;
|
|
136
|
-
}
|
|
137
|
-
if (composing) return;
|
|
138
|
-
let value = element.value;
|
|
139
|
-
const event = ev && ev.type;
|
|
140
|
-
|
|
141
|
-
// By default we will trim the value
|
|
142
|
-
// If the attribute ng-trim exists we will avoid trimming
|
|
143
|
-
// If input type is 'password', the value is never trimmed
|
|
144
|
-
if (type !== "password" && (!attr.ngTrim || attr.ngTrim !== "false")) {
|
|
145
|
-
value = trim(value);
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
// If a control is suffering from bad input (due to native validators), browsers discard its
|
|
149
|
-
// value, so it may be necessary to revalidate (by calling $setViewValue again) even if the
|
|
150
|
-
// control's value is the same empty value twice in a row.
|
|
151
|
-
if (
|
|
152
|
-
ctrl.$viewValue !== value ||
|
|
153
|
-
(value === "" && ctrl.$$hasNativeValidators)
|
|
154
|
-
) {
|
|
155
|
-
ctrl.$target.$setViewValue(value, event);
|
|
156
|
-
}
|
|
157
|
-
};
|
|
158
|
-
|
|
159
|
-
["input", "change", "paste", "drop", "cut"].forEach((event) => {
|
|
160
|
-
element.addEventListener(event, listener);
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
// Some native input types (date-family) have the ability to change validity without
|
|
164
|
-
// firing any input/change events.
|
|
165
|
-
// For these event types, when native validators are present and the browser supports the type,
|
|
166
|
-
// check for validity changes on various DOM events.
|
|
167
|
-
if (
|
|
168
|
-
PARTIAL_VALIDATION_TYPES[type] &&
|
|
169
|
-
ctrl.$$hasNativeValidators &&
|
|
170
|
-
type === attr.type
|
|
171
|
-
) {
|
|
172
|
-
element.addEventListener(PARTIAL_VALIDATION_EVENTS, function (ev) {
|
|
173
|
-
if (!timeout) {
|
|
174
|
-
const validity = this[VALIDITY_STATE_PROPERTY];
|
|
175
|
-
const origBadInput = validity.badInput;
|
|
176
|
-
const origTypeMismatch = validity.typeMismatch;
|
|
177
|
-
timeout = setTimeout(() => {
|
|
178
|
-
timeout = null;
|
|
179
|
-
if (
|
|
180
|
-
validity.badInput !== origBadInput ||
|
|
181
|
-
validity.typeMismatch !== origTypeMismatch
|
|
182
|
-
) {
|
|
183
|
-
listener(ev);
|
|
184
|
-
}
|
|
185
|
-
});
|
|
186
|
-
}
|
|
187
|
-
});
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
ctrl.$render = function () {
|
|
191
|
-
// Workaround for Firefox validation #12102.
|
|
192
|
-
const value = ctrl.$isEmpty(ctrl.$viewValue) ? "" : ctrl.$viewValue;
|
|
193
|
-
if (element.value !== value) {
|
|
194
|
-
element.value = value;
|
|
195
|
-
}
|
|
196
|
-
};
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
export function weekParser(isoWeek, existingDate) {
|
|
200
|
-
if (isDate(isoWeek)) {
|
|
201
|
-
return isoWeek;
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
function getFirstThursdayOfYear(year) {
|
|
205
|
-
// 0 = index of January
|
|
206
|
-
const dayOfWeekOnFirst = new Date(year, 0, 1).getDay();
|
|
207
|
-
// 4 = index of Thursday (+1 to account for 1st = 5)
|
|
208
|
-
// 11 = index of *next* Thursday (+1 account for 1st = 12)
|
|
209
|
-
return new Date(
|
|
210
|
-
year,
|
|
211
|
-
0,
|
|
212
|
-
(dayOfWeekOnFirst <= 4 ? 5 : 12) - dayOfWeekOnFirst,
|
|
213
|
-
);
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
if (isString(isoWeek)) {
|
|
217
|
-
WEEK_REGEXP.lastIndex = 0;
|
|
218
|
-
const parts = WEEK_REGEXP.exec(isoWeek);
|
|
219
|
-
if (parts) {
|
|
220
|
-
const year = +parts[1];
|
|
221
|
-
const week = +parts[2];
|
|
222
|
-
let hours = 0;
|
|
223
|
-
let minutes = 0;
|
|
224
|
-
let seconds = 0;
|
|
225
|
-
let milliseconds = 0;
|
|
226
|
-
const firstThurs = getFirstThursdayOfYear(year);
|
|
227
|
-
const addDays = (week - 1) * 7;
|
|
228
|
-
|
|
229
|
-
if (existingDate) {
|
|
230
|
-
hours = existingDate.getHours();
|
|
231
|
-
minutes = existingDate.getMinutes();
|
|
232
|
-
seconds = existingDate.getSeconds();
|
|
233
|
-
milliseconds = existingDate.getMilliseconds();
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
return new Date(
|
|
237
|
-
year,
|
|
238
|
-
0,
|
|
239
|
-
firstThurs.getDate() + addDays,
|
|
240
|
-
hours,
|
|
241
|
-
minutes,
|
|
242
|
-
seconds,
|
|
243
|
-
milliseconds,
|
|
244
|
-
);
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
return NaN;
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
export function createDateParser(regexp, mapping) {
|
|
252
|
-
return function (iso, previousDate) {
|
|
253
|
-
let parts;
|
|
254
|
-
let map;
|
|
255
|
-
|
|
256
|
-
if (isDate(iso)) {
|
|
257
|
-
return iso;
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
if (isString(iso)) {
|
|
261
|
-
// When a date is JSON'ified to wraps itself inside of an extra
|
|
262
|
-
// set of double quotes. This makes the date parsing code unable
|
|
263
|
-
// to match the date string and parse it as a date.
|
|
264
|
-
if (iso.charAt(0) === '"' && iso.charAt(iso.length - 1) === '"') {
|
|
265
|
-
iso = iso.substring(1, iso.length - 1);
|
|
266
|
-
}
|
|
267
|
-
if (ISO_DATE_REGEXP.test(iso)) {
|
|
268
|
-
return new Date(iso);
|
|
269
|
-
}
|
|
270
|
-
regexp.lastIndex = 0;
|
|
271
|
-
parts = regexp.exec(iso);
|
|
272
|
-
|
|
273
|
-
if (parts) {
|
|
274
|
-
parts.shift();
|
|
275
|
-
if (previousDate) {
|
|
276
|
-
map = {
|
|
277
|
-
yyyy: previousDate.getFullYear(),
|
|
278
|
-
MM: previousDate.getMonth() + 1,
|
|
279
|
-
dd: previousDate.getDate(),
|
|
280
|
-
HH: previousDate.getHours(),
|
|
281
|
-
mm: previousDate.getMinutes(),
|
|
282
|
-
ss: previousDate.getSeconds(),
|
|
283
|
-
sss: previousDate.getMilliseconds() / 1000,
|
|
284
|
-
};
|
|
285
|
-
} else {
|
|
286
|
-
map = { yyyy: 1970, MM: 1, dd: 1, HH: 0, mm: 0, ss: 0, sss: 0 };
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
Object.entries(parts).forEach(([index, part]) => {
|
|
290
|
-
if (index < mapping.length) {
|
|
291
|
-
map[mapping[index]] = +part;
|
|
292
|
-
}
|
|
293
|
-
});
|
|
294
|
-
|
|
295
|
-
const date = new Date(
|
|
296
|
-
map.yyyy,
|
|
297
|
-
map.MM - 1,
|
|
298
|
-
map.dd,
|
|
299
|
-
map.HH,
|
|
300
|
-
map.mm,
|
|
301
|
-
map.ss || 0,
|
|
302
|
-
map.sss * 1000 || 0,
|
|
303
|
-
);
|
|
304
|
-
if (map.yyyy < 100) {
|
|
305
|
-
// In the constructor, 2-digit years map to 1900-1999.
|
|
306
|
-
// Use `setFullYear()` to set the correct year.
|
|
307
|
-
date.setFullYear(map.yyyy);
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
return date;
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
|
-
|
|
314
|
-
return NaN;
|
|
315
|
-
};
|
|
316
|
-
}
|
|
317
|
-
|
|
318
|
-
const MONTH_INPUT_FORMAT = /\b\d{4}-(0[1-9]|1[0-2])\b/;
|
|
319
|
-
|
|
320
|
-
export function createDateInputType(type, regexp, parseDate) {
|
|
321
|
-
return function dynamicDateInputType(
|
|
322
|
-
scope,
|
|
323
|
-
element,
|
|
324
|
-
attr,
|
|
325
|
-
ctrl,
|
|
326
|
-
$filter,
|
|
327
|
-
$parse,
|
|
328
|
-
) {
|
|
329
|
-
badInputChecker(scope, element, attr, ctrl, type);
|
|
330
|
-
baseInputType(scope, element, attr, ctrl);
|
|
331
|
-
let previousDate;
|
|
332
|
-
let previousTimezone;
|
|
333
|
-
|
|
334
|
-
ctrl.$parsers.push((value) => {
|
|
335
|
-
if (ctrl.$isEmpty(value)) return null;
|
|
336
|
-
|
|
337
|
-
if (regexp.test(value)) {
|
|
338
|
-
// Do not convert for native HTML
|
|
339
|
-
if (["month", "week", "datetimelocal", "time", "date"].includes(type)) {
|
|
340
|
-
return value;
|
|
341
|
-
}
|
|
342
|
-
|
|
343
|
-
// Note: We cannot read ctrl.$modelValue, as there might be a different
|
|
344
|
-
// parser/formatter in the processing chain so that the model
|
|
345
|
-
// contains some different data format!
|
|
346
|
-
return parseDateAndConvertTimeZoneToLocal(value, previousDate);
|
|
347
|
-
}
|
|
348
|
-
ctrl.$$parserName = type;
|
|
349
|
-
return undefined;
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
ctrl.$formatters.push(function (value) {
|
|
353
|
-
if (value && !isString(value)) {
|
|
354
|
-
throw ngModelMinErr("datefmt", "Expected `{0}` to be a String", value);
|
|
355
|
-
}
|
|
356
|
-
|
|
357
|
-
if (type === "month") {
|
|
358
|
-
if (value == null) {
|
|
359
|
-
return "";
|
|
360
|
-
}
|
|
361
|
-
if (!MONTH_INPUT_FORMAT.test(value)) {
|
|
362
|
-
throw ngModelMinErr(
|
|
363
|
-
"datefmt",
|
|
364
|
-
"Expected month `{0}` to be a 'YYYY-DD'",
|
|
365
|
-
value,
|
|
366
|
-
);
|
|
367
|
-
}
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
if (type === "week") {
|
|
371
|
-
if (value == null) {
|
|
372
|
-
return "";
|
|
373
|
-
}
|
|
374
|
-
if (!WEEK_REGEXP.test(value)) {
|
|
375
|
-
throw ngModelMinErr(
|
|
376
|
-
"datefmt",
|
|
377
|
-
"Expected week `{0}` to be a 'yyyy-Www'",
|
|
378
|
-
value,
|
|
379
|
-
);
|
|
380
|
-
}
|
|
381
|
-
}
|
|
382
|
-
|
|
383
|
-
if (type === "datetimelocal") {
|
|
384
|
-
if (value == null) {
|
|
385
|
-
return "";
|
|
386
|
-
}
|
|
387
|
-
if (!DATETIMELOCAL_REGEXP.test(value)) {
|
|
388
|
-
throw ngModelMinErr(
|
|
389
|
-
"datefmt",
|
|
390
|
-
"Expected week `{0}` to be a in date time format. See: https://developer.mozilla.org/en-US/docs/Web/HTML/Date_and_time_formats#local_date_and_time_strings",
|
|
391
|
-
value,
|
|
392
|
-
);
|
|
393
|
-
}
|
|
394
|
-
}
|
|
395
|
-
|
|
396
|
-
return value;
|
|
397
|
-
|
|
398
|
-
// if (isValidDate(value)) {
|
|
399
|
-
// previousDate = value;
|
|
400
|
-
// const timezone = ctrl.$options.getOption("timezone");
|
|
401
|
-
|
|
402
|
-
// if (timezone) {
|
|
403
|
-
// previousTimezone = timezone;
|
|
404
|
-
// previousDate = convertTimezoneToLocal(previousDate, timezone, true);
|
|
405
|
-
// }
|
|
406
|
-
|
|
407
|
-
// return value;
|
|
408
|
-
// }
|
|
409
|
-
// previousDate = null;
|
|
410
|
-
// previousTimezone = null;
|
|
411
|
-
// return "";
|
|
412
|
-
});
|
|
413
|
-
|
|
414
|
-
if (isDefined(attr.min) || attr.ngMin) {
|
|
415
|
-
let minVal = attr.min || $parse(attr.ngMin)(scope);
|
|
416
|
-
let parsedMinVal = parseObservedDateValue(
|
|
417
|
-
isProxy(minVal) ? minVal.$target : minVal,
|
|
418
|
-
);
|
|
419
|
-
|
|
420
|
-
ctrl.$validators.min = function (value) {
|
|
421
|
-
if (type === "month") {
|
|
422
|
-
return (
|
|
423
|
-
isUndefined(parsedMinVal) ||
|
|
424
|
-
parseDate(value) >= parseDate(parsedMinVal)
|
|
425
|
-
);
|
|
426
|
-
}
|
|
427
|
-
|
|
428
|
-
return (
|
|
429
|
-
!isValidDate(value) ||
|
|
430
|
-
isUndefined(parsedMinVal) ||
|
|
431
|
-
parseDate(value) >= parsedMinVal
|
|
432
|
-
);
|
|
433
|
-
};
|
|
434
|
-
attr.$observe("min", (val) => {
|
|
435
|
-
if (val !== minVal) {
|
|
436
|
-
parsedMinVal = parseObservedDateValue(val);
|
|
437
|
-
minVal = val;
|
|
438
|
-
ctrl.$validate();
|
|
439
|
-
}
|
|
440
|
-
});
|
|
441
|
-
}
|
|
442
|
-
|
|
443
|
-
if (isDefined(attr.max) || attr.ngMax) {
|
|
444
|
-
let maxVal = attr.max || $parse(attr.ngMax)(scope);
|
|
445
|
-
let parsedMaxVal = parseObservedDateValue(
|
|
446
|
-
isProxy(maxVal) ? maxVal.$target : maxVal,
|
|
447
|
-
);
|
|
448
|
-
|
|
449
|
-
ctrl.$validators.max = function (value) {
|
|
450
|
-
if (type === "month") {
|
|
451
|
-
return (
|
|
452
|
-
isUndefined(parsedMaxVal) ||
|
|
453
|
-
parseDate(value) <= parseDate(parsedMaxVal)
|
|
454
|
-
);
|
|
455
|
-
}
|
|
456
|
-
return (
|
|
457
|
-
!isValidDate(value) ||
|
|
458
|
-
isUndefined(parsedMaxVal) ||
|
|
459
|
-
parseDate(value) <= parsedMaxVal
|
|
460
|
-
);
|
|
461
|
-
};
|
|
462
|
-
attr.$observe("max", (val) => {
|
|
463
|
-
if (val !== maxVal) {
|
|
464
|
-
parsedMaxVal = parseObservedDateValue(val);
|
|
465
|
-
maxVal = val;
|
|
466
|
-
ctrl.$validate();
|
|
467
|
-
}
|
|
468
|
-
});
|
|
469
|
-
}
|
|
470
|
-
|
|
471
|
-
function isValidDate(value) {
|
|
472
|
-
// Invalid Date: getTime() returns NaN
|
|
473
|
-
return value && !(value.getTime && value.getTime() !== value.getTime());
|
|
474
|
-
}
|
|
475
|
-
|
|
476
|
-
function parseObservedDateValue(val) {
|
|
477
|
-
return isDefined(val) && !isDate(val)
|
|
478
|
-
? parseDateAndConvertTimeZoneToLocal(val) || undefined
|
|
479
|
-
: val;
|
|
480
|
-
}
|
|
481
|
-
|
|
482
|
-
function parseDateAndConvertTimeZoneToLocal(value, previousDate) {
|
|
483
|
-
const timezone = ctrl.$options.getOption("timezone");
|
|
484
|
-
|
|
485
|
-
if (previousTimezone && previousTimezone !== timezone) {
|
|
486
|
-
// If the timezone has changed, adjust the previousDate to the default timezone
|
|
487
|
-
// so that the new date is converted with the correct timezone offset
|
|
488
|
-
previousDate = addDateMinutes(
|
|
489
|
-
previousDate,
|
|
490
|
-
timezoneToOffset(previousTimezone),
|
|
491
|
-
);
|
|
492
|
-
}
|
|
493
|
-
|
|
494
|
-
let parsedDate = parseDate(value, previousDate);
|
|
495
|
-
|
|
496
|
-
if (!Number.isNaN(parsedDate) && timezone) {
|
|
497
|
-
parsedDate = convertTimezoneToLocal(parsedDate, timezone);
|
|
498
|
-
}
|
|
499
|
-
return parsedDate;
|
|
500
|
-
}
|
|
501
|
-
};
|
|
502
|
-
}
|
|
503
|
-
|
|
504
|
-
export function badInputChecker(scope, element, attr, ctrl, parserName) {
|
|
505
|
-
const nativeValidation = (ctrl.$$hasNativeValidators = isObject(
|
|
506
|
-
element.validity,
|
|
507
|
-
));
|
|
508
|
-
|
|
509
|
-
if (nativeValidation) {
|
|
510
|
-
ctrl.$parsers.push((value) => {
|
|
511
|
-
const validity = element[VALIDITY_STATE_PROPERTY] || {};
|
|
512
|
-
if (validity.badInput || validity.typeMismatch) {
|
|
513
|
-
ctrl.$$parserName = parserName;
|
|
514
|
-
return undefined;
|
|
515
|
-
}
|
|
516
|
-
|
|
517
|
-
return value;
|
|
518
|
-
});
|
|
519
|
-
}
|
|
520
|
-
}
|
|
521
|
-
|
|
522
|
-
export function numberFormatterParser(ctrl) {
|
|
523
|
-
ctrl.$parsers.push((value) => {
|
|
524
|
-
if (ctrl.$isEmpty(value)) return null;
|
|
525
|
-
if (NUMBER_REGEXP.test(value)) return parseFloat(value);
|
|
526
|
-
|
|
527
|
-
ctrl.$$parserName = "number";
|
|
528
|
-
return undefined;
|
|
529
|
-
});
|
|
530
|
-
|
|
531
|
-
ctrl.$formatters.push((value) => {
|
|
532
|
-
if (!ctrl.$isEmpty(value)) {
|
|
533
|
-
if (!isNumber(value)) {
|
|
534
|
-
throw ngModelMinErr("numfmt", "Expected `{0}` to be a number", value);
|
|
535
|
-
}
|
|
536
|
-
value = value.toString();
|
|
537
|
-
}
|
|
538
|
-
return value;
|
|
539
|
-
});
|
|
540
|
-
}
|
|
541
|
-
|
|
542
|
-
function parseNumberAttrVal(val) {
|
|
543
|
-
if (isDefined(val) && !isNumber(val)) {
|
|
544
|
-
val = parseFloat(val);
|
|
545
|
-
}
|
|
546
|
-
return !isNumberNaN(val) ? val : undefined;
|
|
547
|
-
}
|
|
548
|
-
|
|
549
|
-
export function isNumberInteger(num) {
|
|
550
|
-
// See http://stackoverflow.com/questions/14636536/how-to-check-if-a-variable-is-an-integer-in-javascript#14794066
|
|
551
|
-
// (minus the assumption that `num` is a number)
|
|
552
|
-
|
|
553
|
-
return (num | 0) === num;
|
|
554
|
-
}
|
|
555
|
-
|
|
556
|
-
export function countDecimals(num) {
|
|
557
|
-
const numString = num.toString();
|
|
558
|
-
const decimalSymbolIndex = numString.indexOf(".");
|
|
559
|
-
|
|
560
|
-
if (decimalSymbolIndex === -1) {
|
|
561
|
-
if (num > -1 && num < 1) {
|
|
562
|
-
// It may be in the exponential notation format (`1e-X`)
|
|
563
|
-
const match = /e-(\d+)$/.exec(numString);
|
|
564
|
-
|
|
565
|
-
if (match) {
|
|
566
|
-
return Number(match[1]);
|
|
567
|
-
}
|
|
568
|
-
}
|
|
569
|
-
|
|
570
|
-
return 0;
|
|
571
|
-
}
|
|
572
|
-
|
|
573
|
-
return numString.length - decimalSymbolIndex - 1;
|
|
574
|
-
}
|
|
575
|
-
|
|
576
|
-
export function isValidForStep(viewValue, stepBase, step) {
|
|
577
|
-
// At this point `stepBase` and `step` are expected to be non-NaN values
|
|
578
|
-
// and `viewValue` is expected to be a valid stringified number.
|
|
579
|
-
let value = Number(viewValue);
|
|
580
|
-
|
|
581
|
-
const isNonIntegerValue = !isNumberInteger(value);
|
|
582
|
-
const isNonIntegerStepBase = !isNumberInteger(stepBase);
|
|
583
|
-
const isNonIntegerStep = !isNumberInteger(step);
|
|
584
|
-
|
|
585
|
-
// Due to limitations in Floating Point Arithmetic (e.g. `0.3 - 0.2 !== 0.1` or
|
|
586
|
-
// `0.5 % 0.1 !== 0`), we need to convert all numbers to integers.
|
|
587
|
-
if (isNonIntegerValue || isNonIntegerStepBase || isNonIntegerStep) {
|
|
588
|
-
const valueDecimals = isNonIntegerValue ? countDecimals(value) : 0;
|
|
589
|
-
const stepBaseDecimals = isNonIntegerStepBase ? countDecimals(stepBase) : 0;
|
|
590
|
-
const stepDecimals = isNonIntegerStep ? countDecimals(step) : 0;
|
|
591
|
-
|
|
592
|
-
const decimalCount = Math.max(
|
|
593
|
-
valueDecimals,
|
|
594
|
-
stepBaseDecimals,
|
|
595
|
-
stepDecimals,
|
|
596
|
-
);
|
|
597
|
-
const multiplier = 10 ** decimalCount;
|
|
598
|
-
|
|
599
|
-
value *= multiplier;
|
|
600
|
-
stepBase *= multiplier;
|
|
601
|
-
step *= multiplier;
|
|
602
|
-
|
|
603
|
-
if (isNonIntegerValue) value = Math.round(value);
|
|
604
|
-
if (isNonIntegerStepBase) stepBase = Math.round(stepBase);
|
|
605
|
-
if (isNonIntegerStep) step = Math.round(step);
|
|
606
|
-
}
|
|
607
|
-
|
|
608
|
-
return (value - stepBase) % step === 0;
|
|
609
|
-
}
|
|
610
|
-
|
|
611
|
-
export function numberInputType(scope, element, attr, ctrl, $filter, $parse) {
|
|
612
|
-
badInputChecker(scope, element, attr, ctrl, "number");
|
|
613
|
-
numberFormatterParser(ctrl);
|
|
614
|
-
baseInputType(scope, element, attr, ctrl);
|
|
615
|
-
|
|
616
|
-
let parsedMinVal;
|
|
617
|
-
|
|
618
|
-
if (isDefined(attr.min) || attr.ngMin) {
|
|
619
|
-
let minVal = attr.min || $parse(attr.ngMin)(scope);
|
|
620
|
-
parsedMinVal = parseNumberAttrVal(minVal);
|
|
621
|
-
|
|
622
|
-
ctrl.$validators.min = function (modelValue, viewValue) {
|
|
623
|
-
return (
|
|
624
|
-
ctrl.$isEmpty(viewValue) ||
|
|
625
|
-
isUndefined(parsedMinVal) ||
|
|
626
|
-
viewValue >= parsedMinVal
|
|
627
|
-
);
|
|
628
|
-
};
|
|
629
|
-
|
|
630
|
-
attr.$observe("min", (val) => {
|
|
631
|
-
if (val !== minVal) {
|
|
632
|
-
parsedMinVal = parseNumberAttrVal(val);
|
|
633
|
-
minVal = val;
|
|
634
|
-
// TODO(matsko): implement validateLater to reduce number of validations
|
|
635
|
-
ctrl.$validate();
|
|
636
|
-
}
|
|
637
|
-
});
|
|
638
|
-
}
|
|
639
|
-
|
|
640
|
-
if (isDefined(attr.max) || attr.ngMax) {
|
|
641
|
-
let maxVal = attr.max || $parse(attr.ngMax)(scope);
|
|
642
|
-
let parsedMaxVal = parseNumberAttrVal(maxVal);
|
|
643
|
-
|
|
644
|
-
ctrl.$validators.max = function (modelValue, viewValue) {
|
|
645
|
-
return (
|
|
646
|
-
ctrl.$isEmpty(viewValue) ||
|
|
647
|
-
isUndefined(parsedMaxVal) ||
|
|
648
|
-
viewValue <= parsedMaxVal
|
|
649
|
-
);
|
|
650
|
-
};
|
|
651
|
-
|
|
652
|
-
attr.$observe("max", (val) => {
|
|
653
|
-
if (val !== maxVal) {
|
|
654
|
-
parsedMaxVal = parseNumberAttrVal(val);
|
|
655
|
-
maxVal = val;
|
|
656
|
-
// TODO(matsko): implement validateLater to reduce number of validations
|
|
657
|
-
ctrl.$validate();
|
|
658
|
-
}
|
|
659
|
-
});
|
|
660
|
-
}
|
|
661
|
-
|
|
662
|
-
if (isDefined(attr.step) || attr.ngStep) {
|
|
663
|
-
let stepVal = attr.step || $parse(attr.ngStep)(scope);
|
|
664
|
-
let parsedStepVal = parseNumberAttrVal(stepVal);
|
|
665
|
-
|
|
666
|
-
ctrl.$validators.step = function (modelValue, viewValue) {
|
|
667
|
-
return (
|
|
668
|
-
ctrl.$isEmpty(viewValue) ||
|
|
669
|
-
isUndefined(parsedStepVal) ||
|
|
670
|
-
isValidForStep(viewValue, parsedMinVal || 0, parsedStepVal)
|
|
671
|
-
);
|
|
672
|
-
};
|
|
673
|
-
|
|
674
|
-
attr.$observe("step", (val) => {
|
|
675
|
-
// TODO(matsko): implement validateLater to reduce number of validations
|
|
676
|
-
if (val !== stepVal) {
|
|
677
|
-
parsedStepVal = parseNumberAttrVal(val);
|
|
678
|
-
stepVal = val;
|
|
679
|
-
ctrl.$validate();
|
|
680
|
-
}
|
|
681
|
-
});
|
|
682
|
-
}
|
|
683
|
-
}
|
|
684
|
-
|
|
685
|
-
export function rangeInputType(scope, element, attr, ctrl) {
|
|
686
|
-
badInputChecker(scope, element, attr, ctrl, "range");
|
|
687
|
-
numberFormatterParser(ctrl);
|
|
688
|
-
baseInputType(scope, element, attr, ctrl);
|
|
689
|
-
|
|
690
|
-
const supportsRange = ctrl.$$hasNativeValidators && element.type === "range";
|
|
691
|
-
let minVal = supportsRange ? 0 : undefined;
|
|
692
|
-
let maxVal = supportsRange ? 100 : undefined;
|
|
693
|
-
let stepVal = supportsRange ? 1 : undefined;
|
|
694
|
-
const { validity } = element;
|
|
695
|
-
const hasMinAttr = isDefined(attr.min);
|
|
696
|
-
const hasMaxAttr = isDefined(attr.max);
|
|
697
|
-
const hasStepAttr = isDefined(attr.step);
|
|
698
|
-
|
|
699
|
-
const originalRender = ctrl.$render;
|
|
700
|
-
|
|
701
|
-
ctrl.$render =
|
|
702
|
-
supportsRange &&
|
|
703
|
-
isDefined(validity.rangeUnderflow) &&
|
|
704
|
-
isDefined(validity.rangeOverflow)
|
|
705
|
-
? // Browsers that implement range will set these values automatically, but reading the adjusted values after
|
|
706
|
-
// $render would cause the min / max validators to be applied with the wrong value
|
|
707
|
-
function rangeRender() {
|
|
708
|
-
originalRender();
|
|
709
|
-
ctrl.$setViewValue(element.value);
|
|
710
|
-
}
|
|
711
|
-
: originalRender;
|
|
712
|
-
|
|
713
|
-
if (hasMinAttr) {
|
|
714
|
-
minVal = parseNumberAttrVal(attr.min);
|
|
715
|
-
|
|
716
|
-
ctrl.$validators.min = supportsRange
|
|
717
|
-
? // Since all browsers set the input to a valid value, we don't need to check validity
|
|
718
|
-
function noopMinValidator() {
|
|
719
|
-
return true;
|
|
720
|
-
}
|
|
721
|
-
: // non-support browsers validate the min val
|
|
722
|
-
function minValidator(modelValue, viewValue) {
|
|
723
|
-
return (
|
|
724
|
-
ctrl.$isEmpty(viewValue) ||
|
|
725
|
-
isUndefined(minVal) ||
|
|
726
|
-
viewValue >= minVal
|
|
727
|
-
);
|
|
728
|
-
};
|
|
729
|
-
|
|
730
|
-
setInitialValueAndObserver("min", minChange);
|
|
731
|
-
}
|
|
732
|
-
|
|
733
|
-
if (hasMaxAttr) {
|
|
734
|
-
maxVal = parseNumberAttrVal(attr.max);
|
|
735
|
-
|
|
736
|
-
ctrl.$validators.max = supportsRange
|
|
737
|
-
? // Since all browsers set the input to a valid value, we don't need to check validity
|
|
738
|
-
function noopMaxValidator() {
|
|
739
|
-
return true;
|
|
740
|
-
}
|
|
741
|
-
: // non-support browsers validate the max val
|
|
742
|
-
function maxValidator(modelValue, viewValue) {
|
|
743
|
-
return (
|
|
744
|
-
ctrl.$isEmpty(viewValue) ||
|
|
745
|
-
isUndefined(maxVal) ||
|
|
746
|
-
viewValue <= maxVal
|
|
747
|
-
);
|
|
748
|
-
};
|
|
749
|
-
|
|
750
|
-
setInitialValueAndObserver("max", maxChange);
|
|
751
|
-
}
|
|
752
|
-
|
|
753
|
-
if (hasStepAttr) {
|
|
754
|
-
stepVal = parseNumberAttrVal(attr.step);
|
|
755
|
-
|
|
756
|
-
ctrl.$validators.step = supportsRange
|
|
757
|
-
? function nativeStepValidator() {
|
|
758
|
-
// Currently, only FF implements the spec on step change correctly (i.e. adjusting the
|
|
759
|
-
// input element value to a valid value). It's possible that other browsers set the stepMismatch
|
|
760
|
-
// validity error instead, so we can at least report an error in that case.
|
|
761
|
-
return !validity.stepMismatch;
|
|
762
|
-
}
|
|
763
|
-
: // ngStep doesn't set the setp attr, so the browser doesn't adjust the input value as setting step would
|
|
764
|
-
function stepValidator(modelValue, viewValue) {
|
|
765
|
-
return (
|
|
766
|
-
ctrl.$isEmpty(viewValue) ||
|
|
767
|
-
isUndefined(stepVal) ||
|
|
768
|
-
isValidForStep(viewValue, minVal || 0, stepVal)
|
|
769
|
-
);
|
|
770
|
-
};
|
|
771
|
-
|
|
772
|
-
setInitialValueAndObserver("step", stepChange);
|
|
773
|
-
}
|
|
774
|
-
|
|
775
|
-
function setInitialValueAndObserver(htmlAttrName, changeFn) {
|
|
776
|
-
// interpolated attributes set the attribute value only after a digest, but we need the
|
|
777
|
-
// attribute value when the input is first rendered, so that the browser can adjust the
|
|
778
|
-
// input value based on the min/max value
|
|
779
|
-
element.setAttribute(htmlAttrName, attr[htmlAttrName]);
|
|
780
|
-
let oldVal = attr[htmlAttrName];
|
|
781
|
-
attr.$observe(htmlAttrName, (val) => {
|
|
782
|
-
if (val !== oldVal) {
|
|
783
|
-
oldVal = val;
|
|
784
|
-
changeFn(val);
|
|
785
|
-
}
|
|
786
|
-
});
|
|
787
|
-
}
|
|
788
|
-
|
|
789
|
-
function minChange(val) {
|
|
790
|
-
minVal = parseNumberAttrVal(val);
|
|
791
|
-
// ignore changes before model is initialized
|
|
792
|
-
if (isNumberNaN(ctrl.$modelValue)) {
|
|
793
|
-
return;
|
|
794
|
-
}
|
|
795
|
-
|
|
796
|
-
if (supportsRange) {
|
|
797
|
-
let elVal = element.value;
|
|
798
|
-
// IE11 doesn't set the el val correctly if the minVal is greater than the element value
|
|
799
|
-
if (minVal > elVal) {
|
|
800
|
-
elVal = minVal;
|
|
801
|
-
element.value = elVal;
|
|
802
|
-
}
|
|
803
|
-
ctrl.$setViewValue(elVal);
|
|
804
|
-
} else {
|
|
805
|
-
// TODO(matsko): implement validateLater to reduce number of validations
|
|
806
|
-
ctrl.$validate();
|
|
807
|
-
}
|
|
808
|
-
}
|
|
809
|
-
|
|
810
|
-
function maxChange(val) {
|
|
811
|
-
maxVal = parseNumberAttrVal(val);
|
|
812
|
-
// ignore changes before model is initialized
|
|
813
|
-
if (isNumberNaN(ctrl.$modelValue)) {
|
|
814
|
-
return;
|
|
815
|
-
}
|
|
816
|
-
|
|
817
|
-
if (supportsRange) {
|
|
818
|
-
let elVal = element.value;
|
|
819
|
-
// IE11 doesn't set the el val correctly if the maxVal is less than the element value
|
|
820
|
-
if (maxVal < elVal) {
|
|
821
|
-
element.value = maxVal;
|
|
822
|
-
// IE11 and Chrome don't set the value to the minVal when max < min
|
|
823
|
-
elVal = maxVal < minVal ? minVal : maxVal;
|
|
824
|
-
}
|
|
825
|
-
ctrl.$setViewValue(elVal);
|
|
826
|
-
} else {
|
|
827
|
-
// TODO(matsko): implement validateLater to reduce number of validations
|
|
828
|
-
ctrl.$validate();
|
|
829
|
-
}
|
|
830
|
-
}
|
|
831
|
-
|
|
832
|
-
function stepChange(val) {
|
|
833
|
-
stepVal = parseNumberAttrVal(val);
|
|
834
|
-
// ignore changes before model is initialized
|
|
835
|
-
if (isNumberNaN(ctrl.$modelValue)) {
|
|
836
|
-
return;
|
|
837
|
-
}
|
|
838
|
-
|
|
839
|
-
// Some browsers don't adjust the input value correctly, but set the stepMismatch error
|
|
840
|
-
if (!supportsRange) {
|
|
841
|
-
// TODO(matsko): implement validateLater to reduce number of validations
|
|
842
|
-
ctrl.$validate();
|
|
843
|
-
} else if (ctrl.$viewValue !== element.value) {
|
|
844
|
-
ctrl.$setViewValue(element.value);
|
|
845
|
-
}
|
|
846
|
-
}
|
|
847
|
-
}
|
|
848
|
-
|
|
849
|
-
function urlInputType(scope, element, attr, ctrl) {
|
|
850
|
-
// Note: no badInputChecker here by purpose as `url` is only a validation
|
|
851
|
-
// in browsers, i.e. we can always read out input.value even if it is not valid!
|
|
852
|
-
baseInputType(scope, element, attr, ctrl);
|
|
853
|
-
stringBasedInputType(ctrl);
|
|
854
|
-
|
|
855
|
-
ctrl.$validators.url = function (modelValue, viewValue) {
|
|
856
|
-
const value = modelValue || viewValue;
|
|
857
|
-
return ctrl.$isEmpty(value) || URL_REGEXP.test(value);
|
|
858
|
-
};
|
|
859
|
-
}
|
|
860
|
-
|
|
861
|
-
function emailInputType(scope, element, attr, ctrl) {
|
|
862
|
-
// Note: no badInputChecker here by purpose as `url` is only a validation
|
|
863
|
-
// in browsers, i.e. we can always read out input.value even if it is not valid!
|
|
864
|
-
baseInputType(scope, element, attr, ctrl);
|
|
865
|
-
stringBasedInputType(ctrl);
|
|
866
|
-
|
|
867
|
-
ctrl.$validators.email = function (modelValue, viewValue) {
|
|
868
|
-
const value = modelValue || viewValue;
|
|
869
|
-
return ctrl.$isEmpty(value) || EMAIL_REGEXP.test(value);
|
|
870
|
-
};
|
|
871
|
-
}
|
|
872
|
-
|
|
873
|
-
function radioInputType(scope, element, attr, ctrl) {
|
|
874
|
-
const doTrim = !attr.ngTrim || trim(attr.ngTrim) !== "false";
|
|
875
|
-
// make the name unique, if not defined
|
|
876
|
-
if (isUndefined(attr.name)) {
|
|
877
|
-
element.setAttribute("name", nextUid());
|
|
878
|
-
}
|
|
879
|
-
|
|
880
|
-
const listener = function (ev) {
|
|
881
|
-
let value;
|
|
882
|
-
if (element.checked) {
|
|
883
|
-
value = attr.value;
|
|
884
|
-
if (doTrim) {
|
|
885
|
-
value = trim(value);
|
|
886
|
-
}
|
|
887
|
-
ctrl.$setViewValue(value, ev && ev.type);
|
|
888
|
-
}
|
|
889
|
-
};
|
|
890
|
-
|
|
891
|
-
element.addEventListener("change", listener);
|
|
892
|
-
// NgModelController call
|
|
893
|
-
ctrl.$render = function () {
|
|
894
|
-
let { value } = attr;
|
|
895
|
-
if (doTrim) {
|
|
896
|
-
value = trim(value);
|
|
897
|
-
}
|
|
898
|
-
const deproxy = isProxy(ctrl.$viewValue)
|
|
899
|
-
? ctrl.$viewValue.$target
|
|
900
|
-
: ctrl.$viewValue;
|
|
901
|
-
// the proxy may reach down two levels
|
|
902
|
-
element.checked =
|
|
903
|
-
(isProxy(value) ? value.$target : value) ===
|
|
904
|
-
(isProxy(deproxy) ? deproxy.$target : deproxy);
|
|
905
|
-
};
|
|
906
|
-
|
|
907
|
-
attr.$observe("value", ctrl.$render);
|
|
908
|
-
}
|
|
909
|
-
|
|
910
|
-
function parseConstantExpr($parse, context, name, expression, fallback) {
|
|
911
|
-
let parseFn;
|
|
912
|
-
if (isDefined(expression)) {
|
|
913
|
-
parseFn = $parse(expression);
|
|
914
|
-
if (!parseFn.constant) {
|
|
915
|
-
throw ngModelMinErr(
|
|
916
|
-
"constexpr",
|
|
917
|
-
"Expected constant expression for `{0}`, but saw " + "`{1}`.",
|
|
918
|
-
name,
|
|
919
|
-
expression,
|
|
920
|
-
);
|
|
921
|
-
}
|
|
922
|
-
return parseFn(context);
|
|
923
|
-
}
|
|
924
|
-
return fallback;
|
|
925
|
-
}
|
|
926
|
-
|
|
927
|
-
function checkboxInputType(scope, element, attr, ctrl, $filter, $parse) {
|
|
928
|
-
const trueValue = parseConstantExpr(
|
|
929
|
-
$parse,
|
|
930
|
-
scope,
|
|
931
|
-
"ngTrueValue",
|
|
932
|
-
attr.ngTrueValue,
|
|
933
|
-
true,
|
|
934
|
-
);
|
|
935
|
-
const falseValue = parseConstantExpr(
|
|
936
|
-
$parse,
|
|
937
|
-
scope,
|
|
938
|
-
"ngFalseValue",
|
|
939
|
-
attr.ngFalseValue,
|
|
940
|
-
false,
|
|
941
|
-
);
|
|
942
|
-
|
|
943
|
-
const listener = function (ev) {
|
|
944
|
-
ctrl.$setViewValue(element.checked, ev && ev.type);
|
|
945
|
-
};
|
|
946
|
-
|
|
947
|
-
element.addEventListener("change", listener);
|
|
948
|
-
|
|
949
|
-
ctrl.$render = function () {
|
|
950
|
-
element.checked = ctrl.$viewValue;
|
|
951
|
-
};
|
|
952
|
-
|
|
953
|
-
// Override the standard `$isEmpty` because the $viewValue of an empty checkbox is always set to `false`
|
|
954
|
-
// This is because of the parser below, which compares the `$modelValue` with `trueValue` to convert
|
|
955
|
-
// it to a boolean.
|
|
956
|
-
ctrl.$isEmpty = function (value) {
|
|
957
|
-
return value === false;
|
|
958
|
-
};
|
|
959
|
-
|
|
960
|
-
ctrl.$formatters.push((value) => equals(value, trueValue));
|
|
961
|
-
|
|
962
|
-
ctrl.$parsers.push((value) => (value ? trueValue : falseValue));
|
|
963
|
-
}
|
|
964
|
-
|
|
965
|
-
inputDirective.$inject = ["$filter", "$parse"];
|
|
966
|
-
|
|
967
|
-
/**
|
|
968
|
-
* @param {*} $filter
|
|
969
|
-
* @param {*} $parse
|
|
970
|
-
* @returns {import('../../interface.ts').Directive}
|
|
971
|
-
*/
|
|
972
|
-
export function inputDirective($filter, $parse) {
|
|
973
|
-
return {
|
|
974
|
-
restrict: "E",
|
|
975
|
-
require: ["?ngModel"],
|
|
976
|
-
link: {
|
|
977
|
-
pre(scope, element, attr, ctrls) {
|
|
978
|
-
if (ctrls[0]) {
|
|
979
|
-
(inputType[lowercase(attr["type"])] || inputType.text)(
|
|
980
|
-
scope,
|
|
981
|
-
element,
|
|
982
|
-
attr,
|
|
983
|
-
ctrls[0],
|
|
984
|
-
$filter,
|
|
985
|
-
$parse,
|
|
986
|
-
);
|
|
987
|
-
}
|
|
988
|
-
},
|
|
989
|
-
},
|
|
990
|
-
};
|
|
991
|
-
}
|
|
992
|
-
|
|
993
|
-
/**
|
|
994
|
-
* @returns {import('../../interface.ts').Directive}
|
|
995
|
-
*/
|
|
996
|
-
export function hiddenInputBrowserCacheDirective() {
|
|
997
|
-
const valueProperty = {
|
|
998
|
-
configurable: true,
|
|
999
|
-
enumerable: false,
|
|
1000
|
-
get() {
|
|
1001
|
-
return this.getAttribute("value") || "";
|
|
1002
|
-
},
|
|
1003
|
-
set(val) {
|
|
1004
|
-
this.setAttribute("value", val);
|
|
1005
|
-
},
|
|
1006
|
-
};
|
|
1007
|
-
|
|
1008
|
-
return {
|
|
1009
|
-
restrict: "E",
|
|
1010
|
-
priority: 200,
|
|
1011
|
-
compile(_, attr) {
|
|
1012
|
-
if (lowercase(attr["type"]) !== "hidden") {
|
|
1013
|
-
return;
|
|
1014
|
-
}
|
|
1015
|
-
|
|
1016
|
-
return {
|
|
1017
|
-
pre(scope, element) {
|
|
1018
|
-
const node = element;
|
|
1019
|
-
|
|
1020
|
-
// Support: Edge
|
|
1021
|
-
// Moving the DOM around prevents autofillling
|
|
1022
|
-
if (node.parentNode) {
|
|
1023
|
-
node.parentNode.insertBefore(node, node.nextSibling);
|
|
1024
|
-
}
|
|
1025
|
-
|
|
1026
|
-
// Support: FF, IE
|
|
1027
|
-
// Avoiding direct assignment to .value prevents autofillling
|
|
1028
|
-
if (Object.defineProperty) {
|
|
1029
|
-
Object.defineProperty(node, "value", valueProperty);
|
|
1030
|
-
}
|
|
1031
|
-
},
|
|
1032
|
-
};
|
|
1033
|
-
},
|
|
1034
|
-
};
|
|
1035
|
-
}
|
|
1036
|
-
|
|
1037
|
-
const CONSTANT_VALUE_REGEXP = /^(true|false|\d+)$/;
|
|
1038
|
-
|
|
1039
|
-
/**
|
|
1040
|
-
* @returns {import('../../interface.ts').Directive}
|
|
1041
|
-
*/
|
|
1042
|
-
export function ngValueDirective() {
|
|
1043
|
-
/**
|
|
1044
|
-
* inputs use the value attribute as their default value if the value property is not set.
|
|
1045
|
-
* Once the value property has been set (by adding input), it will not react to changes to
|
|
1046
|
-
* the value attribute anymore. Setting both attribute and property fixes this behavior, and
|
|
1047
|
-
* makes it possible to use ngValue as a sort of one-way bind.
|
|
1048
|
-
*/
|
|
1049
|
-
function updateElementValue(element, attr, value) {
|
|
1050
|
-
// TODO REMOVE IS SUPPORT
|
|
1051
|
-
// Support: IE9 only
|
|
1052
|
-
// In IE9 values are converted to string (e.g. `input.value = null` results in `input.value === 'null'`).
|
|
1053
|
-
element["value"] = isDefined(value)
|
|
1054
|
-
? isProxy(value)
|
|
1055
|
-
? value.$target
|
|
1056
|
-
: value
|
|
1057
|
-
: null;
|
|
1058
|
-
attr.$set("value", value);
|
|
1059
|
-
}
|
|
1060
|
-
|
|
1061
|
-
return {
|
|
1062
|
-
restrict: "A",
|
|
1063
|
-
priority: 100,
|
|
1064
|
-
compile(tpl, tplAttr) {
|
|
1065
|
-
if (CONSTANT_VALUE_REGEXP.test(tplAttr["ngValue"])) {
|
|
1066
|
-
return function ngValueConstantLink(scope, elm, attr) {
|
|
1067
|
-
const value = scope.$eval(attr["ngValue"]);
|
|
1068
|
-
updateElementValue(elm, attr, value);
|
|
1069
|
-
};
|
|
1070
|
-
}
|
|
1071
|
-
return function ngValueLink(scope, elm, attr) {
|
|
1072
|
-
scope.$watch(attr["ngValue"], (value) => {
|
|
1073
|
-
updateElementValue(elm, attr, value);
|
|
1074
|
-
});
|
|
1075
|
-
};
|
|
1076
|
-
},
|
|
1077
|
-
};
|
|
1078
|
-
}
|