@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.
Files changed (645) hide show
  1. package/@types/index.d.ts +1 -84
  2. package/{src/index.ts → @types/namespace.d.ts} +4 -24
  3. package/@types/router/template-factory.d.ts +2 -2
  4. package/dist/angular-ts.esm.js +3 -3
  5. package/dist/angular-ts.umd.js +3 -3
  6. package/dist/angular-ts.umd.min.js +1 -1
  7. package/package.json +9 -2
  8. package/.github/workflows/ci.yml +0 -104
  9. package/.github/workflows/gh-pages.yml +0 -75
  10. package/.husky/pre-commit +0 -5
  11. package/.prettierignore +0 -9
  12. package/CHANGELOG.md +0 -17667
  13. package/CODE_OF_CONDUCT.md +0 -3
  14. package/CONTRIBUTING.md +0 -247
  15. package/DEVELOPERS.md +0 -499
  16. package/Makefile +0 -60
  17. package/RELEASE.md +0 -86
  18. package/TRIAGING.md +0 -127
  19. package/docs/.cspell.yml +0 -8
  20. package/docs/.github/dependabot.yml +0 -14
  21. package/docs/.nvmrc +0 -1
  22. package/docs/CONTRIBUTING.md +0 -28
  23. package/docs/Dockerfile +0 -4
  24. package/docs/LICENSE +0 -201
  25. package/docs/README.md +0 -217
  26. package/docs/assets/icons/logo.svg +0 -1
  27. package/docs/assets/scss/_variables_project.scss +0 -12
  28. package/docs/assets/scss/_variables_project_after_bs.scss +0 -8
  29. package/docs/assets/scss/index.scss +0 -48
  30. package/docs/config.yaml +0 -15
  31. package/docs/content/_index.md +0 -28
  32. package/docs/content/docs/_index.md +0 -61
  33. package/docs/content/docs/directive/_index.md +0 -4
  34. package/docs/content/docs/directive/app.md +0 -11
  35. package/docs/content/docs/directive/aria.md +0 -0
  36. package/docs/content/docs/directive/bind.md +0 -72
  37. package/docs/content/docs/directive/blur.md +0 -38
  38. package/docs/content/docs/directive/channel.md +0 -37
  39. package/docs/content/docs/directive/class-even.md +0 -47
  40. package/docs/content/docs/directive/class-odd.md +0 -48
  41. package/docs/content/docs/directive/class.md +0 -64
  42. package/docs/content/docs/directive/click.md +0 -41
  43. package/docs/content/docs/directive/cloak.md +0 -74
  44. package/docs/content/docs/directive/copy.md +0 -38
  45. package/docs/content/docs/directive/cut.md +0 -40
  46. package/docs/content/docs/directive/dblclick.md +0 -41
  47. package/docs/content/docs/directive/focus.md +0 -38
  48. package/docs/content/docs/directive/get.md +0 -203
  49. package/docs/content/docs/directive/include.md +0 -7
  50. package/docs/content/docs/directive/keydown.md +0 -38
  51. package/docs/content/docs/directive/keyup.md +0 -38
  52. package/docs/content/docs/directive/load.md +0 -43
  53. package/docs/content/docs/directive/mousedown.md +0 -38
  54. package/docs/content/docs/directive/mouseenter.md +0 -38
  55. package/docs/content/docs/directive/mouseleave.md +0 -38
  56. package/docs/content/docs/directive/mousemove.md +0 -38
  57. package/docs/content/docs/directive/mouseout.md +0 -38
  58. package/docs/content/docs/directive/mouseover.md +0 -38
  59. package/docs/content/docs/directive/mouseup.md +0 -38
  60. package/docs/content/docs/directive/non-bindable.md +0 -28
  61. package/docs/content/docs/filter/_index.md +0 -4
  62. package/docs/content/docs/filter/filter.md +0 -78
  63. package/docs/content/docs/filter/json.md +0 -19
  64. package/docs/content/docs/filter/limit-to.md +0 -30
  65. package/docs/content/docs/filter/order-by.md +0 -123
  66. package/docs/content/docs/provider/_index.md +0 -4
  67. package/docs/content/docs/provider/eventBusProvider.md +0 -35
  68. package/docs/content/docs/provider/locationProvider.md +0 -26
  69. package/docs/content/docs/provider/logProvider.md +0 -59
  70. package/docs/content/docs/provider/sceProvider.md +0 -194
  71. package/docs/content/docs/provider/templateCacheProvider.md +0 -100
  72. package/docs/content/docs/provider/templateRequestProvider.md +0 -5
  73. package/docs/content/docs/service/_index.md +0 -4
  74. package/docs/content/docs/service/compile.md +0 -5
  75. package/docs/content/docs/service/controller.md +0 -5
  76. package/docs/content/docs/service/eventBus.md +0 -56
  77. package/docs/content/docs/service/http.md +0 -161
  78. package/docs/content/docs/service/interpolation.md +0 -5
  79. package/docs/content/docs/service/location.md +0 -57
  80. package/docs/content/docs/service/log.md +0 -113
  81. package/docs/content/docs/service/parse.md +0 -5
  82. package/docs/content/docs/service/rootElement.md +0 -5
  83. package/docs/content/docs/service/rootScope.md +0 -5
  84. package/docs/content/docs/service/sce.md +0 -194
  85. package/docs/content/docs/service/templateCache.md +0 -64
  86. package/docs/content/docs/service/templateRequest.md +0 -5
  87. package/docs/content/docs/service/url.md +0 -5
  88. package/docs/content/docs/values/_index.md +0 -4
  89. package/docs/content/docs/values/document.md +0 -29
  90. package/docs/content/docs/values/window.md +0 -29
  91. package/docs/docker-compose.yaml +0 -12
  92. package/docs/docsy.work +0 -5
  93. package/docs/docsy.work.sum +0 -0
  94. package/docs/go.mod +0 -5
  95. package/docs/go.sum +0 -6
  96. package/docs/hugo-disabled.toml +0 -220
  97. package/docs/hugo.yaml +0 -200
  98. package/docs/layouts/404.html +0 -13
  99. package/docs/layouts/_markup/render-heading.html +0 -1
  100. package/docs/layouts/partials/hooks/head-end.html +0 -3
  101. package/docs/layouts/shortcodes/showcss.html +0 -2
  102. package/docs/layouts/shortcodes/showhtml.html +0 -2
  103. package/docs/layouts/shortcodes/showjs.html +0 -2
  104. package/docs/layouts/shortcodes/showraw.html +0 -1
  105. package/docs/layouts/shortcodes/version.html +0 -1
  106. package/docs/package-lock.json +0 -2293
  107. package/docs/package.json +0 -53
  108. package/docs/static/examples/counter/counter-test.html +0 -13
  109. package/docs/static/examples/counter/counter.html +0 -5
  110. package/docs/static/examples/counter/counter.test.js +0 -28
  111. package/docs/static/examples/document/document.html +0 -3
  112. package/docs/static/examples/eventbus/eventbus-test.html +0 -15
  113. package/docs/static/examples/eventbus/eventbus.html +0 -13
  114. package/docs/static/examples/eventbus/eventbus.js +0 -15
  115. package/docs/static/examples/eventbus/eventbus.test.js +0 -19
  116. package/docs/static/examples/i18n/i18n.html +0 -77
  117. package/docs/static/examples/ng-bind/ng-bind.html +0 -9
  118. package/docs/static/examples/ng-blur/ng-blur.html +0 -9
  119. package/docs/static/examples/ng-channel/ng-channel-test.html +0 -17
  120. package/docs/static/examples/ng-channel/ng-channel.html +0 -24
  121. package/docs/static/examples/ng-channel/ng-channel.test.js +0 -31
  122. package/docs/static/examples/ng-class/ng-class.html +0 -71
  123. package/docs/static/examples/ng-class-even/ng-class-even.html +0 -8
  124. package/docs/static/examples/ng-class-odd/ng-class-odd.html +0 -8
  125. package/docs/static/examples/ng-click/ng-click.html +0 -6
  126. package/docs/static/examples/ng-copy/ng-copy.html +0 -6
  127. package/docs/static/examples/ng-cut/ng-cut.html +0 -6
  128. package/docs/static/examples/ng-dblclick/ng-dblclick.html +0 -10
  129. package/docs/static/examples/ng-focus/ng-focus.html +0 -9
  130. package/docs/static/examples/ng-keydown/ng-keydown.html +0 -9
  131. package/docs/static/examples/ng-keyup/ng-keyup.html +0 -9
  132. package/docs/static/examples/ng-load/ng-load.html +0 -8
  133. package/docs/static/examples/ng-mousedown/ng-mousedown.html +0 -6
  134. package/docs/static/examples/ng-mouseenter/ng-mouseenter.html +0 -4
  135. package/docs/static/examples/ng-mouseleave/ng-mouseleave.html +0 -4
  136. package/docs/static/examples/ng-mousemove/ng-mousemove.html +0 -4
  137. package/docs/static/examples/ng-mouseout/ng-mouseout.html +0 -4
  138. package/docs/static/examples/ng-mouseover/ng-mouseover.html +0 -4
  139. package/docs/static/examples/ng-mouseup/ng-mouseup.html +0 -4
  140. package/docs/static/examples/ng-non-bindable/ng-non-bindable-test.html +0 -13
  141. package/docs/static/examples/ng-non-bindable/ng-non-bindable.html +0 -3
  142. package/docs/static/examples/ng-non-bindable/ng-non-bindable.test.js +0 -11
  143. package/docs/static/examples/window/window.html +0 -4
  144. package/docs/static/typedoc/.nojekyll +0 -1
  145. package/docs/static/typedoc/assets/hierarchy.js +0 -1
  146. package/docs/static/typedoc/assets/highlight.css +0 -29
  147. package/docs/static/typedoc/assets/icons.js +0 -18
  148. package/docs/static/typedoc/assets/icons.svg +0 -1
  149. package/docs/static/typedoc/assets/main.js +0 -60
  150. package/docs/static/typedoc/assets/navigation.js +0 -1
  151. package/docs/static/typedoc/assets/search.js +0 -1
  152. package/docs/static/typedoc/assets/style.css +0 -1633
  153. package/docs/static/typedoc/classes/Location.html +0 -55
  154. package/docs/static/typedoc/classes/LocationProvider.html +0 -20
  155. package/docs/static/typedoc/classes/LogProvider.html +0 -6
  156. package/docs/static/typedoc/classes/PubSub.html +0 -71
  157. package/docs/static/typedoc/classes/PubSubProvider.html +0 -4
  158. package/docs/static/typedoc/classes/TemplateCacheProvider.html +0 -5
  159. package/docs/static/typedoc/hierarchy.html +0 -1
  160. package/docs/static/typedoc/index.html +0 -1
  161. package/docs/static/typedoc/interfaces/DefaultPorts.html +0 -5
  162. package/docs/static/typedoc/interfaces/Html5Mode.html +0 -23
  163. package/docs/static/typedoc/interfaces/HttpHeadersGetter.html +0 -1
  164. package/docs/static/typedoc/interfaces/HttpProviderDefaults.html +0 -31
  165. package/docs/static/typedoc/interfaces/HttpRequestConfigHeaders.html +0 -6
  166. package/docs/static/typedoc/interfaces/HttpRequestTransformer.html +0 -1
  167. package/docs/static/typedoc/interfaces/HttpResponse.html +0 -7
  168. package/docs/static/typedoc/interfaces/HttpResponseTransformer.html +0 -1
  169. package/docs/static/typedoc/interfaces/HttpService.html +0 -38
  170. package/docs/static/typedoc/interfaces/LogService.html +0 -12
  171. package/docs/static/typedoc/interfaces/RequestConfig.html +0 -48
  172. package/docs/static/typedoc/interfaces/RequestShortcutConfig.html +0 -38
  173. package/docs/static/typedoc/interfaces/ServiceProvider.html +0 -5
  174. package/docs/static/typedoc/interfaces/UrlParts.html +0 -9
  175. package/docs/static/typedoc/types/HttpParamSerializer.html +0 -2
  176. package/docs/static/typedoc/types/HttpParams.html +0 -2
  177. package/docs/static/typedoc/types/HttpPromise.html +0 -1
  178. package/docs/static/typedoc/types/HttpResponseStatus.html +0 -1
  179. package/docs/static/typedoc/types/LogCall.html +0 -2
  180. package/docs/static/typedoc/types/LogServiceFactory.html +0 -2
  181. package/docs/static/typedoc/types/UrlChangeListener.html +0 -5
  182. package/docs/static/typedoc/variables/EventBus.html +0 -1
  183. package/docs/static/version.js +0 -13
  184. package/docs/test-results/.last-run.json +0 -4
  185. package/docs/test-results/static-examples-counter-counter-counter-example/error-context.md +0 -50
  186. package/eslint.config.js +0 -26
  187. package/images/android-chrome-192x192.png +0 -0
  188. package/images/android-chrome-512x512.png +0 -0
  189. package/images/apple-touch-icon.png +0 -0
  190. package/images/favicon-16x16.png +0 -0
  191. package/images/favicon-32x32.png +0 -0
  192. package/images/favicon.ico +0 -0
  193. package/images/site.webmanifest +0 -19
  194. package/index.html +0 -86
  195. package/legacy.d.ts +0 -1678
  196. package/playwright.config.ts +0 -81
  197. package/public/jasmine/boot0.js +0 -66
  198. package/public/jasmine/boot1.js +0 -134
  199. package/public/jasmine/jasmine-html.js +0 -970
  200. package/public/jasmine/jasmine.css +0 -323
  201. package/public/jasmine/jasmine.js +0 -11406
  202. package/public/public/README.md +0 -1
  203. package/public/public/circle.html +0 -1
  204. package/public/public/jasmine-helper.css +0 -9
  205. package/public/public/my_child_directive.html +0 -1
  206. package/public/public/my_directive.html +0 -1
  207. package/public/public/my_other_directive.html +0 -1
  208. package/public/public/test.html +0 -1
  209. package/rollup.config.js +0 -51
  210. package/src/angular.js +0 -286
  211. package/src/angular.spec.js +0 -1191
  212. package/src/animations/animate-cache.js +0 -80
  213. package/src/animations/animate-children-directive.js +0 -32
  214. package/src/animations/animate-children-directive.md +0 -80
  215. package/src/animations/animate-css-driver.js +0 -284
  216. package/src/animations/animate-css.html +0 -58
  217. package/src/animations/animate-css.js +0 -915
  218. package/src/animations/animate-css.md +0 -263
  219. package/src/animations/animate-js-driver.js +0 -60
  220. package/src/animations/animate-js.html +0 -47
  221. package/src/animations/animate-js.js +0 -371
  222. package/src/animations/animate-queue.js +0 -859
  223. package/src/animations/animate-runner.js +0 -193
  224. package/src/animations/animate-swap.js +0 -33
  225. package/src/animations/animate-swap.md +0 -88
  226. package/src/animations/animate.html +0 -19
  227. package/src/animations/animate.js +0 -546
  228. package/src/animations/animate.md +0 -933
  229. package/src/animations/animate.spec.js +0 -490
  230. package/src/animations/animation.js +0 -519
  231. package/src/animations/animations.test.js +0 -10
  232. package/src/animations/interface.ts +0 -19
  233. package/src/animations/raf-scheduler.html +0 -19
  234. package/src/animations/raf-scheduler.js +0 -92
  235. package/src/animations/raf-scheduler.spec.js +0 -98
  236. package/src/animations/shared.js +0 -341
  237. package/src/binding.html +0 -19
  238. package/src/binding.spec.js +0 -474
  239. package/src/binding.test.js +0 -10
  240. package/src/core/compile/attributes.js +0 -337
  241. package/src/core/compile/compile.html +0 -19
  242. package/src/core/compile/compile.js +0 -3271
  243. package/src/core/compile/compile.md +0 -1128
  244. package/src/core/compile/compile.spec.js +0 -15574
  245. package/src/core/compile/compile.test.js +0 -12
  246. package/src/core/controller/controller.html +0 -22
  247. package/src/core/controller/controller.js +0 -193
  248. package/src/core/controller/controller.spec.js +0 -334
  249. package/src/core/controller/controller.test.js +0 -12
  250. package/src/core/controller/interface.ts +0 -6
  251. package/src/core/core.html +0 -20
  252. package/src/core/core.test.js +0 -12
  253. package/src/core/di/injector.html +0 -19
  254. package/src/core/di/injector.js +0 -307
  255. package/src/core/di/injector.md +0 -740
  256. package/src/core/di/injector.spec.js +0 -2310
  257. package/src/core/di/injector.test.js +0 -12
  258. package/src/core/di/internal-injector.js +0 -286
  259. package/src/core/di/ng-module.html +0 -19
  260. package/src/core/di/ng-module.js +0 -229
  261. package/src/core/di/ng-module.spec.js +0 -263
  262. package/src/core/di/ng-module.test.js +0 -12
  263. package/src/core/filter/filter.html +0 -19
  264. package/src/core/filter/filter.js +0 -55
  265. package/src/core/filter/filter.md +0 -132
  266. package/src/core/filter/filter.spec.js +0 -149
  267. package/src/core/filter/filter.test.js +0 -12
  268. package/src/core/interpolate/interface.ts +0 -14
  269. package/src/core/interpolate/interpolate.html +0 -22
  270. package/src/core/interpolate/interpolate.js +0 -410
  271. package/src/core/interpolate/interpolate.spec.js +0 -601
  272. package/src/core/interpolate/interpolate.test.js +0 -12
  273. package/src/core/parse/ast/ast-node.ts +0 -81
  274. package/src/core/parse/ast/ast.html +0 -19
  275. package/src/core/parse/ast/ast.js +0 -574
  276. package/src/core/parse/ast/ast.spec.js +0 -1453
  277. package/src/core/parse/ast/ast.test.js +0 -10
  278. package/src/core/parse/ast-type.js +0 -23
  279. package/src/core/parse/interface.ts +0 -84
  280. package/src/core/parse/interpreter.js +0 -915
  281. package/src/core/parse/lexer/lexer.html +0 -19
  282. package/src/core/parse/lexer/lexer.js +0 -338
  283. package/src/core/parse/lexer/lexer.spec.js +0 -303
  284. package/src/core/parse/lexer/lexer.test.js +0 -10
  285. package/src/core/parse/lexer/token.ts +0 -22
  286. package/src/core/parse/parse.html +0 -19
  287. package/src/core/parse/parse.js +0 -337
  288. package/src/core/parse/parse.md +0 -57
  289. package/src/core/parse/parse.spec.js +0 -2107
  290. package/src/core/parse/parse.test.js +0 -10
  291. package/src/core/parse/parser/parser.html +0 -19
  292. package/src/core/parse/parser/parser.js +0 -64
  293. package/src/core/parse/parser/parser.spec.js +0 -8
  294. package/src/core/parse/parser/parser.test.js +0 -10
  295. package/src/core/prop.spec.js +0 -775
  296. package/src/core/root-element.spec.js +0 -14
  297. package/src/core/sanitize/interface.ts +0 -10
  298. package/src/core/sanitize/sanitize-uri.js +0 -75
  299. package/src/core/sanitize/sanitize-uri.spec.js +0 -249
  300. package/src/core/sanitize/sanitize-uri.test.js +0 -12
  301. package/src/core/sanitize/sanitize.html +0 -22
  302. package/src/core/scope/scope.html +0 -19
  303. package/src/core/scope/scope.js +0 -1252
  304. package/src/core/scope/scope.spec.js +0 -3000
  305. package/src/core/scope/scope.test.js +0 -12
  306. package/src/directive/aria/aria.html +0 -19
  307. package/src/directive/aria/aria.js +0 -382
  308. package/src/directive/aria/aria.md +0 -145
  309. package/src/directive/aria/aria.spec.js +0 -1241
  310. package/src/directive/aria/aria.test.js +0 -12
  311. package/src/directive/attrs/attrs.html +0 -19
  312. package/src/directive/attrs/attrs.js +0 -106
  313. package/src/directive/attrs/attrs.md +0 -224
  314. package/src/directive/attrs/attrs.spec.js +0 -71
  315. package/src/directive/attrs/attrs.test.js +0 -12
  316. package/src/directive/attrs/boolean.html +0 -19
  317. package/src/directive/attrs/boolean.spec.js +0 -137
  318. package/src/directive/attrs/boolean.test.js +0 -12
  319. package/src/directive/attrs/element-style.html +0 -22
  320. package/src/directive/attrs/element-style.spec.js +0 -85
  321. package/src/directive/attrs/element-style.test.js +0 -12
  322. package/src/directive/attrs/src.html +0 -19
  323. package/src/directive/attrs/src.spec.js +0 -163
  324. package/src/directive/attrs/src.test.js +0 -12
  325. package/src/directive/bind/bind-html.spec.js +0 -36
  326. package/src/directive/bind/bind.html +0 -20
  327. package/src/directive/bind/bind.js +0 -78
  328. package/src/directive/bind/bind.md +0 -142
  329. package/src/directive/bind/bind.spec.js +0 -314
  330. package/src/directive/bind/bind.test.js +0 -12
  331. package/src/directive/channel/channel.html +0 -19
  332. package/src/directive/channel/channel.js +0 -30
  333. package/src/directive/channel/channel.spec.js +0 -67
  334. package/src/directive/channel/channel.test.js +0 -10
  335. package/src/directive/class/class-test.html +0 -23
  336. package/src/directive/class/class.html +0 -19
  337. package/src/directive/class/class.js +0 -184
  338. package/src/directive/class/class.spec.js +0 -704
  339. package/src/directive/class/class.test.js +0 -12
  340. package/src/directive/cloak/cloak.html +0 -19
  341. package/src/directive/cloak/cloak.js +0 -11
  342. package/src/directive/cloak/cloak.spec.js +0 -44
  343. package/src/directive/cloak/cloak.test.js +0 -12
  344. package/src/directive/controller/controller.html +0 -22
  345. package/src/directive/controller/controller.js +0 -11
  346. package/src/directive/controller/controller.md +0 -46
  347. package/src/directive/controller/controller.spec.js +0 -175
  348. package/src/directive/controller/controller.test.js +0 -12
  349. package/src/directive/events/click.spec.js +0 -35
  350. package/src/directive/events/event.spec.js +0 -267
  351. package/src/directive/events/events-test.html +0 -36
  352. package/src/directive/events/events.html +0 -20
  353. package/src/directive/events/events.js +0 -65
  354. package/src/directive/events/events.md +0 -125
  355. package/src/directive/events/events.test.js +0 -12
  356. package/src/directive/form/form.html +0 -19
  357. package/src/directive/form/form.js +0 -669
  358. package/src/directive/form/form.spec.js +0 -1515
  359. package/src/directive/form/form.test.js +0 -12
  360. package/src/directive/http/delete.spec.js +0 -23
  361. package/src/directive/http/form-router-test.html +0 -44
  362. package/src/directive/http/form-test.html +0 -18
  363. package/src/directive/http/get.spec.js +0 -488
  364. package/src/directive/http/http.html +0 -22
  365. package/src/directive/http/http.js +0 -342
  366. package/src/directive/http/http.test.js +0 -12
  367. package/src/directive/http/interface.ts +0 -36
  368. package/src/directive/http/post-example.html +0 -30
  369. package/src/directive/http/post.spec.js +0 -521
  370. package/src/directive/http/put.spec.js +0 -23
  371. package/src/directive/if/if-animate-css.html +0 -57
  372. package/src/directive/if/if-animate-svg.html +0 -25
  373. package/src/directive/if/if.html +0 -19
  374. package/src/directive/if/if.js +0 -72
  375. package/src/directive/if/if.md +0 -76
  376. package/src/directive/if/if.spec.js +0 -293
  377. package/src/directive/if/if.test.js +0 -114
  378. package/src/directive/include/include.html +0 -19
  379. package/src/directive/include/include.js +0 -151
  380. package/src/directive/include/include.md +0 -87
  381. package/src/directive/include/include.spec.js +0 -734
  382. package/src/directive/include/include.test.js +0 -12
  383. package/src/directive/init/init.html +0 -19
  384. package/src/directive/init/init.js +0 -22
  385. package/src/directive/init/init.md +0 -41
  386. package/src/directive/init/init.spec.js +0 -68
  387. package/src/directive/init/init.test.js +0 -12
  388. package/src/directive/inject/inject.html +0 -19
  389. package/src/directive/inject/inject.js +0 -35
  390. package/src/directive/inject/inject.spec.js +0 -108
  391. package/src/directive/inject/inject.test.js +0 -12
  392. package/src/directive/input/input-example.html +0 -15
  393. package/src/directive/input/input.html +0 -19
  394. package/src/directive/input/input.js +0 -1078
  395. package/src/directive/input/input.md +0 -706
  396. package/src/directive/input/input.spec.js +0 -3700
  397. package/src/directive/input/input.test.js +0 -12
  398. package/src/directive/messages/messages.html +0 -22
  399. package/src/directive/messages/messages.js +0 -349
  400. package/src/directive/messages/messages.md +0 -543
  401. package/src/directive/messages/messages.spec.js +0 -1083
  402. package/src/directive/messages/messages.test.js +0 -12
  403. package/src/directive/model/change.md +0 -25
  404. package/src/directive/model/model.html +0 -19
  405. package/src/directive/model/model.js +0 -1170
  406. package/src/directive/model/model.spec.js +0 -1976
  407. package/src/directive/model/model.test.js +0 -12
  408. package/src/directive/model-options/model-option.test.js +0 -12
  409. package/src/directive/model-options/model-options.html +0 -22
  410. package/src/directive/model-options/model-options.js +0 -142
  411. package/src/directive/model-options/model-options.md +0 -407
  412. package/src/directive/model-options/model-options.spec.js +0 -1022
  413. package/src/directive/non-bindable/non-bindable.html +0 -22
  414. package/src/directive/non-bindable/non-bindable.js +0 -9
  415. package/src/directive/non-bindable/non-bindable.spec.js +0 -59
  416. package/src/directive/non-bindable/non-bindable.test.js +0 -12
  417. package/src/directive/observe/observe-demo.html +0 -184
  418. package/src/directive/observe/observe.html +0 -19
  419. package/src/directive/observe/observe.js +0 -41
  420. package/src/directive/observe/observe.spec.js +0 -106
  421. package/src/directive/observe/observe.test.js +0 -10
  422. package/src/directive/on/on.html +0 -19
  423. package/src/directive/on/on.spec.js +0 -215
  424. package/src/directive/on/on.test.js +0 -12
  425. package/src/directive/options/options-example.html +0 -17
  426. package/src/directive/options/options.html +0 -22
  427. package/src/directive/options/options.js +0 -542
  428. package/src/directive/options/options.md +0 -179
  429. package/src/directive/options/options.spec.js +0 -3554
  430. package/src/directive/options/options.test.js +0 -12
  431. package/src/directive/ref/href.html +0 -19
  432. package/src/directive/ref/href.spec.js +0 -141
  433. package/src/directive/ref/href.test.js +0 -19
  434. package/src/directive/ref/ref.html +0 -19
  435. package/src/directive/ref/ref.js +0 -89
  436. package/src/directive/ref/ref.spec.js +0 -546
  437. package/src/directive/repeat/repeat.html +0 -19
  438. package/src/directive/repeat/repeat.js +0 -333
  439. package/src/directive/repeat/repeat.md +0 -330
  440. package/src/directive/repeat/repeat.spec.js +0 -1209
  441. package/src/directive/repeat/repeat.test.js +0 -12
  442. package/src/directive/script/script.html +0 -19
  443. package/src/directive/script/script.js +0 -17
  444. package/src/directive/script/script.md +0 -11
  445. package/src/directive/script/script.spec.js +0 -47
  446. package/src/directive/script/script.test.js +0 -12
  447. package/src/directive/select/select.html +0 -19
  448. package/src/directive/select/select.js +0 -594
  449. package/src/directive/select/select.md +0 -74
  450. package/src/directive/select/select.spec.js +0 -2566
  451. package/src/directive/select/select.test.js +0 -12
  452. package/src/directive/setter/setter.html +0 -19
  453. package/src/directive/setter/setter.js +0 -59
  454. package/src/directive/setter/setter.spec.js +0 -100
  455. package/src/directive/setter/setter.test.js +0 -12
  456. package/src/directive/show-hide/show-hide.html +0 -22
  457. package/src/directive/show-hide/show-hide.js +0 -65
  458. package/src/directive/show-hide/show-hide.md +0 -255
  459. package/src/directive/show-hide/show-hide.spec.js +0 -268
  460. package/src/directive/show-hide/show-hide.test.js +0 -12
  461. package/src/directive/style/style.html +0 -19
  462. package/src/directive/style/style.js +0 -27
  463. package/src/directive/style/style.md +0 -23
  464. package/src/directive/style/style.spec.js +0 -183
  465. package/src/directive/style/style.test.js +0 -12
  466. package/src/directive/switch/switch.html +0 -19
  467. package/src/directive/switch/switch.js +0 -133
  468. package/src/directive/switch/switch.md +0 -66
  469. package/src/directive/switch/switch.spec.js +0 -509
  470. package/src/directive/switch/switch.test.js +0 -12
  471. package/src/directive/transclude/transclude.js +0 -122
  472. package/src/directive/validators/validators.html +0 -22
  473. package/src/directive/validators/validators.js +0 -346
  474. package/src/directive/validators/validators.spec.js +0 -740
  475. package/src/directive/validators/validators.test.js +0 -12
  476. package/src/filters/filter.js +0 -213
  477. package/src/filters/filter.spec.js +0 -719
  478. package/src/filters/filters.html +0 -22
  479. package/src/filters/filters.js +0 -239
  480. package/src/filters/filters.spec.js +0 -36
  481. package/src/filters/filters.test.js +0 -12
  482. package/src/filters/interface.ts +0 -9
  483. package/src/filters/limit-to.js +0 -55
  484. package/src/filters/limit-to.spec.js +0 -252
  485. package/src/filters/order-by.js +0 -181
  486. package/src/filters/order-by.spec.js +0 -883
  487. package/src/index.js +0 -6
  488. package/src/index.spec.js +0 -11
  489. package/src/injection-tokens.js +0 -81
  490. package/src/interface.ts +0 -430
  491. package/src/ng.js +0 -291
  492. package/src/ng.spec.js +0 -45
  493. package/src/router/common/trace.js +0 -240
  494. package/src/router/directives/component-example.html +0 -37
  495. package/src/router/directives/state-directives.html +0 -22
  496. package/src/router/directives/state-directives.js +0 -393
  497. package/src/router/directives/state-directives.md +0 -435
  498. package/src/router/directives/state-directives.spec.js +0 -1091
  499. package/src/router/directives/state-directives.test.js +0 -10
  500. package/src/router/directives/view-directive.js +0 -489
  501. package/src/router/directives/view-directive.spec.js +0 -1921
  502. package/src/router/directives/view-directive.test.js +0 -10
  503. package/src/router/directives/view-directives.html +0 -22
  504. package/src/router/glob/glob.html +0 -19
  505. package/src/router/glob/glob.js +0 -102
  506. package/src/router/glob/glob.spec.js +0 -108
  507. package/src/router/glob/glob.test.js +0 -12
  508. package/src/router/hooks/core-resolvables.js +0 -38
  509. package/src/router/hooks/ignored-transition.js +0 -25
  510. package/src/router/hooks/invalid-transition.js +0 -14
  511. package/src/router/hooks/lazy-load.js +0 -104
  512. package/src/router/hooks/on-enter-exit-retain.js +0 -55
  513. package/src/router/hooks/redirect-to.js +0 -38
  514. package/src/router/hooks/resolve.js +0 -57
  515. package/src/router/hooks/update-globals.js +0 -34
  516. package/src/router/hooks/url.js +0 -34
  517. package/src/router/hooks/views.js +0 -41
  518. package/src/router/params/interface.ts +0 -626
  519. package/src/router/params/param-factory.js +0 -23
  520. package/src/router/params/param-type.js +0 -133
  521. package/src/router/params/param-types.js +0 -153
  522. package/src/router/params/param.js +0 -243
  523. package/src/router/params/state-params.js +0 -36
  524. package/src/router/path/path-node.js +0 -78
  525. package/src/router/path/path-utils.js +0 -207
  526. package/src/router/resolve/interface.ts +0 -208
  527. package/src/router/resolve/resolvable.js +0 -123
  528. package/src/router/resolve/resolve-context.js +0 -190
  529. package/src/router/router-test-hashbang.html +0 -45
  530. package/src/router/router-test.html +0 -41
  531. package/src/router/router.html +0 -22
  532. package/src/router/router.js +0 -54
  533. package/src/router/router.test.js +0 -12
  534. package/src/router/services.spec.js +0 -52
  535. package/src/router/state/interface.ts +0 -1007
  536. package/src/router/state/state-builder.js +0 -376
  537. package/src/router/state/state-builder.spec.js +0 -86
  538. package/src/router/state/state-matcher.js +0 -64
  539. package/src/router/state/state-object.js +0 -118
  540. package/src/router/state/state-queue-manager.js +0 -95
  541. package/src/router/state/state-registry.js +0 -262
  542. package/src/router/state/state-service.js +0 -687
  543. package/src/router/state/state.html +0 -23
  544. package/src/router/state/state.spec.js +0 -1002
  545. package/src/router/state/state.test.js +0 -12
  546. package/src/router/state/target-state.js +0 -162
  547. package/src/router/state/views.js +0 -195
  548. package/src/router/state-filter.spec.js +0 -139
  549. package/src/router/state-filters.js +0 -46
  550. package/src/router/template-factory.html +0 -19
  551. package/src/router/template-factory.js +0 -249
  552. package/src/router/template-factory.spec.js +0 -146
  553. package/src/router/template-factory.test.js +0 -12
  554. package/src/router/transition/hook-builder.js +0 -137
  555. package/src/router/transition/hook-registry.js +0 -181
  556. package/src/router/transition/interface.js +0 -18
  557. package/src/router/transition/interface.ts +0 -922
  558. package/src/router/transition/reject-factory.js +0 -122
  559. package/src/router/transition/transition-event-type.js +0 -26
  560. package/src/router/transition/transition-hook.js +0 -199
  561. package/src/router/transition/transition-service.js +0 -297
  562. package/src/router/transition/transition.js +0 -653
  563. package/src/router/url/url-config.js +0 -155
  564. package/src/router/url/url-matcher.js +0 -532
  565. package/src/router/url/url-rule.js +0 -231
  566. package/src/router/url/url-rules.js +0 -350
  567. package/src/router/url/url-service.js +0 -446
  568. package/src/router/url/url-service.spec.js +0 -1288
  569. package/src/router/url/url.html +0 -19
  570. package/src/router/url/url.test.js +0 -12
  571. package/src/router/view/interface.ts +0 -51
  572. package/src/router/view/view.html +0 -19
  573. package/src/router/view/view.js +0 -262
  574. package/src/router/view/view.spec.js +0 -100
  575. package/src/router/view/view.test.js +0 -12
  576. package/src/router/view-hook.spec.js +0 -215
  577. package/src/router/view-scroll.js +0 -33
  578. package/src/router/view-scroll.spec.js +0 -72
  579. package/src/services/anchor-scroll/anchor-scroll.html +0 -76
  580. package/src/services/anchor-scroll/anchor-scroll.js +0 -147
  581. package/src/services/exception/exception-handler.js +0 -75
  582. package/src/services/exception/interface.ts +0 -7
  583. package/src/services/http/http.html +0 -23
  584. package/src/services/http/http.js +0 -1109
  585. package/src/services/http/http.spec.js +0 -4320
  586. package/src/services/http/http.test.js +0 -11
  587. package/src/services/http/interface.ts +0 -256
  588. package/src/services/http/template-request.spec.js +0 -220
  589. package/src/services/location/interface.ts +0 -70
  590. package/src/services/location/location.html +0 -22
  591. package/src/services/location/location.js +0 -1006
  592. package/src/services/location/location.spec.js +0 -3792
  593. package/src/services/location/location.test.js +0 -12
  594. package/src/services/log/interface.ts +0 -39
  595. package/src/services/log/log.html +0 -19
  596. package/src/services/log/log.js +0 -74
  597. package/src/services/log/log.spec.js +0 -64
  598. package/src/services/log/log.test.js +0 -12
  599. package/src/services/pubsub/pubsub.html +0 -19
  600. package/src/services/pubsub/pubsub.js +0 -349
  601. package/src/services/pubsub/pubsub.spec.js +0 -400
  602. package/src/services/pubsub/pubsub.test.js +0 -12
  603. package/src/services/sce/sce.html +0 -19
  604. package/src/services/sce/sce.js +0 -852
  605. package/src/services/sce/sce.spec.js +0 -617
  606. package/src/services/sce/sce.test.js +0 -12
  607. package/src/services/template-cache/template-cache.html +0 -22
  608. package/src/services/template-cache/template-cache.js +0 -15
  609. package/src/services/template-cache/template-cache.spec.js +0 -134
  610. package/src/services/template-cache/template-cache.test.js +0 -12
  611. package/src/services/template-request/interface.ts +0 -23
  612. package/src/services/template-request/template-request.js +0 -142
  613. package/src/shared/cache.js +0 -7
  614. package/src/shared/common.js +0 -365
  615. package/src/shared/common.spec.js +0 -294
  616. package/src/shared/constants.js +0 -21
  617. package/src/shared/dom.js +0 -716
  618. package/src/shared/hof.js +0 -157
  619. package/src/shared/hof.spec.js +0 -60
  620. package/src/shared/interface.ts +0 -21
  621. package/src/shared/min-err.spec.js +0 -178
  622. package/src/shared/noderef.js +0 -225
  623. package/src/shared/predicates.js +0 -34
  624. package/src/shared/queue.js +0 -105
  625. package/src/shared/queue.spec.js +0 -80
  626. package/src/shared/shared.html +0 -24
  627. package/src/shared/shared.test.js +0 -12
  628. package/src/shared/strings.js +0 -142
  629. package/src/shared/strings.spec.js +0 -40
  630. package/src/shared/test-utils.js +0 -47
  631. package/src/shared/url-utils/interface.ts +0 -54
  632. package/src/shared/url-utils/url-utils.html +0 -22
  633. package/src/shared/url-utils/url-utils.js +0 -122
  634. package/src/shared/url-utils/url-utils.spec.js +0 -148
  635. package/src/shared/url-utils/url-utils.test.js +0 -12
  636. package/src/shared/utils.js +0 -1255
  637. package/src/shared/utils.spec.js +0 -178
  638. package/src/src.html +0 -21
  639. package/src/src.test.js +0 -10
  640. package/tsconfig.json +0 -19
  641. package/tsconfig.types.json +0 -14
  642. package/typedoc.json +0 -8
  643. package/utils/express.js +0 -203
  644. package/utils/version.cjs +0 -23
  645. package/vite.config.js +0 -14
@@ -1,1170 +0,0 @@
1
- import {
2
- DIRTY_CLASS,
3
- EMPTY_CLASS,
4
- INVALID_CLASS,
5
- NOT_EMPTY_CLASS,
6
- PRISTINE_CLASS,
7
- TOUCHED_CLASS,
8
- UNTOUCHED_CLASS,
9
- VALID_CLASS,
10
- } from "../../shared/constants.js";
11
- import {
12
- hasAnimate,
13
- isBoolean,
14
- isFunction,
15
- isNumber,
16
- isNumberNaN,
17
- isObjectEmpty,
18
- isPromiseLike,
19
- isProxy,
20
- isUndefined,
21
- minErr,
22
- snakeCase,
23
- } from "../../shared/utils.js";
24
- import { nullFormCtrl, PENDING_CLASS } from "../form/form.js";
25
- import { defaultModelOptions } from "../model-options/model-options.js";
26
- import { startingTag } from "../../shared/dom.js";
27
- import { $injectTokens as $t } from "../../injection-tokens.js";
28
-
29
- export const ngModelMinErr = minErr("ngModel");
30
-
31
- /**
32
- *
33
- * @property {*} $viewValue The actual value from the control's view.
34
- *
35
- * @property {*} $modelValue The value in the model that the control is bound to.
36
- * @property {Array.<Function>} $parsers Array of functions to execute, as a pipeline, whenever
37
- * the control updates the ngModelController with a new `$viewValue` from the DOM, usually via user input.
38
- *
39
- * @property {Array.<Function>} $formatters Array of functions to execute, as a pipeline, whenever
40
- the bound ngModel expression changes programmatically. The `$formatters` are not called when the
41
- value of the control is changed by user interaction.
42
- *
43
- * @property {Object.<string, (string, string) => boolean>} $validators A collection of validators that are applied whenever the model value changes.
44
- * The key value within the object refers to the name of the validator while the function refers to the validation operation.
45
- * The validation operation is provided with the model value as an argument and must return a true or false value depending on the response of that validation.
46
- *
47
- * @property {Object.<string, function(string, string) => Promise>} $asyncValidators A collection of validations that are expected to perform an asynchronous validation (e.g. a HTTP request).
48
- * The validation function that is provided is expected to return a promise when it is run during the model validation process
49
- *
50
- * @property {Array.<Function>} $viewChangeListeners Array of functions to execute whenever
51
- * a change to {@link ngModel.NgModelController#$viewValue `$viewValue`} has caused a change
52
- * to {@link ngModel.NgModelController#$modelValue `$modelValue`}.
53
- * It is called with no arguments, and its return value is ignored.
54
- * This can be used in place of additional $watches against the model value.
55
- *
56
- * @property {Object} $error An object hash with all failing validator ids as keys.
57
- * @property {Object} $pending An object hash with all pending validator ids as keys.
58
- *
59
- * @property {boolean} $untouched True if control has not lost focus yet.
60
- * @property {boolean} $touched True if control has lost focus.
61
- * @property {boolean} $pristine True if user has not interacted with the control yet.
62
- * @property {boolean} $dirty True if user has already interacted with the control.
63
- * @property {boolean} $valid True if there is no error.
64
- * @property {boolean} $invalid True if at least one error on the control.
65
- * @property {string} $name The name attribute of the control.
66
- */
67
-
68
- export class NgModelController {
69
- static $nonscope = true;
70
- /* @ignore */ static $inject = [
71
- "$scope",
72
- $t.$exceptionHandler,
73
- "$attrs",
74
- "$element",
75
- $t.$parse,
76
- $t.$animate,
77
- $t.$interpolate,
78
- ];
79
-
80
- /**
81
- * @param {import('../../core/scope/scope.js').Scope} $scope
82
- * @param {import('../../services/exception/exception-handler.js').ErrorHandler} $exceptionHandler
83
- * @param {import('../../core/compile/attributes.js').Attributes} $attr
84
- * @param {Element} $element
85
- * @param {import("../../core/parse/interface.ts").ParseService} $parse
86
- * @param {*} $animate
87
- * @param {*} $interpolate
88
- */
89
- constructor(
90
- $scope,
91
- $exceptionHandler,
92
- $attr,
93
- $element,
94
- $parse,
95
- $animate,
96
- $interpolate,
97
- ) {
98
- /** @type {any} The actual value from the control's view */
99
- this.$viewValue = Number.NaN;
100
-
101
- /** @type {any} The value in the model that the control is bound to. */
102
- this.$modelValue = Number.NaN;
103
- /** @type {any} */
104
- this.$$rawModelValue = undefined; // stores the parsed modelValue / model set from scope regardless of validity.
105
-
106
- this.$validators = {};
107
- this.$asyncValidators = {};
108
- this.$parsers = [];
109
- this.$formatters = [];
110
- this.$viewChangeListeners = [];
111
- this.$untouched = true;
112
-
113
- /** @type {boolean} */
114
- this.$touched = false;
115
-
116
- /** @type {boolean} */
117
- this.$pristine = true;
118
-
119
- /** @type {boolean} */
120
- this.$dirty = false;
121
-
122
- /** @type {boolean} */
123
- this.$valid = true;
124
-
125
- /** @type {boolean} */
126
- this.$invalid = false;
127
-
128
- this.$error = {}; // keep invalid keys here
129
- this.$$success = {}; // keep valid keys here
130
- this.$pending = undefined; // keep pending keys here
131
- this.$name = $interpolate($attr["name"] || "", false)($scope);
132
- this.$$parentForm = nullFormCtrl;
133
- this.$options = defaultModelOptions;
134
- this.$$updateEvents = "";
135
- // Attach the correct context to the event handler function for updateOn
136
- this.$$updateEventHandler = this.$$updateEventHandler.bind(this);
137
-
138
- this.$$parsedNgModel = $parse($attr["ngModel"]);
139
- this.$$parsedNgModelAssign = this.$$parsedNgModel.assign;
140
-
141
- /**
142
- * @type {import("../../core/parse/interface.ts").CompiledExpression |
143
- * (function(import("../../core/scope/scope.js").Scope): any)}
144
- */
145
- this.$$ngModelGet = this.$$parsedNgModel;
146
- this.$$ngModelSet = this.$$parsedNgModelAssign;
147
- this.$$pendingDebounce = null;
148
- this.$$parserValid = undefined;
149
-
150
- /** @type {string} */
151
- this.$$parserName = "parse";
152
-
153
- /** @type {number} */
154
- this.$$currentValidationRunId = 0;
155
-
156
- /** @type {import('../../core/scope/scope.js').Scope} */
157
- this.$$scope = $scope; // attempt to bind to nearest controller if present
158
- this.$$attr = $attr;
159
- this.$$element = $element;
160
- this.$$animate = $animate;
161
- this.$$parse = $parse;
162
- this.$$exceptionHandler = $exceptionHandler;
163
-
164
- this.$$hasNativeValidators = false;
165
-
166
- this.$$classCache = {};
167
- const isValid = this.$$element.classList.contains(VALID_CLASS);
168
- this.$$classCache[VALID_CLASS] = isValid;
169
- this.$$classCache[INVALID_CLASS] = !isValid;
170
-
171
- this.$$eventRemovers = new Set();
172
-
173
- setupModelWatcher(this);
174
- }
175
-
176
- set(object, property) {
177
- object[property] = true;
178
- }
179
- unset(object, property) {
180
- delete object[property];
181
- }
182
-
183
- $setValidity(validationErrorKey, state) {
184
- let that = this;
185
-
186
- function createAndSet(ctrl, name, value) {
187
- if (!ctrl[name]) {
188
- ctrl[name] = {};
189
- }
190
- that.set(ctrl[name], value);
191
- }
192
-
193
- function unsetAndCleanup(ctrl, name, value) {
194
- if (ctrl[name]) {
195
- that.unset(ctrl[name], value);
196
- }
197
- if (isObjectEmpty(ctrl[name])) {
198
- ctrl[name] = undefined;
199
- }
200
- }
201
-
202
- function cachedToggleClass(ctrl, className, switchValue) {
203
- if (switchValue && !ctrl.$$classCache[className]) {
204
- if (hasAnimate(ctrl.$$element)) {
205
- ctrl.$$animate.addClass(ctrl.$$element, className);
206
- } else {
207
- ctrl.$$element.classList.add(className);
208
- }
209
-
210
- ctrl.$$classCache[className] = true;
211
- } else if (!switchValue && ctrl.$$classCache[className]) {
212
- if (hasAnimate(ctrl.$$element)) {
213
- ctrl.$$animate.removeClass(ctrl.$$element, className);
214
- } else {
215
- ctrl.$$element.classList.remove(className);
216
- }
217
- ctrl.$$classCache[className] = false;
218
- }
219
- }
220
-
221
- function toggleValidationCss(ctrl, validationErrorKey, isValid) {
222
- validationErrorKey = validationErrorKey
223
- ? `-${snakeCase(validationErrorKey, "-")}`
224
- : "";
225
-
226
- cachedToggleClass(
227
- ctrl,
228
- VALID_CLASS + validationErrorKey,
229
- isValid === true,
230
- );
231
- cachedToggleClass(
232
- ctrl,
233
- INVALID_CLASS + validationErrorKey,
234
- isValid === false,
235
- );
236
- }
237
-
238
- if (isUndefined(state)) {
239
- createAndSet(this, "$pending", validationErrorKey);
240
- } else {
241
- unsetAndCleanup(this, "$pending", validationErrorKey);
242
- }
243
- if (!isBoolean(state)) {
244
- delete this.$error[validationErrorKey];
245
- delete this.$$success[validationErrorKey];
246
- } else if (state) {
247
- delete this.$error[validationErrorKey];
248
- this.set(this.$$success, validationErrorKey);
249
- } else {
250
- this.set(this.$error, validationErrorKey);
251
- delete this.$$success[validationErrorKey];
252
- }
253
- if (this.$pending) {
254
- cachedToggleClass(this, PENDING_CLASS, true);
255
- this.$valid = this.$invalid = undefined;
256
- toggleValidationCss(this, "", null);
257
- } else {
258
- cachedToggleClass(this, PENDING_CLASS, false);
259
- this.$valid = isObjectEmpty(this.$error);
260
- this.$invalid = !this.$valid;
261
- toggleValidationCss(this, "", this.$valid);
262
- }
263
-
264
- // re-read the state as the set/unset methods could have
265
- // combined state in this.$error[validationError] (used for forms),
266
- // where setting/unsetting only increments/decrements the value,
267
- // and does not replace it.
268
- let combinedState;
269
- if (this.$pending && this.$pending[validationErrorKey]) {
270
- combinedState = undefined;
271
- } else if (this.$error[validationErrorKey]) {
272
- combinedState = false;
273
- } else if (this.$$success[validationErrorKey]) {
274
- combinedState = true;
275
- } else {
276
- combinedState = null;
277
- }
278
-
279
- toggleValidationCss(this, validationErrorKey, combinedState);
280
- this.$$parentForm.$setValidity(validationErrorKey, combinedState, this);
281
- }
282
-
283
- $$initGetterSetters() {
284
- if (this.$options.getOption("getterSetter")) {
285
- const invokeModelGetter = this.$$parse(`${this.$$attr["ngModel"]}()`);
286
- const invokeModelSetter = this.$$parse(`${this.$$attr["ngModel"]}($$$p)`);
287
-
288
- this.$$ngModelGet = ($scope) => {
289
- let modelValue = this.$$parsedNgModel($scope);
290
- if (isFunction(modelValue)) {
291
- modelValue = invokeModelGetter($scope);
292
- }
293
- return modelValue;
294
- };
295
- this.$$ngModelSet = ($scope, newValue) => {
296
- if (isFunction(this.$$parsedNgModel($scope))) {
297
- invokeModelSetter($scope, { $$$p: newValue });
298
- } else {
299
- this.$$parsedNgModelAssign($scope, newValue);
300
- }
301
- };
302
- } else if (!this.$$parsedNgModel.assign) {
303
- throw ngModelMinErr(
304
- "nonassign",
305
- "Expression '{0}' is non-assignable. Element: {1}",
306
- this.$$attr["ngModel"],
307
- startingTag(this.$$element),
308
- );
309
- }
310
- }
311
-
312
- /**
313
- * Called when the view needs to be updated. It is expected that the user of the ng-model
314
- * directive will implement this method.
315
- *
316
- * The `$render()` method is invoked in the following situations:
317
- *
318
- * * `$rollbackViewValue()` is called. If we are rolling back the view value to the last
319
- * committed value then `$render()` is called to update the input control.
320
- * * The value referenced by `ng-model` is changed programmatically and both the `$modelValue` and
321
- * the `$viewValue` are different from last time.
322
- *
323
- * Since `ng-model` does not do a deep watch, `$render()` is only invoked if the values of
324
- * `$modelValue` and `$viewValue` are actually different from their previous values. If `$modelValue`
325
- * or `$viewValue` are objects (rather than a string or number) then `$render()` will not be
326
- * invoked if you only change a property on the objects.
327
- */
328
- $render() {}
329
-
330
- /**
331
- * This is called when we need to determine if the value of an input is empty.
332
- *
333
- * For instance, the required directive does this to work out if the input has data or not.
334
- *
335
- * The default `$isEmpty` function checks whether the value is `undefined`, `''`, `null` or `NaN`.
336
- *
337
- * You can override this for input directives whose concept of being empty is different from the
338
- * default. The `checkboxInputType` directive does this because in its case a value of `false`
339
- * implies empty.
340
- *
341
- * @param {*} value The value of the input to check for emptiness.
342
- * @returns {boolean} True if `value` is "empty".
343
- */
344
- $isEmpty(value) {
345
- return (
346
- isUndefined(value) || value === "" || value === null || value !== value
347
- );
348
- }
349
-
350
- $$updateEmptyClasses(value) {
351
- if (this.$isEmpty(value)) {
352
- if (hasAnimate(this.$$element)) {
353
- this.$$animate.removeClass(this.$$element, NOT_EMPTY_CLASS);
354
- this.$$animate.addClass(this.$$element, EMPTY_CLASS);
355
- } else {
356
- this.$$element.classList.remove(NOT_EMPTY_CLASS);
357
- this.$$element.classList.add(EMPTY_CLASS);
358
- }
359
- } else {
360
- if (hasAnimate(this.$$element)) {
361
- this.$$animate.removeClass(this.$$element, EMPTY_CLASS);
362
- this.$$animate.addClass(this.$$element, NOT_EMPTY_CLASS);
363
- } else {
364
- this.$$element.classList.remove(EMPTY_CLASS);
365
- this.$$element.classList.add(NOT_EMPTY_CLASS);
366
- }
367
- }
368
- }
369
-
370
- /**
371
- * Sets the control to its pristine state.
372
- *
373
- * This method can be called to remove the `ng-dirty` class and set the control to its pristine
374
- * state (`ng-pristine` class). A model is considered to be pristine when the control
375
- * has not been changed from when first compiled.
376
- */
377
- $setPristine() {
378
- this.$dirty = false;
379
- this.$pristine = true;
380
- if (!this.$$element) return;
381
- if (hasAnimate(this.$$element)) {
382
- this.$$animate.removeClass(this.$$element, EMPTY_CLASS);
383
- this.$$animate.addClass(this.$$element, PRISTINE_CLASS);
384
- } else {
385
- this.$$element.classList.remove(EMPTY_CLASS);
386
- this.$$element.classList.add(PRISTINE_CLASS);
387
- }
388
- }
389
-
390
- /**
391
- * Sets the control to its dirty state.
392
- *
393
- * This method can be called to remove the `ng-pristine` class and set the control to its dirty
394
- * state (`ng-dirty` class). A model is considered to be dirty when the control has been changed
395
- * from when first compiled.
396
- */
397
- $setDirty() {
398
- this.$dirty = true;
399
- this.$pristine = false;
400
- if (hasAnimate(this.$$element)) {
401
- this.$$animate.removeClass(this.$$element, PRISTINE_CLASS);
402
- this.$$animate.addClass(this.$$element, DIRTY_CLASS);
403
- } else {
404
- this.$$element.classList.remove(PRISTINE_CLASS);
405
- this.$$element.classList.add(DIRTY_CLASS);
406
- }
407
- this.$$parentForm.$setDirty();
408
- }
409
-
410
- /**
411
- * Sets the control to its untouched state.
412
- *
413
- * This method can be called to remove the `ng-touched` class and set the control to its
414
- * untouched state (`ng-untouched` class). Upon compilation, a model is set as untouched
415
- * by default, however this function can be used to restore that state if the model has
416
- * already been touched by the user.
417
- */
418
- $setUntouched() {
419
- this.$touched = false;
420
- this.$untouched = true;
421
- if (hasAnimate(this.$$element)) {
422
- this.$$animate.setClass(this.$$element, UNTOUCHED_CLASS, TOUCHED_CLASS);
423
- } else {
424
- this.$$element.classList.remove(TOUCHED_CLASS);
425
- this.$$element.classList.add(UNTOUCHED_CLASS);
426
- }
427
- }
428
-
429
- /**
430
- * Sets the control to its touched state.
431
- *
432
- * This method can be called to remove the `ng-untouched` class and set the control to its
433
- * touched state (`ng-touched` class). A model is considered to be touched when the user has
434
- * first focused the control element and then shifted focus away from the control (blur event).
435
- */
436
- $setTouched() {
437
- this.$touched = true;
438
- this.$untouched = false;
439
- if (hasAnimate(this.$$element)) {
440
- this.$$animate.setClass(this.$$element, TOUCHED_CLASS, UNTOUCHED_CLASS);
441
- } else {
442
- this.$$element.classList.remove(UNTOUCHED_CLASS);
443
- this.$$element.classList.add(TOUCHED_CLASS);
444
- }
445
- }
446
-
447
- /**
448
- * Cancel an update and reset the input element's value to prevent an update to the `$modelValue`,
449
- * which may be caused by a pending debounced event or because the input is waiting for some
450
- * future event.
451
- *
452
- * If you have an input that uses `ng-model-options` to set up debounced updates or updates that
453
- * depend on special events such as `blur`, there can be a period when the `$viewValue` is out of
454
- * sync with the ngModel's `$modelValue`.
455
- *
456
- * In this case, you can use `$rollbackViewValue()` to manually cancel the debounced / future update
457
- * and reset the input to the last committed view value.
458
- *
459
- * It is also possible that you run into difficulties if you try to update the ngModel's `$modelValue`
460
- * programmatically before these debounced/future events have resolved/occurred, because AngularTS's
461
- * dirty checking mechanism is not able to tell whether the model has actually changed or not.
462
- *
463
- * The `$rollbackViewValue()` method should be called before programmatically changing the model of an
464
- * input which may have such events pending. This is important in order to make sure that the
465
- * input field will be updated with the new model value and any pending operations are cancelled.
466
- *
467
- * @example
468
- * <example name="ng-model-cancel-update" module="cancel-update-example">
469
- * <file name="app.js">
470
- * angular.module('cancel-update-example', [])
471
- *
472
- * .controller('CancelUpdateController', ['$scope', function($scope) {
473
- * $scope.model = {value1: '', value2: ''};
474
- *
475
- * $scope.setEmpty = function(e, value, rollback) {
476
- * if (e.keyCode === 27) {
477
- * e.preventDefault();
478
- * if (rollback) {
479
- * $scope.myForm[value].$rollbackViewValue();
480
- * }
481
- * $scope.model[value] = '';
482
- * }
483
- * };
484
- * }]);
485
- * </file>
486
- * <file name="index.html">
487
- * <div ng-controller="CancelUpdateController">
488
- * <p>Both of these inputs are only updated if they are blurred. Hitting escape should
489
- * empty them. Follow these steps and observe the difference:</p>
490
- * <ol>
491
- * <li>Type something in the input. You will see that the model is not yet updated</li>
492
- * <li>Press the Escape key.
493
- * <ol>
494
- * <li> In the first example, nothing happens, because the model is already '', and no
495
- * update is detected. If you blur the input, the model will be set to the current view.
496
- * </li>
497
- * <li> In the second example, the pending update is cancelled, and the input is set back
498
- * to the last committed view value (''). Blurring the input does nothing.
499
- * </li>
500
- * </ol>
501
- * </li>
502
- * </ol>
503
- *
504
- * <form name="myForm" ng-model-options="{ updateOn: 'blur' }">
505
- * <div>
506
- * <p id="inputDescription1">Without $rollbackViewValue():</p>
507
- * <input name="value1" aria-describedby="inputDescription1" ng-model="model.value1"
508
- * ng-keydown="setEmpty($event, 'value1')">
509
- * value1: "{{ model.value1 }}"
510
- * </div>
511
- *
512
- * <div>
513
- * <p id="inputDescription2">With $rollbackViewValue():</p>
514
- * <input name="value2" aria-describedby="inputDescription2" ng-model="model.value2"
515
- * ng-keydown="setEmpty($event, 'value2', true)">
516
- * value2: "{{ model.value2 }}"
517
- * </div>
518
- * </form>
519
- * </div>
520
- * </file>
521
- <file name="style.css">
522
- div {
523
- display: table-cell;
524
- }
525
- div:nth-child(1) {
526
- padding-right: 30px;
527
- }
528
-
529
- </file>
530
- * </example>
531
- */
532
- $rollbackViewValue() {
533
- clearTimeout(this.$$pendingDebounce);
534
- this.$viewValue = this.$$lastCommittedViewValue;
535
- this.$render();
536
- }
537
-
538
- /**
539
- * Runs each of the registered validators (first synchronous validators and then
540
- * asynchronous validators).
541
- * If the validity changes to invalid, the model will be set to `undefined`,
542
- * unless {@link ngModelOptions `ngModelOptions.allowInvalid`} is `true`.
543
- * If the validity changes to valid, it will set the model to the last available valid
544
- * `$modelValue`, i.e. either the last parsed value or the last value set from the scope.
545
- */
546
- $validate() {
547
- // ignore $validate before model is initialized
548
- if (isNumberNaN(this.$modelValue)) {
549
- return;
550
- }
551
-
552
- const viewValue = this.$$lastCommittedViewValue;
553
- // Note: we use the $$rawModelValue as $modelValue might have been
554
- // set to undefined during a view -> model update that found validation
555
- // errors. We can't parse the view here, since that could change
556
- // the model although neither viewValue nor the model on the scope changed
557
- const modelValue = this.$$rawModelValue;
558
-
559
- const prevValid = this.$valid;
560
- const prevModelValue = this.$modelValue;
561
-
562
- const allowInvalid = this.$options.getOption("allowInvalid");
563
-
564
- const that = this;
565
- this.$$runValidators(modelValue, viewValue, (allValid) => {
566
- // If there was no change in validity, don't update the model
567
- // This prevents changing an invalid modelValue to undefined
568
- if (!allowInvalid && prevValid !== allValid) {
569
- // Note: Don't check this.$valid here, as we could have
570
- // external validators (e.g. calculated on the server),
571
- // that just call $setValidity and need the model value
572
- // to calculate their validity.
573
- that.$modelValue = allValid ? modelValue : undefined;
574
-
575
- if (that.$modelValue !== prevModelValue) {
576
- that.$$writeModelToScope();
577
- }
578
- }
579
- });
580
- }
581
-
582
- $$runValidators(modelValue, viewValue, doneCallback) {
583
- this.$$currentValidationRunId++;
584
- const localValidationRunId = this.$$currentValidationRunId;
585
- const that = this;
586
-
587
- // check parser error
588
- if (!processParseErrors()) {
589
- validationDone(false);
590
- return;
591
- }
592
- if (!processSyncValidators()) {
593
- validationDone(false);
594
- return;
595
- }
596
- processAsyncValidators();
597
-
598
- function processParseErrors() {
599
- const errorKey = that.$$parserName;
600
-
601
- if (isUndefined(that.$$parserValid)) {
602
- setValidity(errorKey, null);
603
- } else {
604
- if (!that.$$parserValid) {
605
- Object.keys(that.$validators).forEach((name) => {
606
- setValidity(name, null);
607
- });
608
- Object.keys(that.$asyncValidators).forEach((name) => {
609
- setValidity(name, null);
610
- });
611
- }
612
-
613
- // Set the parse error last, to prevent unsetting it, should a $validators key == parserName
614
- setValidity(errorKey, that.$$parserValid);
615
- return that.$$parserValid;
616
- }
617
- return true;
618
- }
619
-
620
- function processSyncValidators() {
621
- let syncValidatorsValid = true;
622
- Object.entries(that.$validators).forEach(([name, validator]) => {
623
- const result = Boolean(validator(modelValue, viewValue));
624
- syncValidatorsValid = syncValidatorsValid && result;
625
- setValidity(name, result);
626
- });
627
- if (!syncValidatorsValid) {
628
- Object.keys(that.$asyncValidators).forEach((name) => {
629
- setValidity(name, null);
630
- });
631
- return false;
632
- }
633
- return true;
634
- }
635
-
636
- function processAsyncValidators() {
637
- const validatorPromises = [];
638
- let allValid = true;
639
- Object.entries(that.$asyncValidators).forEach(([name, validator]) => {
640
- const promise = validator(modelValue, viewValue);
641
- if (!isPromiseLike(promise)) {
642
- throw ngModelMinErr(
643
- "nopromise",
644
- "Expected asynchronous validator to return a promise but got '{0}' instead.",
645
- promise,
646
- );
647
- }
648
- setValidity(name, undefined);
649
- validatorPromises.push(
650
- promise.then(
651
- () => {
652
- setValidity(name, true);
653
- },
654
- () => {
655
- allValid = false;
656
- setValidity(name, false);
657
- },
658
- ),
659
- );
660
- });
661
- if (!validatorPromises.length) {
662
- validationDone(true);
663
- } else {
664
- Promise.all(validatorPromises).then(
665
- () => {
666
- validationDone(allValid);
667
- },
668
- () => {},
669
- );
670
- }
671
- }
672
-
673
- function setValidity(name, isValid) {
674
- if (localValidationRunId === that.$$currentValidationRunId) {
675
- that.$setValidity(name, isValid);
676
- }
677
- }
678
-
679
- function validationDone(allValid) {
680
- if (localValidationRunId === that.$$currentValidationRunId) {
681
- doneCallback(allValid);
682
- }
683
- }
684
- }
685
-
686
- /**
687
- * Commit a pending update to the `$modelValue`.
688
- *
689
- * Updates may be pending by a debounced event or because the input is waiting for a some future
690
- * event defined in `ng-model-options`. this method is rarely needed as `NgModelController`
691
- * usually handles calling this in response to input events.
692
- */
693
- $commitViewValue() {
694
- clearTimeout(this.$$pendingDebounce);
695
-
696
- // If the view value has not changed then we should just exit, except in the case where there is
697
- // a native validator on the element. In this case the validation state may have changed even though
698
- // the viewValue has stayed empty.
699
- if (
700
- this.$$lastCommittedViewValue === this.$viewValue &&
701
- (this.$viewValue !== "" || !this.$$hasNativeValidators)
702
- ) {
703
- return;
704
- }
705
-
706
- if (
707
- this.$$lastCommittedViewValue === undefined &&
708
- Number.isNaN(this.$viewValue)
709
- ) {
710
- return;
711
- }
712
-
713
- this.$$updateEmptyClasses(this.$viewValue);
714
- this.$$lastCommittedViewValue = this.$viewValue;
715
-
716
- // change to dirty
717
- if (this.$pristine) {
718
- this.$setDirty();
719
- }
720
- this.$$parseAndValidate();
721
- }
722
-
723
- $$parseAndValidate() {
724
- let modelValue = this.$$lastCommittedViewValue;
725
- const that = this;
726
-
727
- this.$$parserValid = isUndefined(modelValue) ? undefined : true;
728
-
729
- // Reset any previous parse error
730
- this.$setValidity(this.$$parserName, null);
731
- this.$$parserName = "parse";
732
-
733
- if (this.$$parserValid) {
734
- for (let i = 0; i < this.$parsers.length; i++) {
735
- modelValue = this.$parsers[i](modelValue);
736
- if (isUndefined(modelValue)) {
737
- this.$$parserValid = false;
738
- break;
739
- }
740
- }
741
- }
742
- if (isNumberNaN(this.$modelValue)) {
743
- // this.$modelValue has not been touched yet...
744
- // @ts-ignore
745
- this.$modelValue = this.$$ngModelGet(this.$$scope);
746
- }
747
- const prevModelValue = this.$modelValue;
748
- const allowInvalid = this.$options.getOption("allowInvalid");
749
- this.$$rawModelValue = modelValue;
750
-
751
- if (allowInvalid) {
752
- this.$modelValue = modelValue;
753
- writeToModelIfNeeded();
754
- }
755
-
756
- // Pass the $$lastCommittedViewValue here, because the cached viewValue might be out of date.
757
- // This can happen if e.g. $setViewValue is called from inside a parser
758
- this.$$runValidators(
759
- modelValue,
760
- this.$$lastCommittedViewValue,
761
- (allValid) => {
762
- if (!allowInvalid) {
763
- // Note: Don't check this.$valid here, as we could have
764
- // external validators (e.g. calculated on the server),
765
- // that just call $setValidity and need the model value
766
- // to calculate their validity.
767
- // if (that.$modelValue ?? that.$modelValue[isProxySymbol]) {
768
- // delete that.$modelValue;
769
- // }
770
- that.$modelValue = allValid ? modelValue : undefined;
771
- writeToModelIfNeeded();
772
- }
773
- },
774
- );
775
-
776
- function writeToModelIfNeeded() {
777
- // intentional loose equality
778
- if (that.$modelValue != prevModelValue) {
779
- that.$$writeModelToScope();
780
- }
781
- }
782
- }
783
-
784
- $$writeModelToScope() {
785
- this.$$ngModelSet(this.$$scope, this.$modelValue);
786
- Object.values(this.$viewChangeListeners).forEach((listener) => {
787
- try {
788
- listener();
789
- } catch (e) {
790
- this.$$exceptionHandler(e);
791
- }
792
- }, this);
793
- }
794
-
795
- /**
796
- * Update the view value.
797
- *
798
- * This method should be called when a control wants to change the view value; typically,
799
- * this is done from within a DOM event handler. For example, the {@link ng.directive:input input}
800
- * directive calls it when the value of the input changes and {@link ng.directive:select select}
801
- * calls it when an option is selected.
802
- *
803
- * When `$setViewValue` is called, the new `value` will be staged for committing through the `$parsers`
804
- * and `$validators` pipelines. If there are no special {@link ngModelOptions} specified then the staged
805
- * value is sent directly for processing through the `$parsers` pipeline. After this, the `$validators` and
806
- * `$asyncValidators` are called and the value is applied to `$modelValue`.
807
- * Finally, the value is set to the **expression** specified in the `ng-model` attribute and
808
- * all the registered change listeners, in the `$viewChangeListeners` list are called.
809
- *
810
- * In case the {@link ng.directive:ngModelOptions ngModelOptions} directive is used with `updateOn`
811
- * and the `default` trigger is not listed, all those actions will remain pending until one of the
812
- * `updateOn` events is triggered on the DOM element.
813
- * All these actions will be debounced if the {@link ng.directive:ngModelOptions ngModelOptions}
814
- * directive is used with a custom debounce for this particular event.
815
- * Note that a `$digest` is only triggered once the `updateOn` events are fired, or if `debounce`
816
- * is specified, once the timer runs out.
817
- *
818
- * When used with standard inputs, the view value will always be a string (which is in some cases
819
- * parsed into another type, such as a `Date` object for `input[date]`.)
820
- * However, custom controls might also pass objects to this method. In this case, we should make
821
- * a copy of the object before passing it to `$setViewValue`. This is because `ngModel` does not
822
- * perform a deep watch of objects, it only looks for a change of identity. If you only change
823
- * the property of the object then ngModel will not realize that the object has changed and
824
- * will not invoke the `$parsers` and `$validators` pipelines. For this reason, you should
825
- * not change properties of the copy once it has been passed to `$setViewValue`.
826
- * Otherwise you may cause the model value on the scope to change incorrectly.
827
- *
828
- * <div class="alert alert-info">
829
- * In any case, the value passed to the method should always reflect the current value
830
- * of the control. For example, if you are calling `$setViewValue` for an input element,
831
- * you should pass the input DOM value. Otherwise, the control and the scope model become
832
- * out of sync. It's also important to note that `$setViewValue` does not call `$render` or change
833
- * the control's DOM value in any way. If we want to change the control's DOM value
834
- * programmatically, we should update the `ngModel` scope expression. Its new value will be
835
- * picked up by the model controller, which will run it through the `$formatters`, `$render` it
836
- * to update the DOM, and finally call `$validate` on it.
837
- * </div>
838
- *
839
- * @param {*} value value from the view.
840
- * @param {string} [trigger] Event that triggered the update.
841
- */
842
- $setViewValue(value, trigger) {
843
- this.$viewValue = value;
844
- if (this.$options?.getOption("updateOnDefault")) {
845
- this.$$debounceViewValueCommit(trigger);
846
- }
847
- }
848
-
849
- $$debounceViewValueCommit(trigger) {
850
- let debounceDelay = this.$options.getOption("debounce");
851
-
852
- if (isNumber(debounceDelay[trigger])) {
853
- debounceDelay = debounceDelay[trigger];
854
- } else if (
855
- isNumber(debounceDelay["default"]) &&
856
- /** @type {string} */ (this.$options.getOption("updateOn")).indexOf(
857
- trigger,
858
- ) === -1
859
- ) {
860
- debounceDelay = debounceDelay["default"];
861
- } else if (isNumber(debounceDelay["*"])) {
862
- debounceDelay = debounceDelay["*"];
863
- }
864
-
865
- clearTimeout(this.$$pendingDebounce);
866
- const that = this;
867
- if (/** @type {number} */ (debounceDelay) > 0) {
868
- // this fails if debounceDelay is an object
869
- this.$$pendingDebounce = setTimeout(() => {
870
- that.$commitViewValue();
871
- }, /** @type {number} */ (debounceDelay));
872
- } else {
873
- this.$commitViewValue();
874
- }
875
- }
876
-
877
- /**
878
- *
879
- * Override the current model options settings programmatically.
880
- *
881
- * The previous `ModelOptions` value will not be modified. Instead, a
882
- * new `ModelOptions` object will inherit from the previous one overriding
883
- * or inheriting settings that are defined in the given parameter.
884
- *
885
- * See {@link ngModelOptions} for information about what options can be specified
886
- * and how model option inheritance works.
887
- *
888
- * <div class="alert alert-warning">
889
- * **Note:** this function only affects the options set on the `ngModelController`,
890
- * and not the options on the {@link ngModelOptions} directive from which they might have been
891
- * obtained initially.
892
- * </div>
893
- *
894
- * <div class="alert alert-danger">
895
- * **Note:** it is not possible to override the `getterSetter` option.
896
- * </div>
897
- *
898
- * @param {Object} options a hash of settings to override the previous options
899
- *
900
- */
901
- $overrideModelOptions(options) {
902
- this.$$removeAllEventListeners();
903
- this.$options = this.$options.createChild(options);
904
- this.$$updateEvents = this.$options.$$options.updateOn;
905
- this.$$setUpdateOnEvents();
906
- }
907
-
908
- /**
909
- * Runs the model -> view pipeline on the current
910
- * {@link ngModel.NgModelController#$modelValue $modelValue}.
911
- *
912
- * The following actions are performed by this method:
913
- *
914
- * - the `$modelValue` is run through the {@link ngModel.NgModelController#$formatters $formatters}
915
- * and the result is set to the {@link ngModel.NgModelController#$viewValue $viewValue}
916
- * - the `ng-empty` or `ng-not-empty` class is set on the element
917
- * - if the `$viewValue` has changed:
918
- * - {@link ngModel.NgModelController#$render $render} is called on the control
919
- * - the {@link ngModel.NgModelController#$validators $validators} are run and
920
- * the validation status is set.
921
- *
922
- * This method is called by ngModel internally when the bound scope value changes.
923
- * Application developers usually do not have to call this function themselves.
924
- *
925
- * This function can be used when the `$viewValue` or the rendered DOM value are not correctly
926
- * formatted and the `$modelValue` must be run through the `$formatters` again.
927
- *
928
- * @example
929
- * Consider a text input with an autocomplete list (for fruit), where the items are
930
- * objects with a name and an id.
931
- * A user enters `ap` and then selects `Apricot` from the list.
932
- * Based on this, the autocomplete widget will call `$setViewValue({name: 'Apricot', id: 443})`,
933
- * but the rendered value will still be `ap`.
934
- * The widget can then call `ctrl.$processModelValue()` to run the model -> view
935
- * pipeline again, which formats the object to the string `Apricot`,
936
- * then updates the `$viewValue`, and finally renders it in the DOM.
937
- *
938
- * <example module="inputExample" name="ng-model-process">
939
- <file name="index.html">
940
- <div ng-controller="inputController" style="display: flex;">
941
- <div style="margin-right: 30px;">
942
- Search Fruit:
943
- <basic-autocomplete items="items" on-select="selectedFruit = item"></basic-autocomplete>
944
- </div>
945
- <div>
946
- Model:<br>
947
- <pre>{{selectedFruit | json}}</pre>
948
- </div>
949
- </div>
950
- </file>
951
- <file name="app.js">
952
- angular.module('inputExample', [])
953
- .controller('inputController', function($scope) {
954
- $scope.items = [
955
- {name: 'Apricot', id: 443},
956
- {name: 'Clementine', id: 972},
957
- {name: 'Durian', id: 169},
958
- {name: 'Jackfruit', id: 982},
959
- {name: 'Strawberry', id: 863}
960
- ];
961
- })
962
- .component('basicAutocomplete', {
963
- bindings: {
964
- items: '<',
965
- onSelect: '&'
966
- },
967
- templateUrl: 'autocomplete.html',
968
- controller: function($element, $scope) {
969
- let that = this;
970
- let ngModel;
971
-
972
- that.$postLink = function() {
973
- ngModel = $element.querySelectorAll('input').controller('ngModel');
974
-
975
- ngModel.$formatters.push(function(value) {
976
- return (value && value.name) || value;
977
- });
978
-
979
- ngModel.$parsers.push(function(value) {
980
- let match = value;
981
- for (let i = 0; i < that.items.length; i++) {
982
- if (that.items[i].name === value) {
983
- match = that.items[i];
984
- break;
985
- }
986
- }
987
-
988
- return match;
989
- });
990
- };
991
-
992
- that.selectItem = function(item) {
993
- ngModel.$setViewValue(item);
994
- ngModel.$processModelValue();
995
- that.onSelect({item: item});
996
- };
997
- }
998
- });
999
- </file>
1000
- <file name="autocomplete.html">
1001
- <div>
1002
- <input type="search" ng-model="$ctrl.searchTerm" />
1003
- <ul>
1004
- <li ng-repeat="item in $ctrl.items | filter:$ctrl.searchTerm">
1005
- <button ng-click="$ctrl.selectItem(item)">{{ item.name }}</button>
1006
- </li>
1007
- </ul>
1008
- </div>
1009
- </file>
1010
- * </example>
1011
- *
1012
- */
1013
- $processModelValue() {
1014
- const viewValue = this.$$format();
1015
-
1016
- if (this.$viewValue !== viewValue) {
1017
- this.$$updateEmptyClasses(viewValue);
1018
- this.$viewValue = this.$$lastCommittedViewValue = viewValue;
1019
- this.$render();
1020
- // It is possible that model and view value have been updated during render
1021
- this.$$runValidators(this.$modelValue, this.$viewValue, () => {});
1022
- }
1023
- }
1024
-
1025
- /**
1026
- * This method is called internally to run the $formatters on the $modelValue
1027
- */
1028
- $$format() {
1029
- const formatters = this.$formatters;
1030
- let idx = formatters.length;
1031
-
1032
- let viewValue = this.$modelValue;
1033
- while (idx--) {
1034
- viewValue = formatters[idx](viewValue);
1035
- }
1036
-
1037
- return viewValue;
1038
- }
1039
-
1040
- /**
1041
- * This method is called internally when the bound scope value changes.
1042
- */
1043
- $$setModelValue(modelValue) {
1044
- this.$modelValue = this.$$rawModelValue = modelValue;
1045
- this.$$parserValid = undefined;
1046
- this.$processModelValue();
1047
- }
1048
-
1049
- $$removeAllEventListeners() {
1050
- this.$$eventRemovers.forEach((removeCallback) => removeCallback());
1051
- this.$$eventRemovers.clear();
1052
- }
1053
-
1054
- $$setUpdateOnEvents() {
1055
- if (this.$$updateEvents) {
1056
- this.$$updateEvents.split(" ").forEach((ev) => {
1057
- this.$$element.addEventListener(ev, this.$$updateEventHandler);
1058
- this.$$eventRemovers.add(() =>
1059
- this.$$element.removeEventListener(ev, this.$$updateEventHandler),
1060
- );
1061
- });
1062
- }
1063
-
1064
- this.$$updateEvents = /** @type {string} */ (
1065
- this.$options.getOption("updateOn")
1066
- );
1067
- if (this.$$updateEvents) {
1068
- this.$$updateEvents.split(" ").forEach((ev) => {
1069
- this.$$element.addEventListener(ev, this.$$updateEventHandler);
1070
- this.$$eventRemovers.add(() =>
1071
- this.$$element.removeEventListener(ev, this.$$updateEventHandler),
1072
- );
1073
- });
1074
- }
1075
- }
1076
-
1077
- $$updateEventHandler(ev) {
1078
- this.$$debounceViewValueCommit(ev && ev.type);
1079
- }
1080
- }
1081
-
1082
- function setupModelWatcher(ctrl) {
1083
- // model -> value
1084
- // Note: we cannot use a normal scope.$watch as we want to detect the following:
1085
- // 1. scope value is 'a'
1086
- // 2. user enters 'b'
1087
- // 3. ng-change kicks in and reverts scope value to 'a'
1088
- // -> scope value did not change since the last digest as
1089
- // ng-change executes in apply phase
1090
- // 4. view should be changed back to 'a'
1091
- ctrl.$$scope.$watch("value", () => {
1092
- const modelValue = ctrl.$$ngModelGet(ctrl.$$scope);
1093
-
1094
- // if scope model value and ngModel value are out of sync
1095
- // This cannot be moved to the action function, because it would not catch the
1096
- // case where the model is changed in the ngChange function or the model setter
1097
- if (
1098
- modelValue !== ctrl.$modelValue &&
1099
- // checks for NaN is needed to allow setting the model to NaN when there's an asyncValidator
1100
-
1101
- (ctrl.$modelValue === ctrl.$modelValue || modelValue === modelValue)
1102
- ) {
1103
- ctrl.$$setModelValue(modelValue);
1104
- }
1105
- });
1106
- }
1107
-
1108
- export function ngModelDirective() {
1109
- return {
1110
- restrict: "A",
1111
- require: ["ngModel", "^?form", "^?ngModelOptions"],
1112
- controller: NgModelController,
1113
- // Prelink needs to run before any input directive
1114
- // so that we can set the NgModelOptions in NgModelController
1115
- // before anyone else uses it.
1116
- priority: 1,
1117
- compile:
1118
- /** @param {Element} element */
1119
- (element) => {
1120
- // Setup initial state of the control
1121
- element.classList.add(PRISTINE_CLASS, UNTOUCHED_CLASS, VALID_CLASS);
1122
- return {
1123
- pre: (scope, _element, attr, ctrls) => {
1124
- const modelCtrl = ctrls[0];
1125
- const formCtrl = ctrls[1] || modelCtrl.$$parentForm;
1126
- const optionsCtrl = ctrls[2];
1127
-
1128
- if (optionsCtrl) {
1129
- modelCtrl.$options = optionsCtrl.$options;
1130
- }
1131
- modelCtrl.$$initGetterSetters();
1132
-
1133
- // notify others, especially parent forms
1134
- formCtrl.$addControl(modelCtrl);
1135
-
1136
- attr.$observe("name", (newValue) => {
1137
- if (modelCtrl.$name !== newValue) {
1138
- modelCtrl.$$parentForm.$$renameControl(modelCtrl, newValue);
1139
- }
1140
- });
1141
- let deregisterWatch = scope.$watch(attr["ngModel"], (val) => {
1142
- modelCtrl.$$setModelValue(isProxy(val) ? val.$target : val);
1143
- });
1144
-
1145
- scope.$on("$destroy", () => {
1146
- modelCtrl.$$parentForm.$removeControl(modelCtrl);
1147
- deregisterWatch();
1148
- });
1149
- },
1150
- post: (scope, element, _attr, ctrls) => {
1151
- const modelCtrl = ctrls[0];
1152
- modelCtrl.$$setUpdateOnEvents();
1153
-
1154
- function setTouched() {
1155
- modelCtrl.$setTouched();
1156
- }
1157
-
1158
- element.addEventListener("blur", () => {
1159
- if (modelCtrl.$touched) return;
1160
- setTouched();
1161
- });
1162
-
1163
- modelCtrl.$viewChangeListeners.push(() =>
1164
- scope.$eval(element.dataset["change"]),
1165
- );
1166
- },
1167
- };
1168
- },
1169
- };
1170
- }