@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,1241 +0,0 @@
1
- import { createInjector } from "../../core/di/injector.js";
2
- import { Angular } from "../../angular.js";
3
- import { dealoc, getController } from "../../shared/dom.js";
4
- import { browserTrigger, wait } from "../../shared/test-utils.js";
5
-
6
- describe("$aria", () => {
7
- let scope;
8
- let $compile;
9
- let element;
10
-
11
- beforeEach(() => {
12
- window.angular = new Angular();
13
- window.angular.module("test", ["ng"]);
14
- let injector = createInjector(["test"]);
15
- scope = injector.get("$rootScope");
16
- $compile = injector.get("$compile");
17
- });
18
-
19
- afterEach(() => {
20
- dealoc(element);
21
- });
22
-
23
- describe("with `ngAriaDisable`", () => {
24
- // ariaChecked
25
- it("should not attach aria-checked to custom checkbox", () => {
26
- element = $compile(
27
- '<div role="checkbox" ng-model="val" ng-aria-disable></div>',
28
- )(scope);
29
-
30
- scope.$apply("val = false");
31
- expect(element.hasAttribute("aria-checked")).toBeFalse();
32
-
33
- scope.$apply("val = true");
34
- expect(element.hasAttribute("aria-checked")).toBeFalse();
35
- });
36
-
37
- it("should not attach aria-checked to custom radio controls", () => {
38
- element = $compile(
39
- '<div><div role="radio" ng-model="val" value="one" ng-aria-disable></div>' +
40
- '<div role="radio" ng-model="val" value="two" ng-aria-disable></div></div>',
41
- )(scope);
42
- const radio1 = element.children[0];
43
- const radio2 = element.children[1];
44
-
45
- scope.$apply('val = "one"');
46
- expect(radio1.hasAttribute("aria-checked")).toBeFalse();
47
- expect(radio2.hasAttribute("aria-checked")).toBeFalse();
48
-
49
- scope.$apply('val = "two"');
50
- expect(radio1.hasAttribute("aria-checked")).toBeFalse();
51
- expect(radio2.hasAttribute("aria-checked")).toBeFalse();
52
- });
53
-
54
- // ariaDisabled
55
- it("should not attach aria-disabled to custom controls", () => {
56
- element = $compile('<div ng-disabled="val" ng-aria-disable></div>')(
57
- scope,
58
- );
59
- scope.$apply("val = false");
60
- expect(element.hasAttribute("aria-disabled")).toBeFalse();
61
-
62
- scope.$apply("val = true");
63
- expect(element.hasAttribute("aria-disabled")).toBeFalse();
64
- });
65
-
66
- // ariaHidden
67
- it("should not attach aria-hidden to `ngShow`", () => {
68
- element = $compile('<div ng-show="val" ng-aria-disable></div>')(scope);
69
- scope.$apply("val = false");
70
- expect(element.hasAttribute("aria-hidden")).toBeFalse();
71
-
72
- scope.$apply("val = true");
73
- expect(element.hasAttribute("aria-hidden")).toBeFalse();
74
- });
75
-
76
- it("should not attach aria-hidden to `ngHide`", () => {
77
- element = $compile('<div ng-hide="val" ng-aria-disable></div>')(scope);
78
- scope.$apply("val = false");
79
- expect(element.hasAttribute("aria-hidden")).toBeFalse();
80
-
81
- scope.$apply("val = true");
82
- expect(element.hasAttribute("aria-hidden")).toBeFalse();
83
- });
84
-
85
- // ariaInvalid
86
- it("should not attach aria-invalid to input", () => {
87
- element = $compile(
88
- '<input ng-model="val" ng-minlength="10" ng-aria-disable />',
89
- )(scope);
90
- scope.$apply('val = "lt 10"');
91
- expect(element.hasAttribute("aria-invalid")).toBeFalse();
92
-
93
- scope.$apply('val = "gt 10 characters"');
94
- expect(element.hasAttribute("aria-invalid")).toBeFalse();
95
- });
96
-
97
- it("should not attach aria-invalid to custom controls", () => {
98
- element = $compile(
99
- '<div role="textbox" ng-model="val" ng-minlength="10" ng-aria-disable></div>',
100
- )(scope);
101
- scope.$apply('val = "lt 10"');
102
- expect(element.hasAttribute("aria-invalid")).toBeFalse();
103
-
104
- scope.$apply('val = "gt 10 characters"');
105
- expect(element.hasAttribute("aria-invalid")).toBeFalse();
106
- });
107
-
108
- // ariaLive
109
- it("should not attach aria-live to `ngMessages`", () => {
110
- element = $compile('<div ng-messages="val" ng-aria-disable>')(scope);
111
- expect(element.hasAttribute("aria-live")).toBeFalse();
112
- });
113
-
114
- // ariaReadonly
115
- it("should not attach aria-readonly to custom controls", () => {
116
- element = $compile('<div ng-readonly="val" ng-aria-disable></div>')(
117
- scope,
118
- );
119
- scope.$apply("val = false");
120
- expect(element.hasAttribute("aria-readonly")).toBeFalse();
121
-
122
- scope.$apply("val = true");
123
- expect(element.hasAttribute("aria-readonly")).toBeFalse();
124
- });
125
-
126
- // ariaRequired
127
- it("should not attach aria-required to custom controls with `required`", () => {
128
- element = $compile('<div ng-model="val" required ng-aria-disable></div>')(
129
- scope,
130
- );
131
- expect(element.hasAttribute("aria-required")).toBeFalse();
132
- });
133
-
134
- it("should not attach aria-required to custom controls with `ngRequired`", () => {
135
- element = $compile(
136
- '<div ng-model="val" ng-required="val" ng-aria-disable></div>',
137
- )(scope);
138
- scope.$apply("val = false");
139
- expect(element.hasAttribute("aria-required")).toBeFalse();
140
-
141
- scope.$apply("val = true");
142
- expect(element.hasAttribute("aria-required")).toBeFalse();
143
- });
144
-
145
- // ariaValue
146
- it("should not attach aria-value* to input[range]", () => {
147
- element = $compile(
148
- '<input type="range" ng-model="val" min="0" max="100" ng-aria-disable />',
149
- )(scope);
150
- expect(element.hasAttribute("aria-valuemax")).toBeFalse();
151
- expect(element.hasAttribute("aria-valuemin")).toBeFalse();
152
- expect(element.hasAttribute("aria-valuenow")).toBeFalse();
153
-
154
- scope.$apply("val = 50");
155
- expect(element.hasAttribute("aria-valuemax")).toBeFalse();
156
- expect(element.hasAttribute("aria-valuemin")).toBeFalse();
157
- expect(element.hasAttribute("aria-valuenow")).toBeFalse();
158
-
159
- scope.$apply("val = 150");
160
- expect(element.hasAttribute("aria-valuemax")).toBeFalse();
161
- expect(element.hasAttribute("aria-valuemin")).toBeFalse();
162
- expect(element.hasAttribute("aria-valuenow")).toBeFalse();
163
- });
164
-
165
- it("should not attach aria-value* to custom controls", () => {
166
- element = $compile(
167
- '<div><div role="progressbar" ng-model="val" min="0" max="100" ng-aria-disable></div>' +
168
- '<div role="slider" ng-model="val" min="0" max="100" ng-aria-disable></div></div>',
169
- )(scope);
170
- const progressbar = element.children[0];
171
- const slider = element.children[1];
172
-
173
- ["aria-valuemax", "aria-valuemin", "aria-valuenow"].forEach((attr) => {
174
- expect(progressbar.hasAttribute(attr)).toBeFalse();
175
- expect(slider.hasAttribute(attr)).toBeFalse();
176
- });
177
-
178
- scope.$apply("val = 50");
179
- ["aria-valuemax", "aria-valuemin", "aria-valuenow"].forEach((attr) => {
180
- expect(progressbar.hasAttribute(attr)).toBeFalse();
181
- expect(slider.hasAttribute(attr)).toBeFalse();
182
- });
183
-
184
- scope.$apply("val = 150");
185
- ["aria-valuemax", "aria-valuemin", "aria-valuenow"].forEach((attr) => {
186
- expect(progressbar.hasAttribute(attr)).toBeFalse();
187
- expect(slider.hasAttribute(attr)).toBeFalse();
188
- });
189
- });
190
-
191
- // bindKeypress
192
- it("should not bind keypress to `ngClick`", () => {
193
- scope.onClick = jasmine.createSpy("onClick");
194
- element = $compile(
195
- '<div><div ng-click="onClick()" tabindex="0" ng-aria-disable></div>' +
196
- '<ul><li ng-click="onClick()" tabindex="0" ng-aria-disable></li></ul></div>',
197
- )(scope);
198
- const div = element.querySelector("div");
199
- const li = element.querySelector("li");
200
-
201
- browserTrigger(div, { type: "keypress", keyCode: 32 });
202
- browserTrigger(li, { type: "keypress", keyCode: 32 });
203
-
204
- expect(scope.onClick).not.toHaveBeenCalled();
205
- });
206
-
207
- // bindRoleForClick
208
- it("should not attach role to custom controls", () => {
209
- element = $compile(
210
- '<div><div ng-click="onClick()" ng-aria-disable></div>' +
211
- '<div type="checkbox" ng-model="val" ng-aria-disable></div>' +
212
- '<div type="radio" ng-model="val" ng-aria-disable></div>' +
213
- '<div type="range" ng-model="val" ng-aria-disable></div></div>',
214
- )(scope);
215
- expect(element.children[0].hasAttribute("role")).toBeFalse();
216
- expect(element.children[1].hasAttribute("role")).toBeFalse();
217
- expect(element.children[2].hasAttribute("role")).toBeFalse();
218
- expect(element.children[3].hasAttribute("role")).toBeFalse();
219
- });
220
-
221
- // tabindex
222
- it("should not attach tabindex to custom controls", () => {
223
- element = $compile(
224
- '<div><div role="checkbox" ng-model="val" ng-aria-disable></div>' +
225
- '<div role="slider" ng-model="val" ng-aria-disable></div></div>',
226
- )(scope);
227
- expect(element.children[0].hasAttribute("tabindex")).toBeFalse();
228
- expect(element.children[1].hasAttribute("tabindex")).toBeFalse();
229
- });
230
-
231
- it("should not attach tabindex to `ngClick` or `ngDblclick`", () => {
232
- element = $compile(
233
- '<div><div ng-click="onClick()" ng-aria-disable></div>' +
234
- '<div ng-dblclick="onDblclick()" ng-aria-disable></div></div>',
235
- )(scope);
236
- expect(element.children[0].hasAttribute("tabindex")).toBeFalse();
237
- expect(element.children[1].hasAttribute("tabindex")).toBeFalse();
238
- });
239
- });
240
-
241
- describe("aria-hidden", () => {
242
- it("should attach aria-hidden to ng-show", async () => {
243
- element = $compile('<div ng-show="val"></div>')(scope);
244
- scope.$apply("val = false");
245
- await wait();
246
-
247
- expect(element.getAttribute("aria-hidden")).toBe("true");
248
-
249
- scope.$apply("val = true");
250
- await wait();
251
- expect(element.getAttribute("aria-hidden")).toBe("false");
252
- });
253
-
254
- it("should attach aria-hidden to ng-hide", async () => {
255
- element = $compile('<div ng-hide="val"></div>')(scope);
256
- scope.$apply("val = false");
257
- await wait();
258
- expect(element.getAttribute("aria-hidden")).toBe("false");
259
-
260
- scope.$apply("val = true");
261
- await wait();
262
- expect(element.getAttribute("aria-hidden")).toBe("true");
263
- });
264
-
265
- it("should not change aria-hidden if it is already present on ng-show", async () => {
266
- element = $compile(
267
- '<div ng-show="val" aria-hidden="userSetValue"></div>',
268
- )(scope);
269
- await wait();
270
- expect(element.getAttribute("aria-hidden")).toBe("userSetValue");
271
-
272
- scope.$apply("val = true");
273
- await wait();
274
- expect(element.getAttribute("aria-hidden")).toBe("userSetValue");
275
- });
276
-
277
- it("should not change aria-hidden if it is already present on ng-hide", async () => {
278
- element = $compile(
279
- '<div ng-hide="val" aria-hidden="userSetValue"></div>',
280
- )(scope);
281
- await wait();
282
- expect(element.getAttribute("aria-hidden")).toBe("userSetValue");
283
-
284
- scope.$apply("val = true");
285
- await wait();
286
- expect(element.getAttribute("aria-hidden")).toBe("userSetValue");
287
- });
288
-
289
- it("should always set aria-hidden to a boolean value", async () => {
290
- element = $compile('<div ng-hide="val"></div>')(scope);
291
- scope.$apply('val = "test angular"');
292
- await wait();
293
- expect(element.getAttribute("aria-hidden")).toBe("true");
294
-
295
- scope.$apply("val = null");
296
- await wait();
297
- expect(element.getAttribute("aria-hidden")).toBe("false");
298
-
299
- scope.$apply("val = {}");
300
- await wait();
301
- expect(element.getAttribute("aria-hidden")).toBe("true");
302
-
303
- element = $compile('<div ng-show="val"></div>')(scope);
304
- scope.$apply('val = "test angular"');
305
- await wait();
306
- expect(element.getAttribute("aria-hidden")).toBe("false");
307
-
308
- scope.$apply("val = null");
309
- await wait();
310
- expect(element.getAttribute("aria-hidden")).toBe("true");
311
-
312
- scope.$apply("val = {}");
313
- await wait();
314
- expect(element.getAttribute("aria-hidden")).toBe("false");
315
- });
316
- });
317
-
318
- describe("aria-hidden when disabled", () => {
319
- beforeEach(() => {
320
- window.angular.module("test", [
321
- "ng",
322
- ($ariaProvider) => {
323
- $ariaProvider.config({
324
- ariaHidden: false,
325
- });
326
- },
327
- ]);
328
- let injector = createInjector(["test"]);
329
- scope = injector.get("$rootScope");
330
- $compile = injector.get("$compile");
331
- });
332
-
333
- it("should not attach aria-hidden", () => {
334
- scope.$apply("val = false");
335
- element = $compile('<div ng-show="val"></div>')(scope);
336
- expect(element.hasAttribute("aria-hidden")).toBeFalse();
337
-
338
- element = $compile('<div ng-hide="val"></div>')(scope);
339
- expect(element.hasAttribute("aria-hidden")).toBeFalse();
340
- });
341
- });
342
-
343
- describe("aria-checked", () => {
344
- it('should not attach itself to native input type="checkbox"', async () => {
345
- element = $compile('<input type="checkbox" ng-model="val">')(scope);
346
- scope.$apply("val = true");
347
- await wait();
348
- expect(element.getAttribute("aria-checked")).toBeNull();
349
-
350
- scope.$apply("val = false");
351
- await wait();
352
- expect(element.getAttribute("aria-checked")).toBeNull();
353
- });
354
-
355
- it("should attach itself to custom checkbox", async () => {
356
- element = $compile('<div role="checkbox" ng-model="val"></div>')(scope);
357
- scope.$apply('val = "checked"');
358
- await wait();
359
- expect(element.getAttribute("aria-checked")).toBe("true");
360
-
361
- scope.$apply("val = null");
362
- await wait();
363
- expect(element.getAttribute("aria-checked")).toBe("false");
364
- });
365
-
366
- it("should use `$isEmpty()` to determine if the checkbox is checked", async () => {
367
- element = $compile('<div role="checkbox" ng-model="val"></div>')(scope);
368
- await wait();
369
- const ctrl = getController(element, "ngModel");
370
- ctrl.$isEmpty = function (value) {
371
- return value === "not-checked";
372
- };
373
-
374
- scope.$apply("val = true");
375
- await wait();
376
- expect(ctrl.$modelValue).toBe(true);
377
- expect(element.getAttribute("aria-checked")).toBe("true");
378
-
379
- scope.$apply("val = false");
380
- await wait();
381
- expect(ctrl.$modelValue).toBe(false);
382
- expect(element.getAttribute("aria-checked")).toBe("true");
383
-
384
- scope.$apply('val = "not-checked"');
385
- await wait();
386
- expect(ctrl.$modelValue).toBe("not-checked");
387
- expect(element.getAttribute("aria-checked")).toBe("false");
388
-
389
- scope.$apply('val = "checked"');
390
- await wait();
391
- expect(ctrl.$modelValue).toBe("checked");
392
- expect(element.getAttribute("aria-checked")).toBe("true");
393
- });
394
-
395
- it("should not handle native checkbox with ngChecked", async () => {
396
- const element = $compile('<input type="checkbox" ng-checked="val">')(
397
- scope,
398
- );
399
- scope.$apply("val = true");
400
- await wait();
401
- expect(element.getAttribute("aria-checked")).toBeNull();
402
-
403
- scope.$apply("val = false");
404
- await wait();
405
- expect(element.getAttribute("aria-checked")).toBeNull();
406
- });
407
-
408
- it("should handle custom checkbox with ngChecked", async () => {
409
- const element = $compile('<div role="checkbox" ng-checked="val">')(scope);
410
-
411
- scope.$apply("val = true");
412
- await wait();
413
- expect(element.getAttribute("aria-checked")).toBe("true");
414
-
415
- scope.$apply("val = false");
416
- await wait();
417
- expect(element.getAttribute("aria-checked")).toBe("false");
418
- });
419
-
420
- it('should not attach to native input type="radio"', async () => {
421
- const element = $compile(
422
- '<div><input type="radio" ng-model="val" value="one">' +
423
- '<input type="radio" ng-model="val" value="two"></div>',
424
- )(scope);
425
-
426
- scope.$apply("val='one'");
427
- await wait();
428
- expect(element.children[0].getAttribute("aria-checked")).toBeNull();
429
- expect(element.children[1].getAttribute("aria-checked")).toBeNull();
430
-
431
- scope.$apply("val='two'");
432
- await wait();
433
- expect(element.children[0].getAttribute("aria-checked")).toBeNull();
434
- expect(element.children[1].getAttribute("aria-checked")).toBeNull();
435
- });
436
-
437
- it("should attach to custom radio controls", async () => {
438
- const element = $compile(
439
- '<div><div role="radio" ng-model="val" value="one"></div>' +
440
- '<div role="radio" ng-model="val" value="two"></div></div>',
441
- )(scope);
442
-
443
- scope.$apply("val='one'");
444
- await wait();
445
- expect(element.children[0].getAttribute("aria-checked")).toBe("true");
446
- expect(element.children[1].getAttribute("aria-checked")).toBe("false");
447
-
448
- scope.$apply("val='two'");
449
- await wait();
450
- expect(element.children[0].getAttribute("aria-checked")).toBe("false");
451
- expect(element.children[1].getAttribute("aria-checked")).toBe("true");
452
- });
453
-
454
- it("should handle custom radios with integer model values", async () => {
455
- const element = $compile(
456
- '<div><div role="radio" ng-model="val" value="0"></div>' +
457
- '<div role="radio" ng-model="val" value="1"></div></div>',
458
- )(scope);
459
-
460
- scope.$apply("val=0");
461
- await wait();
462
- expect(element.children[0].getAttribute("aria-checked")).toBe("true");
463
- expect(element.children[1].getAttribute("aria-checked")).toBe("false");
464
-
465
- scope.$apply("val=1");
466
- await wait();
467
- expect(element.children[0].getAttribute("aria-checked")).toBe("false");
468
- expect(element.children[1].getAttribute("aria-checked")).toBe("true");
469
- });
470
-
471
- it("should handle radios with boolean model values using ngValue", async () => {
472
- const element = $compile(
473
- '<div><div role="radio" ng-model="val" ng-value="valExp"></div>' +
474
- '<div role="radio" ng-model="val" ng-value="valExp2"></div></div>',
475
- )(scope);
476
- scope.valExp = true;
477
- scope.valExp2 = false;
478
- scope.val = true;
479
- await wait();
480
- expect(element.children[0].getAttribute("aria-checked")).toBe("true");
481
- expect(element.children[1].getAttribute("aria-checked")).toBe("false");
482
-
483
- scope.$apply("val = false");
484
- await wait();
485
- expect(element.children[0].getAttribute("aria-checked")).toBe("false");
486
- expect(element.children[1].getAttribute("aria-checked")).toBe("true");
487
- });
488
-
489
- it('should attach itself to role="menuitemradio"', async () => {
490
- scope.val = "one";
491
- element = $compile(
492
- '<div role="menuitemradio" ng-model="val" value="one"></div>',
493
- )(scope);
494
- await wait();
495
- expect(element.getAttribute("aria-checked")).toBe("true");
496
-
497
- scope.$apply("val = 'two'");
498
- await wait();
499
- expect(element.getAttribute("aria-checked")).toBe("false");
500
- });
501
-
502
- it('should attach itself to role="menuitemcheckbox"', async () => {
503
- element = $compile('<div role="menuitemcheckbox" ng-model="val"></div>')(
504
- scope,
505
- );
506
- scope.$apply('val = "checked"');
507
- await wait();
508
- expect(element.getAttribute("aria-checked")).toBe("true");
509
-
510
- scope.$apply("val = null");
511
- await wait();
512
- expect(element.getAttribute("aria-checked")).toBe("false");
513
- });
514
-
515
- it("should not attach itself if an aria-checked value is already present", async () => {
516
- const element = [
517
- $compile(
518
- "<div role='radio' ng-model='val' value='{{val3}}' aria-checked='userSetValue'></div>",
519
- )(scope),
520
- $compile(
521
- "<div role='menuitemradio' ng-model='val' value='{{val3}}' aria-checked='userSetValue'></div>",
522
- )(scope),
523
- $compile(
524
- "<div role='checkbox' checked='checked' aria-checked='userSetValue'></div>",
525
- )(scope),
526
- $compile(
527
- "<div role='menuitemcheckbox' checked='checked' aria-checked='userSetValue'></div>",
528
- )(scope),
529
- ];
530
- scope.$apply("val1=true;val2='one';val3='1'");
531
- await wait();
532
- expectAriaAttrOnEachElement(element, "aria-checked", "userSetValue");
533
- });
534
- });
535
-
536
- describe("roles for custom inputs", () => {
537
- it('should add missing role="button" to custom input', () => {
538
- element = $compile('<div ng-click="someFunction()"></div>')(scope);
539
- expect(element.getAttribute("role")).toBe("button");
540
- });
541
-
542
- it('should not add role="button" to anchor', () => {
543
- element = $compile('<a ng-click="someFunction()"></a>')(scope);
544
- expect(element.getAttribute("role")).not.toBe("button");
545
- });
546
-
547
- it('should add missing role="checkbox" to custom input', () => {
548
- element = $compile('<div type="checkbox" ng-model="val"></div>')(scope);
549
- expect(element.getAttribute("role")).toBe("checkbox");
550
- });
551
-
552
- it("should not add a role to a native checkbox", () => {
553
- element = $compile('<input type="checkbox" ng-model="val"/>')(scope);
554
- expect(element.getAttribute("role")).toBeNull();
555
- });
556
-
557
- it('should add missing role="radio" to custom input', () => {
558
- element = $compile('<div type="radio" ng-model="val"></div>')(scope);
559
- expect(element.getAttribute("role")).toBe("radio");
560
- });
561
-
562
- it("should not add a role to a native radio button", () => {
563
- element = $compile('<input type="radio" ng-model="val"/>')(scope);
564
- expect(element.getAttribute("role")).toBeNull();
565
- });
566
-
567
- it('should add missing role="slider" to custom input', () => {
568
- element = $compile('<div type="range" ng-model="val"></div>')(scope);
569
- expect(element.getAttribute("role")).toBe("slider");
570
- });
571
-
572
- it("should not add a role to a native range input", () => {
573
- element = $compile('<input type="range" ng-model="val"/>')(scope);
574
- expect(element.getAttribute("role")).toBeNull();
575
- });
576
-
577
- it("should not add role to native $prop controls", () => {
578
- [
579
- '<input type="text" ng-model="val">',
580
- '<select type="checkbox" ng-model="val"></select>',
581
- '<textarea type="checkbox" ng-model="val"></textarea>',
582
- '<button ng-click="doClick()"></button>',
583
- '<summary ng-click="doClick()"></summary>',
584
- '<details ng-click="doClick()"></details>',
585
- '<a ng-click="doClick()"></a>',
586
- ].forEach((tmpl) => {
587
- const element = $compile(tmpl)(scope);
588
- expect(element.getAttribute("role")).toBeNull();
589
- });
590
- });
591
- });
592
-
593
- describe("aria-checked when disabled", () => {
594
- beforeEach(() => {
595
- window.angular.module("test", [
596
- "ng",
597
- ($ariaProvider) => {
598
- $ariaProvider.config({
599
- ariaChecked: false,
600
- });
601
- },
602
- ]);
603
- let injector = createInjector(["test"]);
604
- scope = injector.get("$rootScope");
605
- $compile = injector.get("$compile");
606
- });
607
-
608
- it("should not attach aria-checked", () => {
609
- element = $compile(
610
- "<div role='radio' ng-model='val' value='{{val}}'></div>",
611
- )(scope);
612
- expect(element.getAttribute("aria-checked")).toBeNull();
613
-
614
- element = $compile(
615
- "<div role='menuitemradio' ng-model='val' value='{{val}}'></div>",
616
- )(scope);
617
- expect(element.getAttribute("aria-checked")).toBeNull();
618
-
619
- element = $compile("<div role='checkbox' checked='checked'></div>")(
620
- scope,
621
- );
622
- expect(element.getAttribute("aria-checked")).toBeNull();
623
-
624
- element = $compile(
625
- "<div role='menuitemcheckbox' checked='checked'></div>",
626
- )(scope);
627
- expect(element.getAttribute("aria-checked")).toBeNull();
628
- });
629
- });
630
-
631
- describe("aria-disabled", () => {
632
- it("should not attach itself to native $prop controls", () => {
633
- [
634
- '<input ng-disabled="val">',
635
- '<textarea ng-disabled="val"></textarea>',
636
- '<select ng-disabled="val"></select>',
637
- '<button ng-disabled="val"></button>',
638
- ].forEach((tmpl) => {
639
- const element = $compile(tmpl)(scope);
640
- scope.$apply("val = true");
641
-
642
- expect(element.getAttribute("disabled")).toBeDefined();
643
- expect(element.getAttribute("aria-disabled")).toBeNull();
644
- });
645
- });
646
-
647
- it("should attach itself to custom controls", async () => {
648
- element = $compile('<div ng-disabled="val"></div>')(scope);
649
- await wait();
650
- expect(element.getAttribute("aria-disabled")).toBe("false");
651
-
652
- scope.$apply("val = true");
653
- await wait();
654
- expect(element.getAttribute("aria-disabled")).toBe("true");
655
- });
656
-
657
- it("should not attach itself if an aria-disabled attribute is already present", () => {
658
- element = $compile(
659
- '<div ng-disabled="val" aria-disabled="userSetValue"></div>',
660
- )(scope);
661
- expect(element.getAttribute("aria-disabled")).toBe("userSetValue");
662
- });
663
-
664
- it("should always set aria-disabled to a boolean value", async () => {
665
- element = $compile('<div ng-disabled="val"></div>')(scope);
666
-
667
- scope.$apply('val = "test angular"');
668
- await wait();
669
-
670
- expect(element.getAttribute("aria-disabled")).toBe("true");
671
-
672
- scope.$apply("val = null");
673
- await wait();
674
- expect(element.getAttribute("aria-disabled")).toBe("false");
675
-
676
- scope.$apply("val = {}");
677
- await wait();
678
- expect(element.getAttribute("aria-disabled")).toBe("true");
679
- });
680
- });
681
-
682
- describe("aria-disabled when disabled", () => {
683
- beforeEach(() => {
684
- window.angular.module("test", [
685
- "ng",
686
- ($ariaProvider) => {
687
- $ariaProvider.config({
688
- ariaDisabled: false,
689
- });
690
- },
691
- ]);
692
- let injector = createInjector(["test"]);
693
- scope = injector.get("$rootScope");
694
- $compile = injector.get("$compile");
695
- });
696
-
697
- it("should not attach aria-disabled", async () => {
698
- element = $compile('<div ng-disabled="val"></div>')(scope);
699
-
700
- scope.$apply("val = true");
701
- await wait();
702
- expect(element.getAttribute("aria-disabled")).toBeNull();
703
- });
704
- });
705
-
706
- describe("aria-invalid", () => {
707
- it("should attach aria-invalid to input", async () => {
708
- element = $compile('<input ng-model="txtInput" ng-minlength="10">')(
709
- scope,
710
- );
711
- scope.$apply("txtInput='LTten'");
712
- await wait();
713
- expect(element.getAttribute("aria-invalid")).toBe("true");
714
-
715
- scope.$apply("txtInput='morethantencharacters'");
716
- await wait();
717
- expect(element.getAttribute("aria-invalid")).toBe("false");
718
- });
719
-
720
- it("should attach aria-invalid to custom controls", async () => {
721
- element = $compile(
722
- '<div ng-model="txtInput" role="textbox" ng-minlength="10"></div>',
723
- )(scope);
724
- scope.$apply("txtInput='LTten'");
725
- await wait();
726
- expect(element.getAttribute("aria-invalid")).toBe("true");
727
-
728
- scope.$apply("txtInput='morethantencharacters'");
729
- await wait();
730
- expect(element.getAttribute("aria-invalid")).toBe("false");
731
- });
732
-
733
- it("should not attach itself if aria-invalid is already present", async () => {
734
- element = $compile(
735
- '<input ng-model="txtInput" ng-minlength="10" aria-invalid="userSetValue">',
736
- )(scope);
737
- await wait();
738
- scope.$apply("txtInput='LTten'");
739
- expect(element.getAttribute("aria-invalid")).toBe("userSetValue");
740
- });
741
-
742
- it('should not attach if input is type="hidden"', () => {
743
- element = $compile('<input type="hidden" ng-model="txtInput">')(scope);
744
- expect(element.getAttribute("aria-invalid")).toBeNull();
745
- });
746
-
747
- it('should attach aria-invalid to custom control that is type="hidden"', async () => {
748
- element = $compile(
749
- '<div ng-model="txtInput" type="hidden" role="textbox" ng-minlength="10"></div>',
750
- )(scope);
751
- scope.$apply("txtInput='LTten'");
752
- await wait();
753
- expect(element.getAttribute("aria-invalid")).toBe("true");
754
-
755
- scope.$apply("txtInput='morethantencharacters'");
756
- await wait();
757
- expect(element.getAttribute("aria-invalid")).toBe("false");
758
- });
759
- });
760
-
761
- describe("aria-invalid when disabled", () => {
762
- beforeEach(() => {
763
- window.angular.module("test", [
764
- "ng",
765
- ($ariaProvider) => {
766
- $ariaProvider.config({
767
- ariaInvalid: false,
768
- });
769
- },
770
- ]);
771
- let injector = createInjector(["test"]);
772
- scope = injector.get("$rootScope");
773
- $compile = injector.get("$compile");
774
- });
775
-
776
- it("should not attach aria-invalid if the option is disabled", () => {
777
- scope.$apply("txtInput='LTten'");
778
- element = $compile('<input ng-model="txtInput" ng-minlength="10">')(
779
- scope,
780
- );
781
- expect(element.getAttribute("aria-invalid")).toBeNull();
782
- });
783
- });
784
-
785
- describe("aria-readonly", () => {
786
- it("should not attach itself to native $prop controls", () => {
787
- [
788
- '<input ng-readonly="val">',
789
- '<textarea ng-readonly="val"></textarea>',
790
- '<select ng-readonly="val"></select>',
791
- '<button ng-readonly="val"></button>',
792
- ].forEach((tmpl) => {
793
- const element = $compile(tmpl)(scope);
794
- scope.$apply("val = true");
795
-
796
- expect(element.getAttribute("readonly")).toBeDefined();
797
- expect(element.getAttribute("aria-readonly")).toBeNull();
798
- });
799
- });
800
-
801
- it("should attach itself to custom controls", async () => {
802
- element = $compile('<div ng-readonly="val"></div>')(scope);
803
- await wait();
804
- expect(element.getAttribute("aria-readonly")).toBe("false");
805
-
806
- scope.$apply("val = true");
807
- await wait();
808
- expect(element.getAttribute("aria-readonly")).toBe("true");
809
- });
810
-
811
- it("should not attach itself if an aria-readonly attribute is already present", () => {
812
- element = $compile(
813
- '<div ng-readonly="val" aria-readonly="userSetValue"></div>',
814
- )(scope);
815
- expect(element.getAttribute("aria-readonly")).toBe("userSetValue");
816
- });
817
-
818
- it("should always set aria-readonly to a boolean value", async () => {
819
- element = $compile('<div ng-readonly="val"></div>')(scope);
820
-
821
- scope.$apply('val = "test angular"');
822
- await wait();
823
- expect(element.getAttribute("aria-readonly")).toBe("true");
824
-
825
- scope.$apply("val = null");
826
- await wait();
827
- expect(element.getAttribute("aria-readonly")).toBe("false");
828
-
829
- scope.$apply("val = {}");
830
- await wait();
831
- expect(element.getAttribute("aria-readonly")).toBe("true");
832
- });
833
- });
834
-
835
- describe("aria-readonly when disabled", () => {
836
- beforeEach(() => {
837
- window.angular.module("test", [
838
- "ng",
839
- ($ariaProvider) => {
840
- $ariaProvider.config({
841
- ariaReadonly: false,
842
- });
843
- },
844
- ]);
845
- let injector = createInjector(["test"]);
846
- scope = injector.get("$rootScope");
847
- $compile = injector.get("$compile");
848
- });
849
-
850
- it("should not add the aria-readonly attribute", () => {
851
- element = $compile("<input ng-model='val' readonly>")(scope);
852
- expect(element.getAttribute("aria-readonly")).toBeNull();
853
-
854
- element = $compile("<div ng-model='val' ng-readonly='true'></div>")(
855
- scope,
856
- );
857
- expect(element.getAttribute("aria-readonly")).toBeNull();
858
- });
859
- });
860
-
861
- describe("aria-required", () => {
862
- it("should not attach to input", () => {
863
- element = $compile('<input ng-model="val" required>')(scope);
864
- expect(element.getAttribute("aria-required")).toBeNull();
865
- });
866
-
867
- it("should attach to custom controls with ngModel and required", () => {
868
- element = $compile('<div ng-model="val" role="checkbox" required></div>')(
869
- scope,
870
- );
871
- expect(element.getAttribute("aria-required")).toBe("true");
872
- });
873
-
874
- it("should set aria-required to false when ng-required is false", async () => {
875
- element = $compile(
876
- "<div role='checkbox' ng-required='false' ng-model='val'></div>",
877
- )(scope);
878
- await wait();
879
- expect(element.getAttribute("aria-required")).toBe("false");
880
- });
881
-
882
- it("should attach to custom controls with ngRequired", async () => {
883
- element = $compile(
884
- '<div role="checkbox" ng-model="val" ng-required="true"></div>',
885
- )(scope);
886
- await wait();
887
- expect(element.getAttribute("aria-required")).toBe("true");
888
- });
889
-
890
- it("should not attach itself if aria-required is already present", () => {
891
- element = $compile(
892
- "<div role='checkbox' ng-model='val' ng-required='true' aria-required='userSetValue'></div>",
893
- )(scope);
894
- expect(element.getAttribute("aria-required")).toBe("userSetValue");
895
- });
896
- });
897
-
898
- describe("aria-required when disabled", () => {
899
- beforeEach(() => {
900
- window.angular.module("test", [
901
- "ng",
902
- ($ariaProvider) => {
903
- $ariaProvider.config({
904
- ariaRequired: false,
905
- });
906
- },
907
- ]);
908
- let injector = createInjector(["test"]);
909
- scope = injector.get("$rootScope");
910
- $compile = injector.get("$compile");
911
- });
912
-
913
- it("should not add the aria-required attribute", () => {
914
- element = $compile("<input ng-model='val' required>")(scope);
915
- expect(element.getAttribute("aria-required")).toBeNull();
916
-
917
- element = $compile("<div ng-model='val' ng-required='true'></div>")(
918
- scope,
919
- );
920
- expect(element.getAttribute("aria-required")).toBeNull();
921
- });
922
- });
923
-
924
- describe("aria-value", () => {
925
- it('should attach to input type="range"', async () => {
926
- const element = [
927
- $compile('<input type="range" ng-model="val" min="0" max="100">')(
928
- scope,
929
- ),
930
- $compile('<div role="progressbar" min="0" max="100" ng-model="val">')(
931
- scope,
932
- ),
933
- $compile('<div role="slider" min="0" max="100" ng-model="val">')(scope),
934
- ];
935
-
936
- scope.$apply("val = 50");
937
- await wait();
938
- expectAriaAttrOnEachElement(element, "aria-valuenow", "50");
939
- expectAriaAttrOnEachElement(element, "aria-valuemin", "0");
940
- expectAriaAttrOnEachElement(element, "aria-valuemax", "100");
941
-
942
- scope.$apply("val = 90");
943
- await wait();
944
- expectAriaAttrOnEachElement(element, "aria-valuenow", "90");
945
- });
946
-
947
- it("should not attach if aria-value* is already present", () => {
948
- const element = [
949
- $compile(
950
- '<input type="range" ng-model="val" min="0" max="100" aria-valuenow="userSetValue1" aria-valuemin="userSetValue2" aria-valuemax="userSetValue3">',
951
- )(scope),
952
- $compile(
953
- '<div role="progressbar" min="0" max="100" ng-model="val" aria-valuenow="userSetValue1" aria-valuemin="userSetValue2" aria-valuemax="userSetValue3">',
954
- )(scope),
955
- $compile(
956
- '<div role="slider" min="0" max="100" ng-model="val" aria-valuenow="userSetValue1" aria-valuemin="userSetValue2" aria-valuemax="userSetValue3">',
957
- )(scope),
958
- ];
959
-
960
- scope.$apply("val = 50");
961
- expectAriaAttrOnEachElement(element, "aria-valuenow", "userSetValue1");
962
- expectAriaAttrOnEachElement(element, "aria-valuemin", "userSetValue2");
963
- expectAriaAttrOnEachElement(element, "aria-valuemax", "userSetValue3");
964
- });
965
-
966
- it("should update `aria-valuemin/max` when `min/max` changes dynamically", async () => {
967
- scope.$apply("min = 25; max = 75");
968
- element = $compile(
969
- '<input type="range" ng-model="val" min="{{min}}" max="{{max}}" />',
970
- )(scope);
971
- await wait();
972
- expect(element.getAttribute("aria-valuemin")).toBe("25");
973
- expect(element.getAttribute("aria-valuemax")).toBe("75");
974
-
975
- scope.$apply("min = 0");
976
- await wait();
977
- expect(element.getAttribute("aria-valuemin")).toBe("0");
978
-
979
- scope.$apply("max = 100");
980
- await wait();
981
- expect(element.getAttribute("aria-valuemax")).toBe("100");
982
- });
983
-
984
- it("should update `aria-valuemin/max` when `ng-min/ng-max` changes dynamically", async () => {
985
- scope.$apply("min = 25; max = 75");
986
- element = $compile(
987
- '<input type="range" ng-model="val" ng-min="min" ng-max="max" />',
988
- )(scope);
989
- await wait();
990
- expect(element.getAttribute("aria-valuemin")).toBe("25");
991
- expect(element.getAttribute("aria-valuemax")).toBe("75");
992
-
993
- scope.$apply("min = 0");
994
-
995
- await wait();
996
- expect(element.getAttribute("aria-valuemin")).toBe("0");
997
-
998
- scope.$apply("max = 100");
999
-
1000
- await wait();
1001
- expect(element.getAttribute("aria-valuemax")).toBe("100");
1002
- });
1003
- });
1004
-
1005
- describe("announcing ngMessages", () => {
1006
- it("should attach aria-live", async () => {
1007
- const element = $compile(
1008
- '<div><div ng-messages="myForm.myName.$error"></div></div',
1009
- )(scope);
1010
- await wait();
1011
- expectAriaAttrOnEachElement(
1012
- Array.from(element.children),
1013
- "aria-live",
1014
- "assertive",
1015
- );
1016
- });
1017
- });
1018
-
1019
- describe("aria-value when disabled", () => {
1020
- beforeEach(() => {
1021
- window.angular.module("test", [
1022
- "ng",
1023
- ($ariaProvider) => {
1024
- $ariaProvider.config({
1025
- ariaValue: false,
1026
- });
1027
- },
1028
- ]);
1029
- let injector = createInjector(["test"]);
1030
- scope = injector.get("$rootScope");
1031
- $compile = injector.get("$compile");
1032
- });
1033
-
1034
- it("should not attach itself", async () => {
1035
- scope.$apply("val = 50");
1036
-
1037
- element = $compile(
1038
- '<input type="range" ng-model="val" min="0" max="100">',
1039
- )(scope);
1040
- await wait();
1041
- expect(element.getAttribute("aria-valuenow")).toBeNull();
1042
- expect(element.getAttribute("aria-valuemin")).toBeNull();
1043
- expect(element.getAttribute("aria-valuemax")).toBeNull();
1044
-
1045
- element = $compile(
1046
- '<div role="progressbar" min="0" max="100" ng-model="val">',
1047
- )(scope);
1048
- await wait();
1049
- expect(element.getAttribute("aria-valuenow")).toBeNull();
1050
- expect(element.getAttribute("aria-valuemin")).toBeNull();
1051
- expect(element.getAttribute("aria-valuemax")).toBeNull();
1052
- });
1053
- });
1054
-
1055
- describe("tabindex", () => {
1056
- it("should not attach to native control $prop", () => {
1057
- [
1058
- "<button ng-click='something'></button>",
1059
- "<a ng-href='#/something'>",
1060
- "<input type='text' ng-model='val'>",
1061
- "<input type='radio' ng-model='val'>",
1062
- "<input type='checkbox' ng-model='val'>",
1063
- "<textarea ng-model='val'></textarea>",
1064
- "<select ng-model='val'></select>",
1065
- "<details ng-model='val'></details>",
1066
- ].forEach((html) => {
1067
- element = $compile(html)(scope);
1068
- expect(element.getAttribute("tabindex")).toBeNull();
1069
- });
1070
- });
1071
-
1072
- it("should not attach to random ng-model elements", () => {
1073
- element = $compile('<div ng-model="val"></div>')(scope);
1074
- expect(element.getAttribute("tabindex")).toBeNull();
1075
- });
1076
-
1077
- it("should attach tabindex to custom inputs", () => {
1078
- element = $compile('<div role="checkbox" ng-model="val"></div>')(scope);
1079
- expect(element.getAttribute("tabindex")).toBe("0");
1080
-
1081
- element = $compile('<div role="slider" ng-model="val"></div>')(scope);
1082
- expect(element.getAttribute("tabindex")).toBe("0");
1083
- });
1084
-
1085
- it("should attach to ng-click and ng-dblclick", async () => {
1086
- element = $compile('<div ng-click="someAction()"></div>')(scope);
1087
- await wait();
1088
- expect(element.getAttribute("tabindex")).toBe("0");
1089
-
1090
- element = $compile('<div ng-dblclick="someAction()"></div>')(scope);
1091
- await wait();
1092
- expect(element.getAttribute("tabindex")).toBe("0");
1093
- });
1094
-
1095
- it("should not attach tabindex if it is already on an element", () => {
1096
- element = $compile('<div role="button" tabindex="userSetValue"></div>')(
1097
- scope,
1098
- );
1099
- expect(element.getAttribute("tabindex")).toBe("userSetValue");
1100
-
1101
- element = $compile('<div role="checkbox" tabindex="userSetValue"></div>')(
1102
- scope,
1103
- );
1104
- expect(element.getAttribute("tabindex")).toBe("userSetValue");
1105
-
1106
- element = $compile(
1107
- '<div ng-click="someAction()" tabindex="userSetValue"></div>',
1108
- )(scope);
1109
- expect(element.getAttribute("tabindex")).toBe("userSetValue");
1110
-
1111
- element = $compile(
1112
- '<div ng-dblclick="someAction()" tabindex="userSetValue"></div>',
1113
- )(scope);
1114
- expect(element.getAttribute("tabindex")).toBe("userSetValue");
1115
- });
1116
- });
1117
-
1118
- describe("actions when bindRoleForClick is set to false", () => {
1119
- beforeEach(() => {
1120
- window.angular.module("test", [
1121
- "ng",
1122
- ($ariaProvider) => {
1123
- $ariaProvider.config({
1124
- bindRoleForClick: false,
1125
- });
1126
- },
1127
- ]);
1128
- let injector = createInjector(["test"]);
1129
- scope = injector.get("$rootScope");
1130
- $compile = injector.get("$compile");
1131
- });
1132
-
1133
- it("should not add a button role", () => {
1134
- element = $compile('<radio-group ng-click="something"></radio-group>')(
1135
- scope,
1136
- );
1137
- expect(element.getAttribute("role")).toBeNull();
1138
- });
1139
- });
1140
-
1141
- describe("actions when bindKeydown is set to false", () => {
1142
- beforeEach(() => {
1143
- window.angular.module("test", [
1144
- "ng",
1145
- ($ariaProvider) => {
1146
- $ariaProvider.config({
1147
- bindKeydown: false,
1148
- });
1149
- },
1150
- ]);
1151
- let injector = createInjector(["test"]);
1152
- scope = injector.get("$rootScope");
1153
- $compile = injector.get("$compile");
1154
- });
1155
-
1156
- it("should not trigger click", () => {
1157
- scope.someAction = jasmine.createSpy("someAction");
1158
-
1159
- element = $compile('<div ng-click="someAction()" tabindex="0"></div>')(
1160
- scope,
1161
- );
1162
-
1163
- browserTrigger(element, { type: "keydown", keyCode: 13 });
1164
- browserTrigger(element, { type: "keydown", keyCode: 32 });
1165
- browserTrigger(element, { type: "keypress", keyCode: 13 });
1166
- browserTrigger(element, { type: "keypress", keyCode: 32 });
1167
- browserTrigger(element, { type: "keyup", keyCode: 13 });
1168
- browserTrigger(element, { type: "keyup", keyCode: 32 });
1169
-
1170
- expect(scope.someAction).not.toHaveBeenCalled();
1171
-
1172
- browserTrigger(element, { type: "click", keyCode: 32 });
1173
-
1174
- expect(scope.someAction).toHaveBeenCalled();
1175
- });
1176
- });
1177
-
1178
- describe("tabindex when disabled", () => {
1179
- beforeEach(() => {
1180
- window.angular.module("test", [
1181
- "ng",
1182
- ($ariaProvider) => {
1183
- $ariaProvider.config({
1184
- tabindex: false,
1185
- });
1186
- },
1187
- ]);
1188
- let injector = createInjector(["test"]);
1189
- scope = injector.get("$rootScope");
1190
- $compile = injector.get("$compile");
1191
- });
1192
-
1193
- it("should not add a tabindex attribute", async () => {
1194
- element = $compile('<div role="button"></div>')(scope);
1195
- await wait();
1196
- expect(element.getAttribute("tabindex")).toBeNull();
1197
-
1198
- element = $compile('<div role="checkbox"></div>')(scope);
1199
- await wait();
1200
- expect(element.getAttribute("tabindex")).toBeNull();
1201
-
1202
- element = $compile('<div ng-click="someAction()"></div>')(scope);
1203
- await wait();
1204
- expect(element.getAttribute("tabindex")).toBeNull();
1205
-
1206
- element = $compile('<div ng-dblclick="someAction()"></div>')(scope);
1207
- await wait();
1208
- expect(element.getAttribute("tabindex")).toBeNull();
1209
- });
1210
- });
1211
-
1212
- describe("ngModel", () => {
1213
- it("should not break when manually compiling", async () => {
1214
- window.angular.module("test", [
1215
- "ng",
1216
- ($compileProvider) => {
1217
- $compileProvider.directive("foo", () => ({
1218
- priority: 10,
1219
- terminal: true,
1220
- link(scope, elem) {
1221
- $compile(elem, null, 10)(scope);
1222
- },
1223
- }));
1224
- },
1225
- ]);
1226
- let injector = createInjector(["test"]);
1227
- scope = injector.get("$rootScope");
1228
- $compile = injector.get("$compile");
1229
- element = $compile('<div role="checkbox" ng-model="value" foo />')(scope);
1230
- await wait();
1231
- // Just check an arbitrary feature to make sure it worked
1232
- expect(element.getAttribute("tabindex")).toBe("0");
1233
- });
1234
- });
1235
-
1236
- function expectAriaAttrOnEachElement(elem, ariaAttr, expected) {
1237
- elem.forEach((val) => {
1238
- expect(val.getAttribute(ariaAttr)).toBe(expected);
1239
- });
1240
- }
1241
- });