@taiga-ui/addon-doc 3.57.0 → 3.59.0-canary.10da730

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 (245) hide show
  1. package/components/code/code.component.d.ts +1 -1
  2. package/components/copy/copy.component.d.ts +1 -1
  3. package/components/demo/demo.component.d.ts +3 -3
  4. package/components/doc-tab/doc-tab.component.d.ts +6 -0
  5. package/components/doc-tab/doc-tab.module.d.ts +8 -0
  6. package/components/documentation/documentation-property-connector.directive.d.ts +6 -4
  7. package/components/documentation/documentation.component.d.ts +1 -1
  8. package/components/documentation/documentation.module.d.ts +1 -1
  9. package/components/documentation/pipes/cleaner.pipe.d.ts +1 -1
  10. package/components/documentation/pipes/color.pipe.d.ts +1 -1
  11. package/components/documentation/pipes/inspect.pipe.d.ts +1 -1
  12. package/components/documentation/pipes/opacity.pipe.d.ts +1 -1
  13. package/components/documentation/pipes/optional.pipe.d.ts +1 -1
  14. package/components/documentation/pipes/primitive-polymorpheus-content.pipe.d.ts +1 -1
  15. package/components/documentation/pipes/strip-optional.pipe.d.ts +1 -1
  16. package/components/documentation/pipes/type-reference.pipe.d.ts +1 -1
  17. package/components/example/example-get-tabs.pipe.d.ts +1 -1
  18. package/components/example/example.component.d.ts +1 -1
  19. package/components/index.d.ts +2 -0
  20. package/components/internal/header/header.component.d.ts +1 -1
  21. package/components/internal/input-opacity/input-opacity.directive.d.ts +1 -1
  22. package/components/internal/see-also/see-also.component.d.ts +1 -1
  23. package/components/internal/source-code/source-code.component.d.ts +1 -1
  24. package/components/language-switcher/language-switcher.component.d.ts +3 -3
  25. package/components/main/main.component.d.ts +1 -1
  26. package/components/navigation/navigation.component.d.ts +8 -9
  27. package/components/page/page-tab.directive.d.ts +1 -1
  28. package/components/page/page.component.d.ts +1 -1
  29. package/directives/scroll-into-view/scroll-into-view.directive.d.ts +1 -1
  30. package/directives/text-code/text-code.directive.d.ts +1 -1
  31. package/{esm2015/addon-doc.module.js → esm2020/addon-doc.module.mjs} +4 -4
  32. package/esm2020/components/code/code.component.mjs +42 -0
  33. package/{esm2015/components/code/code.module.js → esm2020/components/code/code.module.mjs} +9 -11
  34. package/esm2020/components/copy/copy.component.mjs +35 -0
  35. package/{esm2015/components/copy/copy.module.js → esm2020/components/copy/copy.module.mjs} +5 -5
  36. package/esm2020/components/demo/demo.component.mjs +179 -0
  37. package/{esm2015/components/demo/demo.module.js → esm2020/components/demo/demo.module.mjs} +23 -25
  38. package/esm2020/components/doc-tab/doc-tab.component.mjs +17 -0
  39. package/esm2020/components/doc-tab/doc-tab.module.mjs +18 -0
  40. package/esm2020/components/documentation/documentation-property-connector.directive.mjs +141 -0
  41. package/esm2020/components/documentation/documentation.component.mjs +109 -0
  42. package/{esm2015/components/documentation/documentation.module.js → esm2020/components/documentation/documentation.module.mjs} +25 -25
  43. package/{esm2015/components/documentation/pipes/cleaner.pipe.js → esm2020/components/documentation/pipes/cleaner.pipe.mjs} +3 -3
  44. package/{esm2015/components/documentation/pipes/color.pipe.js → esm2020/components/documentation/pipes/color.pipe.mjs} +3 -3
  45. package/{esm2015/components/documentation/pipes/inspect.pipe.js → esm2020/components/documentation/pipes/inspect.pipe.mjs} +3 -3
  46. package/{esm2015/components/documentation/pipes/opacity.pipe.js → esm2020/components/documentation/pipes/opacity.pipe.mjs} +3 -3
  47. package/{esm2015/components/documentation/pipes/optional.pipe.js → esm2020/components/documentation/pipes/optional.pipe.mjs} +3 -3
  48. package/{esm2015/components/documentation/pipes/primitive-polymorpheus-content.pipe.js → esm2020/components/documentation/pipes/primitive-polymorpheus-content.pipe.mjs} +3 -3
  49. package/{esm2015/components/documentation/pipes/strip-optional.pipe.js → esm2020/components/documentation/pipes/strip-optional.pipe.mjs} +3 -3
  50. package/esm2020/components/documentation/pipes/type-reference.pipe.mjs +31 -0
  51. package/{esm2015/components/example/example-get-tabs.pipe.js → esm2020/components/example/example-get-tabs.pipe.mjs} +3 -3
  52. package/esm2020/components/example/example.component.mjs +150 -0
  53. package/{esm2015/components/example/example.module.js → esm2020/components/example/example.module.mjs} +13 -15
  54. package/esm2020/components/index.mjs +42 -0
  55. package/esm2020/components/internal/header/header.component.mjs +54 -0
  56. package/{esm2015/components/internal/header/header.module.js → esm2020/components/internal/header/header.module.mjs} +10 -12
  57. package/{esm2015/components/internal/input-opacity/input-opacity.directive.js → esm2020/components/internal/input-opacity/input-opacity.directive.mjs} +8 -8
  58. package/{esm2015/components/internal/input-opacity/input-opacity.module.js → esm2020/components/internal/input-opacity/input-opacity.module.mjs} +4 -4
  59. package/esm2020/components/internal/see-also/see-also.component.mjs +31 -0
  60. package/{esm2015/components/internal/see-also/see-also.module.js → esm2020/components/internal/see-also/see-also.module.mjs} +5 -5
  61. package/{esm2015/components/internal/source-code/source-code.component.js → esm2020/components/internal/source-code/source-code.component.mjs} +7 -11
  62. package/{esm2015/components/internal/source-code/source-code.module.js → esm2020/components/internal/source-code/source-code.module.mjs} +5 -5
  63. package/esm2020/components/language-switcher/language-switcher.component.mjs +61 -0
  64. package/{esm2015/components/language-switcher/language-switcher.module.js → esm2020/components/language-switcher/language-switcher.module.mjs} +9 -11
  65. package/esm2020/components/main/main.component.mjs +59 -0
  66. package/{esm2015/components/main/main.module.js → esm2020/components/main/main.module.mjs} +14 -16
  67. package/esm2020/components/navigation/navigation.component.mjs +213 -0
  68. package/{esm2015/components/navigation/navigation.module.js → esm2020/components/navigation/navigation.module.mjs} +24 -26
  69. package/esm2020/components/navigation/navigation.providers.mjs +48 -0
  70. package/{esm2015/components/page/page-tab.directive.js → esm2020/components/page/page-tab.directive.mjs} +3 -3
  71. package/esm2020/components/page/page.component.mjs +56 -0
  72. package/{esm2015/components/page/page.module.js → esm2020/components/page/page.module.mjs} +11 -13
  73. package/esm2020/directives/scroll-into-view/scroll-into-view.directive.mjs +44 -0
  74. package/{esm2015/directives/scroll-into-view/scroll-into-view.module.js → esm2020/directives/scroll-into-view/scroll-into-view.module.mjs} +4 -4
  75. package/{esm2015/directives/text-code/text-code.directive.js → esm2020/directives/text-code/text-code.directive.mjs} +3 -3
  76. package/{esm2015/directives/text-code/text-code.module.js → esm2020/directives/text-code/text-code.module.mjs} +4 -4
  77. package/{esm2015/services/theme-night.service.js → esm2020/services/theme-night.service.mjs} +4 -4
  78. package/{esm2015/services/theme.service.js → esm2020/services/theme.service.mjs} +4 -4
  79. package/esm2020/tokens/page-loaded.mjs +7 -0
  80. package/esm2020/tokens/pages.mjs +9 -0
  81. package/esm2020/utils/coerce-boolean.mjs +4 -0
  82. package/{esm2015/utils/coerce-value.js → esm2020/utils/coerce-value.mjs} +2 -2
  83. package/esm2020/utils/raw-load-record.mjs +11 -0
  84. package/esm2020/utils/raw-load.mjs +4 -0
  85. package/esm2020/utils/sort-pages.mjs +26 -0
  86. package/esm2020/utils/to-flat-map-pages.mjs +22 -0
  87. package/esm2020/utils/type-reference-parser.mjs +24 -0
  88. package/fesm2015/taiga-ui-addon-doc-components.mjs +1909 -0
  89. package/fesm2015/taiga-ui-addon-doc-components.mjs.map +1 -0
  90. package/fesm2015/taiga-ui-addon-doc-directives.mjs +99 -0
  91. package/fesm2015/taiga-ui-addon-doc-directives.mjs.map +1 -0
  92. package/fesm2015/{taiga-ui-addon-doc-interfaces.js → taiga-ui-addon-doc-interfaces.mjs} +1 -1
  93. package/fesm2015/taiga-ui-addon-doc-interfaces.mjs.map +1 -0
  94. package/fesm2015/{taiga-ui-addon-doc-languages.js → taiga-ui-addon-doc-languages.mjs} +1 -1
  95. package/fesm2015/taiga-ui-addon-doc-languages.mjs.map +1 -0
  96. package/fesm2015/taiga-ui-addon-doc-services.mjs +97 -0
  97. package/fesm2015/taiga-ui-addon-doc-services.mjs.map +1 -0
  98. package/fesm2015/{taiga-ui-addon-doc-tokens.js → taiga-ui-addon-doc-tokens.mjs} +2 -3
  99. package/fesm2015/taiga-ui-addon-doc-tokens.mjs.map +1 -0
  100. package/fesm2015/taiga-ui-addon-doc-types.mjs +4 -0
  101. package/fesm2015/taiga-ui-addon-doc-types.mjs.map +1 -0
  102. package/fesm2015/{taiga-ui-addon-doc-utils.js → taiga-ui-addon-doc-utils.mjs} +7 -6
  103. package/fesm2015/taiga-ui-addon-doc-utils.mjs.map +1 -0
  104. package/fesm2015/{taiga-ui-addon-doc.js → taiga-ui-addon-doc.mjs} +5 -5
  105. package/fesm2015/taiga-ui-addon-doc.mjs.map +1 -0
  106. package/fesm2020/taiga-ui-addon-doc-components.mjs +1879 -0
  107. package/fesm2020/taiga-ui-addon-doc-components.mjs.map +1 -0
  108. package/{fesm2015/taiga-ui-addon-doc-directives.js → fesm2020/taiga-ui-addon-doc-directives.mjs} +19 -20
  109. package/fesm2020/taiga-ui-addon-doc-directives.mjs.map +1 -0
  110. package/fesm2020/taiga-ui-addon-doc-interfaces.mjs +12 -0
  111. package/fesm2020/taiga-ui-addon-doc-interfaces.mjs.map +1 -0
  112. package/fesm2020/taiga-ui-addon-doc-languages.mjs +46 -0
  113. package/fesm2020/taiga-ui-addon-doc-languages.mjs.map +1 -0
  114. package/{fesm2015/taiga-ui-addon-doc-services.js → fesm2020/taiga-ui-addon-doc-services.mjs} +7 -7
  115. package/fesm2020/taiga-ui-addon-doc-services.mjs.map +1 -0
  116. package/fesm2020/taiga-ui-addon-doc-tokens.mjs +148 -0
  117. package/fesm2020/taiga-ui-addon-doc-tokens.mjs.map +1 -0
  118. package/fesm2020/taiga-ui-addon-doc-types.mjs +4 -0
  119. package/fesm2020/taiga-ui-addon-doc-types.mjs.map +1 -0
  120. package/fesm2020/taiga-ui-addon-doc-utils.mjs +275 -0
  121. package/fesm2020/taiga-ui-addon-doc-utils.mjs.map +1 -0
  122. package/fesm2020/taiga-ui-addon-doc.mjs +49 -0
  123. package/fesm2020/taiga-ui-addon-doc.mjs.map +1 -0
  124. package/interfaces/page.d.ts +3 -3
  125. package/package.json +115 -38
  126. package/styles/markdown.less +118 -0
  127. package/tokens/pages.d.ts +4 -2
  128. package/types/pages.d.ts +1 -1
  129. package/utils/type-reference-parser.d.ts +1 -1
  130. package/bundles/taiga-ui-addon-doc-components.umd.js +0 -2500
  131. package/bundles/taiga-ui-addon-doc-components.umd.js.map +0 -1
  132. package/bundles/taiga-ui-addon-doc-directives.umd.js +0 -140
  133. package/bundles/taiga-ui-addon-doc-directives.umd.js.map +0 -1
  134. package/bundles/taiga-ui-addon-doc-interfaces.umd.js +0 -22
  135. package/bundles/taiga-ui-addon-doc-interfaces.umd.js.map +0 -1
  136. package/bundles/taiga-ui-addon-doc-languages.umd.js +0 -54
  137. package/bundles/taiga-ui-addon-doc-languages.umd.js.map +0 -1
  138. package/bundles/taiga-ui-addon-doc-services.umd.js +0 -457
  139. package/bundles/taiga-ui-addon-doc-services.umd.js.map +0 -1
  140. package/bundles/taiga-ui-addon-doc-tokens.umd.js +0 -179
  141. package/bundles/taiga-ui-addon-doc-tokens.umd.js.map +0 -1
  142. package/bundles/taiga-ui-addon-doc-types.umd.js +0 -11
  143. package/bundles/taiga-ui-addon-doc-types.umd.js.map +0 -1
  144. package/bundles/taiga-ui-addon-doc-utils.umd.js +0 -671
  145. package/bundles/taiga-ui-addon-doc-utils.umd.js.map +0 -1
  146. package/bundles/taiga-ui-addon-doc.umd.js +0 -117
  147. package/bundles/taiga-ui-addon-doc.umd.js.map +0 -1
  148. package/components/package.json +0 -10
  149. package/components/taiga-ui-addon-doc-components.d.ts +0 -5
  150. package/directives/package.json +0 -10
  151. package/directives/taiga-ui-addon-doc-directives.d.ts +0 -5
  152. package/esm2015/components/code/code.component.js +0 -48
  153. package/esm2015/components/copy/copy.component.js +0 -42
  154. package/esm2015/components/demo/demo.component.js +0 -183
  155. package/esm2015/components/documentation/documentation-property-connector.directive.js +0 -127
  156. package/esm2015/components/documentation/documentation.component.js +0 -117
  157. package/esm2015/components/documentation/pipes/type-reference.pipe.js +0 -34
  158. package/esm2015/components/example/example.component.js +0 -152
  159. package/esm2015/components/index.js +0 -40
  160. package/esm2015/components/internal/header/header.component.js +0 -60
  161. package/esm2015/components/internal/see-also/see-also.component.js +0 -37
  162. package/esm2015/components/language-switcher/language-switcher.component.js +0 -67
  163. package/esm2015/components/main/main.component.js +0 -68
  164. package/esm2015/components/navigation/navigation.component.js +0 -223
  165. package/esm2015/components/navigation/navigation.providers.js +0 -48
  166. package/esm2015/components/page/page.component.js +0 -62
  167. package/esm2015/directives/scroll-into-view/scroll-into-view.directive.js +0 -45
  168. package/esm2015/tokens/page-loaded.js +0 -8
  169. package/esm2015/tokens/pages.js +0 -9
  170. package/esm2015/utils/coerce-boolean.js +0 -4
  171. package/esm2015/utils/raw-load-record.js +0 -14
  172. package/esm2015/utils/raw-load.js +0 -7
  173. package/esm2015/utils/sort-pages.js +0 -23
  174. package/esm2015/utils/to-flat-map-pages.js +0 -23
  175. package/esm2015/utils/type-reference-parser.js +0 -24
  176. package/fesm2015/taiga-ui-addon-doc-components.js +0 -1928
  177. package/fesm2015/taiga-ui-addon-doc-components.js.map +0 -1
  178. package/fesm2015/taiga-ui-addon-doc-directives.js.map +0 -1
  179. package/fesm2015/taiga-ui-addon-doc-interfaces.js.map +0 -1
  180. package/fesm2015/taiga-ui-addon-doc-languages.js.map +0 -1
  181. package/fesm2015/taiga-ui-addon-doc-services.js.map +0 -1
  182. package/fesm2015/taiga-ui-addon-doc-tokens.js.map +0 -1
  183. package/fesm2015/taiga-ui-addon-doc-types.js +0 -4
  184. package/fesm2015/taiga-ui-addon-doc-types.js.map +0 -1
  185. package/fesm2015/taiga-ui-addon-doc-utils.js.map +0 -1
  186. package/fesm2015/taiga-ui-addon-doc.js.map +0 -1
  187. package/interfaces/package.json +0 -10
  188. package/interfaces/taiga-ui-addon-doc-interfaces.d.ts +0 -5
  189. package/languages/package.json +0 -10
  190. package/languages/taiga-ui-addon-doc-languages.d.ts +0 -5
  191. package/services/package.json +0 -10
  192. package/services/taiga-ui-addon-doc-services.d.ts +0 -5
  193. package/taiga-ui-addon-doc.d.ts +0 -5
  194. package/tokens/package.json +0 -10
  195. package/tokens/taiga-ui-addon-doc-tokens.d.ts +0 -5
  196. package/types/package.json +0 -10
  197. package/types/taiga-ui-addon-doc-types.d.ts +0 -5
  198. package/utils/package.json +0 -10
  199. package/utils/taiga-ui-addon-doc-utils.d.ts +0 -5
  200. /package/{esm2015/components/example/example.options.js → esm2020/components/example/example.options.mjs} +0 -0
  201. /package/{esm2015/components/page/page.providers.js → esm2020/components/page/page.providers.mjs} +0 -0
  202. /package/{esm2015/components/taiga-ui-addon-doc-components.js → esm2020/components/taiga-ui-addon-doc-components.mjs} +0 -0
  203. /package/{esm2015/directives/index.js → esm2020/directives/index.mjs} +0 -0
  204. /package/{esm2015/directives/taiga-ui-addon-doc-directives.js → esm2020/directives/taiga-ui-addon-doc-directives.mjs} +0 -0
  205. /package/{esm2015/index.js → esm2020/index.mjs} +0 -0
  206. /package/{esm2015/interfaces/code-editor.js → esm2020/interfaces/code-editor.mjs} +0 -0
  207. /package/{esm2015/interfaces/demo-params.js → esm2020/interfaces/demo-params.mjs} +0 -0
  208. /package/{esm2015/interfaces/index.js → esm2020/interfaces/index.mjs} +0 -0
  209. /package/{esm2015/interfaces/page.js → esm2020/interfaces/page.mjs} +0 -0
  210. /package/{esm2015/interfaces/source-code-path-options.js → esm2020/interfaces/source-code-path-options.mjs} +0 -0
  211. /package/{esm2015/interfaces/taiga-ui-addon-doc-interfaces.js → esm2020/interfaces/taiga-ui-addon-doc-interfaces.mjs} +0 -0
  212. /package/{esm2015/languages/index.js → esm2020/languages/index.mjs} +0 -0
  213. /package/{esm2015/languages/russian.js → esm2020/languages/russian.mjs} +0 -0
  214. /package/{esm2015/languages/taiga-ui-addon-doc-languages.js → esm2020/languages/taiga-ui-addon-doc-languages.mjs} +0 -0
  215. /package/{esm2015/services/index.js → esm2020/services/index.mjs} +0 -0
  216. /package/{esm2015/services/taiga-ui-addon-doc-services.js → esm2020/services/taiga-ui-addon-doc-services.mjs} +0 -0
  217. /package/{esm2015/services/theme-night.options.js → esm2020/services/theme-night.options.mjs} +0 -0
  218. /package/{esm2015/services/theme.options.js → esm2020/services/theme.options.mjs} +0 -0
  219. /package/{esm2015/taiga-ui-addon-doc.js → esm2020/taiga-ui-addon-doc.mjs} +0 -0
  220. /package/{esm2015/tokens/code-actions.js → esm2020/tokens/code-actions.mjs} +0 -0
  221. /package/{esm2015/tokens/code-editor.js → esm2020/tokens/code-editor.mjs} +0 -0
  222. /package/{esm2015/tokens/default-tabs.js → esm2020/tokens/default-tabs.mjs} +0 -0
  223. /package/{esm2015/tokens/doc-icons.js → esm2020/tokens/doc-icons.mjs} +0 -0
  224. /package/{esm2015/tokens/example-content-processor.js → esm2020/tokens/example-content-processor.mjs} +0 -0
  225. /package/{esm2015/tokens/excluded-properties.js → esm2020/tokens/excluded-properties.mjs} +0 -0
  226. /package/{esm2015/tokens/i18n.js → esm2020/tokens/i18n.mjs} +0 -0
  227. /package/{esm2015/tokens/index.js → esm2020/tokens/index.mjs} +0 -0
  228. /package/{esm2015/tokens/logo.js → esm2020/tokens/logo.mjs} +0 -0
  229. /package/{esm2015/tokens/scroll-behavior.js → esm2020/tokens/scroll-behavior.mjs} +0 -0
  230. /package/{esm2015/tokens/see-also.js → esm2020/tokens/see-also.mjs} +0 -0
  231. /package/{esm2015/tokens/source-code.js → esm2020/tokens/source-code.mjs} +0 -0
  232. /package/{esm2015/tokens/taiga-ui-addon-doc-tokens.js → esm2020/tokens/taiga-ui-addon-doc-tokens.mjs} +0 -0
  233. /package/{esm2015/tokens/title.js → esm2020/tokens/title.mjs} +0 -0
  234. /package/{esm2015/tokens/type-reference-handler.js → esm2020/tokens/type-reference-handler.mjs} +0 -0
  235. /package/{esm2015/tokens/url-state-handler.js → esm2020/tokens/url-state-handler.mjs} +0 -0
  236. /package/{esm2015/types/index.js → esm2020/types/index.mjs} +0 -0
  237. /package/{esm2015/types/pages.js → esm2020/types/pages.mjs} +0 -0
  238. /package/{esm2015/types/taiga-ui-addon-doc-types.js → esm2020/types/taiga-ui-addon-doc-types.mjs} +0 -0
  239. /package/{esm2015/utils/generate-routes.js → esm2020/utils/generate-routes.mjs} +0 -0
  240. /package/{esm2015/utils/index.js → esm2020/utils/index.mjs} +0 -0
  241. /package/{esm2015/utils/inspect.js → esm2020/utils/inspect.mjs} +0 -0
  242. /package/{esm2015/utils/is-page-group.js → esm2020/utils/is-page-group.mjs} +0 -0
  243. /package/{esm2015/utils/parse-code-block.js → esm2020/utils/parse-code-block.mjs} +0 -0
  244. /package/{esm2015/utils/taiga-ui-addon-doc-utils.js → esm2020/utils/taiga-ui-addon-doc-utils.mjs} +0 -0
  245. /package/{esm2015/utils/transliterate-keyboard-layout.js → esm2020/utils/transliterate-keyboard-layout.mjs} +0 -0
@@ -1,183 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { Location } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, forwardRef, HostBinding, HostListener, Inject, Input, TemplateRef, ViewChild, } from '@angular/core';
4
- import { FormGroup } from '@angular/forms';
5
- import { UrlSerializer } from '@angular/router';
6
- import { TUI_DOC_DEMO_TEXTS, TUI_DOC_URL_STATE_HANDLER } from '@taiga-ui/addon-doc/tokens';
7
- import { tuiCoerceValueIsTrue } from '@taiga-ui/addon-doc/utils';
8
- import { TUI_IS_MOBILE, tuiClamp, tuiCleanObject, TuiDestroyService, tuiPure, tuiPx, TuiResizeableDirective, tuiToInteger, } from '@taiga-ui/cdk';
9
- import { TuiModeDirective } from '@taiga-ui/core';
10
- import { TUI_ARROW_OPTIONS } from '@taiga-ui/kit';
11
- import { Subject } from 'rxjs';
12
- import * as i0 from "@angular/core";
13
- import * as i1 from "@taiga-ui/core";
14
- import * as i2 from "@taiga-ui/kit";
15
- import * as i3 from "@angular/router";
16
- import * as i4 from "@angular/common";
17
- import * as i5 from "@angular/forms";
18
- import * as i6 from "@taiga-ui/cdk";
19
- const MIN_WIDTH = 160;
20
- export class TuiDocDemoComponent {
21
- constructor(options, isMobile, el, locationRef, urlSerializer, texts, urlStateHandler) {
22
- var _a, _b;
23
- this.options = options;
24
- this.isMobile = isMobile;
25
- this.el = el;
26
- this.locationRef = locationRef;
27
- this.urlSerializer = urlSerializer;
28
- this.texts = texts;
29
- this.urlStateHandler = urlStateHandler;
30
- this.control = null;
31
- this.sticky = true;
32
- this.template = null;
33
- this.updateOnVariants = ['change', 'blur', 'submit'];
34
- this.updateOn = this.params.updateOn || this.updateOnVariants[0];
35
- this.opaque = tuiCoerceValueIsTrue((_a = this.params.sandboxOpaque) !== null && _a !== void 0 ? _a : true);
36
- this.expanded = tuiCoerceValueIsTrue((_b = this.params.sandboxExpanded) !== null && _b !== void 0 ? _b : false);
37
- this.mode = this.params.tuiMode || null;
38
- this.sandboxWidth = tuiToInteger(this.params.sandboxWidth);
39
- this.change$ = new Subject();
40
- this.items = ['onLight', 'onDark'];
41
- }
42
- onResize() {
43
- this.updateWidth();
44
- this.onMouseUp();
45
- }
46
- onMouseUp() {
47
- this.updateUrl({ sandboxWidth: this.sandboxWidth });
48
- }
49
- ngOnInit() {
50
- this.createForm();
51
- this.updateWidth(this.sandboxWidth + this.delta);
52
- }
53
- onModeChange(mode) {
54
- this.mode = mode;
55
- this.updateUrl({ sandboxWidth: this.sandboxWidth });
56
- this.change$.next();
57
- }
58
- toggleDetails() {
59
- this.expanded = !this.expanded;
60
- this.updateUrl({ sandboxExpanded: this.expanded });
61
- }
62
- changeOpaque(opaque) {
63
- this.opaque = opaque;
64
- this.updateUrl({ sandboxOpaque: this.opaque });
65
- }
66
- updateOnChange(updateOn) {
67
- this.updateOn = updateOn;
68
- this.updateUrl({ updateOn });
69
- this.createForm();
70
- }
71
- updateWidth(width = NaN) {
72
- if (!this.resizer || !this.resizeable || !this.content) {
73
- return;
74
- }
75
- const safe = width || this.resizeable.nativeElement.clientWidth;
76
- const total = this.el.nativeElement.clientWidth;
77
- const clamped = Math.round(tuiClamp(safe, MIN_WIDTH, total)) - this.delta;
78
- const validated = safe < total ? clamped : NaN;
79
- this.resizer.nativeElement.textContent = String(clamped || '-');
80
- this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : '';
81
- this.sandboxWidth = validated;
82
- }
83
- get delta() {
84
- return this.resizeable && this.content
85
- ? this.resizeable.nativeElement.clientWidth -
86
- this.content.nativeElement.clientWidth
87
- : 0;
88
- }
89
- updateUrl(params) {
90
- const tree = this.getUrlTree();
91
- const { queryParams } = tree;
92
- delete queryParams.sandboxWidth;
93
- delete queryParams.tuiMode;
94
- tree.queryParams = Object.assign(Object.assign({}, queryParams), tuiCleanObject(Object.assign({ tuiMode: this.mode }, params)));
95
- this.locationRef.go(this.urlStateHandler(tree));
96
- }
97
- createForm() {
98
- const { control, updateOn } = this;
99
- if (control) {
100
- this.testForm = new FormGroup({ testValue: control }, { updateOn });
101
- }
102
- }
103
- getUrlTree() {
104
- return this.urlSerializer.parse(this.locationRef.path());
105
- }
106
- get params() {
107
- return this.getUrlTree().queryParams;
108
- }
109
- }
110
- TuiDocDemoComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocDemoComponent, deps: [{ token: TUI_ARROW_OPTIONS }, { token: TUI_IS_MOBILE }, { token: ElementRef }, { token: Location }, { token: UrlSerializer }, { token: TUI_DOC_DEMO_TEXTS }, { token: TUI_DOC_URL_STATE_HANDLER }], target: i0.ɵɵFactoryTarget.Component });
111
- TuiDocDemoComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiDocDemoComponent, selector: "tui-doc-demo", inputs: { control: "control", sticky: "sticky" }, host: { listeners: { "window:resize": "onResize()", "document:mouseup.silent": "onMouseUp()" }, properties: { "class._sticky": "this.sticky" } }, providers: [
112
- TuiDestroyService,
113
- {
114
- provide: TuiModeDirective,
115
- useExisting: forwardRef(() => TuiDocDemoComponent),
116
- },
117
- ], queries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true }], viewQueries: [{ propertyName: "resizeable", first: true, predicate: TuiResizeableDirective, descendants: true, static: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, static: true }, { propertyName: "resizer", first: true, predicate: ["resizer"], descendants: true, static: true }], ngImport: i0, template: "<div\n class=\"t-bg-toggle\"\n [tuiMode]=\"null\"\n>\n <ng-template #tooltip>\n {{ texts[0] }}\n <a\n routerLink=\"/directives/mode\"\n tuiLink\n tuiMode=\"onDark\"\n >\n <code>tuiMode</code>\n </a>\n </ng-template>\n <ng-container *ngIf=\"isMobile; else desktop\">\n <tui-select\n tuiTextfieldSize=\"s\"\n class=\"t-mode\"\n [ngModel]=\"mode\"\n [tuiHintContent]=\"tooltip\"\n [tuiTextfieldCleaner]=\"true\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n tuiMode\n <tui-data-list-wrapper\n *tuiDataList\n [items]=\"items\"\n ></tui-data-list-wrapper>\n </tui-select>\n </ng-container>\n <ng-template #desktop>\n tuiMode:\n <tui-tooltip\n describeId=\"form\"\n [content]=\"tooltip\"\n ></tui-tooltip>\n <div\n tuiGroup\n class=\"t-group\"\n [collapsed]=\"true\"\n >\n <tui-radio-block\n nativeId=\"form\"\n size=\"s\"\n class=\"tui-group__auto-width-item\"\n [hideRadio]=\"true\"\n [item]=\"null\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n null\n </tui-radio-block>\n <tui-radio-block\n item=\"onDark\"\n nativeId=\"form\"\n size=\"s\"\n class=\"tui-group__auto-width-item\"\n [hideRadio]=\"true\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n onDark\n </tui-radio-block>\n <tui-radio-block\n item=\"onLight\"\n nativeId=\"form\"\n size=\"s\"\n class=\"tui-group__auto-width-item\"\n [hideRadio]=\"true\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n onLight\n </tui-radio-block>\n </div>\n </ng-template>\n <tui-checkbox-labeled\n size=\"m\"\n class=\"t-checkbox\"\n [ngModel]=\"opaque\"\n (ngModelChange)=\"changeOpaque($event)\"\n >\n {{ texts[1] }}\n </tui-checkbox-labeled>\n</div>\n<div\n tuiResizeable\n class=\"t-wrapper\"\n [class.t-wrapper_dark]=\"mode === 'onDark'\"\n [class.t-wrapper_gray]=\"mode === 'onLight'\"\n [class.t-wrapper_transparent]=\"!opaque\"\n>\n <div\n id=\"demo-content\"\n class=\"t-content\"\n >\n <div #content>\n <form\n *ngIf=\"testForm\"\n class=\"t-form\"\n [formGroup]=\"testForm\"\n >\n <div class=\"t-input-wrapper\">\n <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n </div>\n <button\n automation-id=\"tui-demo-button__toggle-details\"\n size=\"s\"\n tuiButton\n type=\"button\"\n class=\"t-button\"\n [iconRight]=\"icon\"\n (click)=\"toggleDetails()\"\n >\n {{ texts[2] }}\n </button>\n <ng-template #icon>\n <tui-svg\n class=\"t-icon\"\n [class.t-icon_rotated]=\"expanded\"\n [src]=\"options.iconSmall\"\n ></tui-svg>\n </ng-template>\n <tui-expand\n class=\"t-expand\"\n [expanded]=\"expanded\"\n >\n <ng-template tuiExpandContent>\n <pre class=\"t-value\">Form data: {{ testForm.value | json }}</pre>\n <div\n tuiGroup\n class=\"t-form-controls\"\n >\n <tui-select\n automation-id=\"tui-demo-select__expand-update-on\"\n tuiTextfieldSize=\"s\"\n class=\"t-select\"\n [ngModel]=\"updateOn\"\n [ngModelOptions]=\"{standalone: true}\"\n (ngModelChange)=\"updateOnChange($event)\"\n >\n updateOn\n <tui-data-list-wrapper\n *tuiDataList\n [items]=\"updateOnVariants\"\n ></tui-data-list-wrapper>\n </tui-select>\n <button\n automation-id=\"tui-demo-button__reset-state\"\n size=\"s\"\n tuiButton\n type=\"reset\"\n class=\"tui-group__auto-width-item\"\n >\n Reset\n </button>\n <button\n automation-id=\"tui-demo-button__submit-state\"\n size=\"s\"\n tuiButton\n type=\"submit\"\n class=\"tui-group__auto-width-item\"\n >\n Submit\n </button>\n </div>\n </ng-template>\n </tui-expand>\n </form>\n <ng-content></ng-content>\n </div>\n </div>\n <div\n #resizer\n class=\"t-resizer\"\n [tuiResizer]=\"[1, 0]\"\n (tuiSizeChange)=\"updateWidth($event[0])\"\n ></div>\n</div>\n", styles: [":host{position:relative;display:block;min-width:100%;margin:1.5rem 0}.t-bg-toggle{position:absolute;bottom:calc(100% + .75rem);display:flex;align-items:center;justify-content:flex-end;pointer-events:none;width:100%}.t-bg-toggle>*{pointer-events:auto}.t-wrapper{box-shadow:var(--tui-shadow-dropdown);display:flex;border:1px solid var(--tui-base-03);border-radius:var(--tui-radius-m);max-width:100%;min-height:6rem;width:100%;min-width:10rem;background-color:var(--tui-base-01);overflow:hidden}.t-wrapper.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-base-02) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-base-02) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-base-02) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-base-02) 75%);background-size:1.25rem 1.25rem;background-position:0 0,0 .625rem,.625rem -.625rem,-.625rem 0}.t-wrapper.t-wrapper_dark{background-color:#454e58;color:var(--tui-base-01)}.t-wrapper.t-wrapper_gray{background-color:#e5e7ea}.t-wrapper.t-wrapper_dark.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-focus) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-focus) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-focus) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-focus) 75%)}.t-wrapper.t-wrapper_gray.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-base-05) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-base-05) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-base-05) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-base-05) 75%)}:host-context(tui-root._mobile) .t-wrapper{min-height:auto}.t-content{flex:1 1 0;min-width:0;padding:1.5rem;box-sizing:border-box;overflow:hidden}:host-context(tui-root._mobile) .t-content{padding:1rem}.t-form{display:flex;flex-wrap:wrap;align-items:flex-start}.t-input-wrapper{width:100%;margin-bottom:.5rem}.t-expand{width:100%}.t-icon{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}.t-icon_rotated{transform:rotate(180deg)}.t-value{flex:1;background:var(--tui-clear-inverse);padding:.75rem;border-radius:.25rem}.t-mode{width:12.5rem}.t-select{max-width:15rem}.t-resizer{box-shadow:var(--tui-shadow-dropdown);position:relative;width:3.5rem;min-height:inherit;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-left:1px solid var(--tui-base-03);outline:none;background:var(--tui-base-01);color:var(--tui-text-01)}.t-resizer:before,.t-resizer:after{content:\"\";position:absolute;top:.75rem;left:50%;bottom:calc(50% + 1rem);width:1px;background:var(--tui-base-04);box-shadow:-.25rem 0 var(--tui-base-04);transform:translate(0)}.t-resizer:after{bottom:.75rem;top:calc(50% + 1rem)}:host-context(tui-root._mobile) .t-resizer{display:none}.t-resizer-text{font:var(--tui-font-text-s);position:relative;z-index:1;padding:.75rem;background:var(--tui-base-01)}.wrapper_light .t-resizer-text{background:#3e464e}.t-group,.t-checkbox{margin-left:.75rem}.t-button,.t-form-controls{margin-top:.75rem}@supports ((position: -webkit-sticky) or (position: sticky)){@media screen and (min-height: 37.5rem){:host._sticky{position:-webkit-sticky;position:sticky;top:4.625rem;z-index:2}}}\n"], components: [{ type: i1.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { type: i2.TuiSelectComponent, selector: "tui-select", inputs: ["stringify", "identityMatcher", "valueContent"] }, { type: i2.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels])", inputs: ["items"] }, { type: i1.TuiTooltipComponent, selector: "tui-tooltip", inputs: ["content", "direction", "appearance", "showDelay", "hideDelay", "describeId", "context"] }, { type: i2.TuiRadioBlockComponent, selector: "tui-radio-block", inputs: ["item", "identityMatcher", "contentAlign", "size", "hideRadio", "pseudoDisabled"] }, { type: i2.TuiCheckboxLabeledComponent, selector: "tui-checkbox-labeled", inputs: ["size"] }, { type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { type: i1.TuiExpandComponent, selector: "tui-expand", inputs: ["async", "expanded"] }], directives: [{ type: i1.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.TuiSelectDirective, selector: "tui-select" }, { type: i1.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.TuiHintOptionsDirective, selector: "[tuiHintContent]", inputs: ["tuiHintContent", "tuiHintDirection", "tuiHintAppearance", "tuiHintShowDelay", "tuiHintHideDelay"] }, { type: i1.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { type: i1.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { type: i1.TuiGroupDirective, selector: "[tuiGroup]:not(ng-container)", inputs: ["orientation", "adaptive", "collapsed", "rounded", "size"] }, { type: i6.TuiResizeableDirective, selector: "[tuiResizeable]" }, { type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.TuiExpandContentDirective, selector: "[tuiExpandContent]" }, { type: i6.TuiResizerDirective, selector: "[tuiResizer]", inputs: ["tuiResizer"], outputs: ["tuiSizeChange"] }], pipes: { "json": i4.JsonPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
118
- __decorate([
119
- tuiPure
120
- ], TuiDocDemoComponent.prototype, "updateUrl", null);
121
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocDemoComponent, decorators: [{
122
- type: Component,
123
- args: [{
124
- selector: 'tui-doc-demo',
125
- templateUrl: './demo.template.html',
126
- styleUrls: ['./demo.style.less'],
127
- changeDetection: ChangeDetectionStrategy.OnPush,
128
- providers: [
129
- TuiDestroyService,
130
- {
131
- provide: TuiModeDirective,
132
- useExisting: forwardRef(() => TuiDocDemoComponent),
133
- },
134
- ],
135
- }]
136
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
137
- type: Inject,
138
- args: [TUI_ARROW_OPTIONS]
139
- }] }, { type: undefined, decorators: [{
140
- type: Inject,
141
- args: [TUI_IS_MOBILE]
142
- }] }, { type: i0.ElementRef, decorators: [{
143
- type: Inject,
144
- args: [ElementRef]
145
- }] }, { type: i4.Location, decorators: [{
146
- type: Inject,
147
- args: [Location]
148
- }] }, { type: i3.UrlSerializer, decorators: [{
149
- type: Inject,
150
- args: [UrlSerializer]
151
- }] }, { type: undefined, decorators: [{
152
- type: Inject,
153
- args: [TUI_DOC_DEMO_TEXTS]
154
- }] }, { type: undefined, decorators: [{
155
- type: Inject,
156
- args: [TUI_DOC_URL_STATE_HANDLER]
157
- }] }]; }, propDecorators: { resizeable: [{
158
- type: ViewChild,
159
- args: [TuiResizeableDirective, { static: true }]
160
- }], content: [{
161
- type: ViewChild,
162
- args: ['content', { static: true }]
163
- }], resizer: [{
164
- type: ViewChild,
165
- args: ['resizer', { static: true }]
166
- }], control: [{
167
- type: Input
168
- }], sticky: [{
169
- type: Input
170
- }, {
171
- type: HostBinding,
172
- args: ['class._sticky']
173
- }], template: [{
174
- type: ContentChild,
175
- args: [TemplateRef]
176
- }], onResize: [{
177
- type: HostListener,
178
- args: ['window:resize']
179
- }], onMouseUp: [{
180
- type: HostListener,
181
- args: ['document:mouseup.silent']
182
- }], updateUrl: [] } });
183
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/demo/demo.component.ts","../../../../../projects/addon-doc/components/demo/demo.template.html"],"names":[],"mappings":";AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,UAAU,EACV,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,WAAW,EACX,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAS,aAAa,EAAU,MAAM,iBAAiB,CAAC;AAE/D,OAAO,EAAC,kBAAkB,EAAE,yBAAyB,EAAC,MAAM,4BAA4B,CAAC;AACzF,OAAO,EAAC,oBAAoB,EAAC,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EACH,aAAa,EACb,QAAQ,EACR,cAAc,EACd,iBAAiB,EACjB,OAAO,EACP,KAAK,EACL,sBAAsB,EAEtB,YAAY,GACf,MAAM,eAAe,CAAC;AACvB,OAAO,EAAgB,gBAAgB,EAAC,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAC,iBAAiB,EAAkB,MAAM,eAAe,CAAC;AACjE,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;;;;;;;;AAE7B,MAAM,SAAS,GAAG,GAAG,CAAC;AAetB,MAAM,OAAO,mBAAmB;IAmC5B,YACwC,OAAwB,EAC5B,QAAiB,EACZ,EAA2B,EAC7B,WAAqB,EAChB,aAA4B,EAC/B,KAA+B,EAEnD,eAA0C;;QAPvB,YAAO,GAAP,OAAO,CAAiB;QAC5B,aAAQ,GAAR,QAAQ,CAAS;QACZ,OAAE,GAAF,EAAE,CAAyB;QAC7B,gBAAW,GAAX,WAAW,CAAU;QAChB,kBAAa,GAAb,aAAa,CAAe;QAC/B,UAAK,GAAL,KAAK,CAA0B;QAEnD,oBAAe,GAAf,eAAe,CAA2B;QAhC/D,YAAO,GAA2B,IAAI,CAAC;QAIvC,WAAM,GAAG,IAAI,CAAC;QAGL,aAAQ,GAAgD,IAAI,CAAC;QAI7D,qBAAgB,GAAG,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAU,CAAC;QAElE,aAAQ,GACJ,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;QAErD,WAAM,GAAG,oBAAoB,CAAC,MAAA,IAAI,CAAC,MAAM,CAAC,aAAa,mCAAI,IAAI,CAAC,CAAC;QACjE,aAAQ,GAAG,oBAAoB,CAAC,MAAA,IAAI,CAAC,MAAM,CAAC,eAAe,mCAAI,KAAK,CAAC,CAAC;QACtE,SAAI,GAAyB,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;QACzD,iBAAY,GAAG,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QAE7C,YAAO,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC9B,UAAK,GAA6B,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;IAW9D,CAAC;IAGJ,QAAQ;QACJ,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAGD,SAAS;QACL,IAAI,CAAC,SAAS,CAAC,EAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAC,CAAC,CAAC;IACtD,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC;IAED,YAAY,CAAC,IAA0B;QACnC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,SAAS,CAAC,EAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAC,CAAC,CAAC;QAClD,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAED,aAAa;QACT,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,SAAS,CAAC,EAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,EAAC,CAAC,CAAC;IACrD,CAAC;IAED,YAAY,CAAC,MAAe;QACxB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,SAAS,CAAC,EAAC,aAAa,EAAE,IAAI,CAAC,MAAM,EAAC,CAAC,CAAC;IACjD,CAAC;IAED,cAAc,CAAC,QAAsC;QACjD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,EAAC,QAAQ,EAAC,CAAC,CAAC;QAC3B,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,WAAW,CAAC,QAAgB,GAAG;QAC3B,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACpD,OAAO;SACV;QAED,MAAM,IAAI,GAAG,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC;QAChE,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC;QAChD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QAC1E,MAAM,SAAS,GAAG,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;QAE/C,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,GAAG,MAAM,CAAC,OAAO,IAAI,GAAG,CAAC,CAAC;QAChE,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACzE,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;IAClC,CAAC;IAED,IAAY,KAAK;QACb,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO;YAClC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW;gBACrC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW;YAC5C,CAAC,CAAC,CAAC,CAAC;IACZ,CAAC;IAGO,SAAS,CAAC,MAAqB;QACnC,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAC/B,MAAM,EAAC,WAAW,EAAC,GAAG,IAAI,CAAC;QAE3B,OAAO,WAAW,CAAC,YAAY,CAAC;QAChC,OAAO,WAAW,CAAC,OAAO,CAAC;QAE3B,IAAI,CAAC,WAAW,mCACT,WAAW,GACX,cAAc,iBAAE,OAAO,EAAE,IAAI,CAAC,IAAI,IAAK,MAAM,EAAE,CACrD,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;IACpD,CAAC;IAEO,UAAU;QACd,MAAM,EAAC,OAAO,EAAE,QAAQ,EAAC,GAAG,IAAI,CAAC;QAEjC,IAAI,OAAO,EAAE;YACT,IAAI,CAAC,QAAQ,GAAG,IAAI,SAAS,CAAC,EAAC,SAAS,EAAE,OAAO,EAAC,EAAE,EAAC,QAAQ,EAAC,CAAC,CAAC;SACnE;IACL,CAAC;IAEO,UAAU;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;IAC7D,CAAC;IAED,IAAY,MAAM;QACd,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC;IACzC,CAAC;;iHAxIQ,mBAAmB,kBAoChB,iBAAiB,aACjB,aAAa,aACb,UAAU,aACV,QAAQ,aACR,aAAa,aACb,kBAAkB,aAClB,yBAAyB;qGA1C5B,mBAAmB,2OARjB;QACP,iBAAiB;QACjB;YACI,OAAO,EAAE,gBAAgB;YACzB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;SACrD;KACJ,gEAmBa,WAAW,4FAhBd,sBAAsB,oQCnDrC,kmMAmLA;ADtBI;IADC,OAAO;oDAcP;4FAxHQ,mBAAmB;kBAb/B,SAAS;mBAAC;oBACP,QAAQ,EAAE,cAAc;oBACxB,WAAW,EAAE,sBAAsB;oBACnC,SAAS,EAAE,CAAC,mBAAmB,CAAC;oBAChC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE;wBACP,iBAAiB;wBACjB;4BACI,OAAO,EAAE,gBAAgB;4BACzB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC;yBACrD;qBACJ;iBACJ;;0BAqCQ,MAAM;2BAAC,iBAAiB;;0BACxB,MAAM;2BAAC,aAAa;;0BACpB,MAAM;2BAAC,UAAU;;0BACjB,MAAM;2BAAC,QAAQ;;0BACf,MAAM;2BAAC,aAAa;;0BACpB,MAAM;2BAAC,kBAAkB;;0BACzB,MAAM;2BAAC,yBAAyB;4CAxCpB,UAAU;sBAD1B,SAAS;uBAAC,sBAAsB,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAIhC,OAAO;sBADvB,SAAS;uBAAC,SAAS,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAInB,OAAO;sBADvB,SAAS;uBAAC,SAAS,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAIpC,OAAO;sBADN,KAAK;gBAKN,MAAM;sBAFL,KAAK;;sBACL,WAAW;uBAAC,eAAe;gBAInB,QAAQ;sBADhB,YAAY;uBAAC,WAAW;gBA8BzB,QAAQ;sBADP,YAAY;uBAAC,eAAe;gBAO7B,SAAS;sBADR,YAAY;uBAAC,yBAAyB;gBAuD/B,SAAS","sourcesContent":["import {Location} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnInit,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {AbstractControl, FormGroup} from '@angular/forms';\nimport {Params, UrlSerializer, UrlTree} from '@angular/router';\nimport {TuiDemoParams} from '@taiga-ui/addon-doc/interfaces';\nimport {TUI_DOC_DEMO_TEXTS, TUI_DOC_URL_STATE_HANDLER} from '@taiga-ui/addon-doc/tokens';\nimport {tuiCoerceValueIsTrue} from '@taiga-ui/addon-doc/utils';\nimport {\n    TUI_IS_MOBILE,\n    tuiClamp,\n    tuiCleanObject,\n    TuiDestroyService,\n    tuiPure,\n    tuiPx,\n    TuiResizeableDirective,\n    TuiStringHandler,\n    tuiToInteger,\n} from '@taiga-ui/cdk';\nimport {TuiBrightness, TuiModeDirective} from '@taiga-ui/core';\nimport {TUI_ARROW_OPTIONS, TuiArrowOptions} from '@taiga-ui/kit';\nimport {Subject} from 'rxjs';\n\nconst MIN_WIDTH = 160;\n\n@Component({\n    selector: 'tui-doc-demo',\n    templateUrl: './demo.template.html',\n    styleUrls: ['./demo.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TuiDestroyService,\n        {\n            provide: TuiModeDirective,\n            useExisting: forwardRef(() => TuiDocDemoComponent),\n        },\n    ],\n})\nexport class TuiDocDemoComponent implements OnInit {\n    @ViewChild(TuiResizeableDirective, {static: true})\n    private readonly resizeable?: ElementRef<HTMLElement>;\n\n    @ViewChild('content', {static: true})\n    private readonly content?: ElementRef<HTMLElement>;\n\n    @ViewChild('resizer', {static: true})\n    private readonly resizer?: ElementRef<HTMLElement>;\n\n    @Input()\n    control: AbstractControl | null = null;\n\n    @Input()\n    @HostBinding('class._sticky')\n    sticky = true;\n\n    @ContentChild(TemplateRef)\n    readonly template: TemplateRef<Record<string, unknown>> | null = null;\n\n    testForm?: FormGroup;\n\n    readonly updateOnVariants = ['change', 'blur', 'submit'] as const;\n\n    updateOn: 'blur' | 'change' | 'submit' =\n        this.params.updateOn || this.updateOnVariants[0];\n\n    opaque = tuiCoerceValueIsTrue(this.params.sandboxOpaque ?? true);\n    expanded = tuiCoerceValueIsTrue(this.params.sandboxExpanded ?? false);\n    mode: TuiBrightness | null = this.params.tuiMode || null;\n    sandboxWidth = tuiToInteger(this.params.sandboxWidth);\n\n    readonly change$ = new Subject<void>();\n    readonly items: readonly TuiBrightness[] = ['onLight', 'onDark'];\n\n    constructor(\n        @Inject(TUI_ARROW_OPTIONS) readonly options: TuiArrowOptions,\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(Location) private readonly locationRef: Location,\n        @Inject(UrlSerializer) private readonly urlSerializer: UrlSerializer,\n        @Inject(TUI_DOC_DEMO_TEXTS) readonly texts: [string, string, string],\n        @Inject(TUI_DOC_URL_STATE_HANDLER)\n        private readonly urlStateHandler: TuiStringHandler<UrlTree>,\n    ) {}\n\n    @HostListener('window:resize')\n    onResize(): void {\n        this.updateWidth();\n        this.onMouseUp();\n    }\n\n    @HostListener('document:mouseup.silent')\n    onMouseUp(): void {\n        this.updateUrl({sandboxWidth: this.sandboxWidth});\n    }\n\n    ngOnInit(): void {\n        this.createForm();\n        this.updateWidth(this.sandboxWidth + this.delta);\n    }\n\n    onModeChange(mode: TuiBrightness | null): void {\n        this.mode = mode;\n        this.updateUrl({sandboxWidth: this.sandboxWidth});\n        this.change$.next();\n    }\n\n    toggleDetails(): void {\n        this.expanded = !this.expanded;\n        this.updateUrl({sandboxExpanded: this.expanded});\n    }\n\n    changeOpaque(opaque: boolean): void {\n        this.opaque = opaque;\n        this.updateUrl({sandboxOpaque: this.opaque});\n    }\n\n    updateOnChange(updateOn: 'blur' | 'change' | 'submit'): void {\n        this.updateOn = updateOn;\n        this.updateUrl({updateOn});\n        this.createForm();\n    }\n\n    updateWidth(width: number = NaN): void {\n        if (!this.resizer || !this.resizeable || !this.content) {\n            return;\n        }\n\n        const safe = width || this.resizeable.nativeElement.clientWidth;\n        const total = this.el.nativeElement.clientWidth;\n        const clamped = Math.round(tuiClamp(safe, MIN_WIDTH, total)) - this.delta;\n        const validated = safe < total ? clamped : NaN;\n\n        this.resizer.nativeElement.textContent = String(clamped || '-');\n        this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : '';\n        this.sandboxWidth = validated;\n    }\n\n    private get delta(): number {\n        return this.resizeable && this.content\n            ? this.resizeable.nativeElement.clientWidth -\n                  this.content.nativeElement.clientWidth\n            : 0;\n    }\n\n    @tuiPure\n    private updateUrl(params: TuiDemoParams): void {\n        const tree = this.getUrlTree();\n        const {queryParams} = tree;\n\n        delete queryParams.sandboxWidth;\n        delete queryParams.tuiMode;\n\n        tree.queryParams = {\n            ...queryParams,\n            ...tuiCleanObject({tuiMode: this.mode, ...params}),\n        };\n\n        this.locationRef.go(this.urlStateHandler(tree));\n    }\n\n    private createForm(): void {\n        const {control, updateOn} = this;\n\n        if (control) {\n            this.testForm = new FormGroup({testValue: control}, {updateOn});\n        }\n    }\n\n    private getUrlTree(): UrlTree {\n        return this.urlSerializer.parse(this.locationRef.path());\n    }\n\n    private get params(): Params | TuiDemoParams {\n        return this.getUrlTree().queryParams;\n    }\n}\n","<div\n    class=\"t-bg-toggle\"\n    [tuiMode]=\"null\"\n>\n    <ng-template #tooltip>\n        {{ texts[0] }}\n        <a\n            routerLink=\"/directives/mode\"\n            tuiLink\n            tuiMode=\"onDark\"\n        >\n            <code>tuiMode</code>\n        </a>\n    </ng-template>\n    <ng-container *ngIf=\"isMobile; else desktop\">\n        <tui-select\n            tuiTextfieldSize=\"s\"\n            class=\"t-mode\"\n            [ngModel]=\"mode\"\n            [tuiHintContent]=\"tooltip\"\n            [tuiTextfieldCleaner]=\"true\"\n            (ngModelChange)=\"onModeChange($event)\"\n        >\n            tuiMode\n            <tui-data-list-wrapper\n                *tuiDataList\n                [items]=\"items\"\n            ></tui-data-list-wrapper>\n        </tui-select>\n    </ng-container>\n    <ng-template #desktop>\n        tuiMode:\n        <tui-tooltip\n            describeId=\"form\"\n            [content]=\"tooltip\"\n        ></tui-tooltip>\n        <div\n            tuiGroup\n            class=\"t-group\"\n            [collapsed]=\"true\"\n        >\n            <tui-radio-block\n                nativeId=\"form\"\n                size=\"s\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [item]=\"null\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                null\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onDark\"\n                nativeId=\"form\"\n                size=\"s\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                onDark\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onLight\"\n                nativeId=\"form\"\n                size=\"s\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                onLight\n            </tui-radio-block>\n        </div>\n    </ng-template>\n    <tui-checkbox-labeled\n        size=\"m\"\n        class=\"t-checkbox\"\n        [ngModel]=\"opaque\"\n        (ngModelChange)=\"changeOpaque($event)\"\n    >\n        {{ texts[1] }}\n    </tui-checkbox-labeled>\n</div>\n<div\n    tuiResizeable\n    class=\"t-wrapper\"\n    [class.t-wrapper_dark]=\"mode === 'onDark'\"\n    [class.t-wrapper_gray]=\"mode === 'onLight'\"\n    [class.t-wrapper_transparent]=\"!opaque\"\n>\n    <div\n        id=\"demo-content\"\n        class=\"t-content\"\n    >\n        <div #content>\n            <form\n                *ngIf=\"testForm\"\n                class=\"t-form\"\n                [formGroup]=\"testForm\"\n            >\n                <div class=\"t-input-wrapper\">\n                    <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n                </div>\n                <button\n                    automation-id=\"tui-demo-button__toggle-details\"\n                    size=\"s\"\n                    tuiButton\n                    type=\"button\"\n                    class=\"t-button\"\n                    [iconRight]=\"icon\"\n                    (click)=\"toggleDetails()\"\n                >\n                    {{ texts[2] }}\n                </button>\n                <ng-template #icon>\n                    <tui-svg\n                        class=\"t-icon\"\n                        [class.t-icon_rotated]=\"expanded\"\n                        [src]=\"options.iconSmall\"\n                    ></tui-svg>\n                </ng-template>\n                <tui-expand\n                    class=\"t-expand\"\n                    [expanded]=\"expanded\"\n                >\n                    <ng-template tuiExpandContent>\n                        <pre class=\"t-value\">Form data: {{ testForm.value | json }}</pre>\n                        <div\n                            tuiGroup\n                            class=\"t-form-controls\"\n                        >\n                            <tui-select\n                                automation-id=\"tui-demo-select__expand-update-on\"\n                                tuiTextfieldSize=\"s\"\n                                class=\"t-select\"\n                                [ngModel]=\"updateOn\"\n                                [ngModelOptions]=\"{standalone: true}\"\n                                (ngModelChange)=\"updateOnChange($event)\"\n                            >\n                                updateOn\n                                <tui-data-list-wrapper\n                                    *tuiDataList\n                                    [items]=\"updateOnVariants\"\n                                ></tui-data-list-wrapper>\n                            </tui-select>\n                            <button\n                                automation-id=\"tui-demo-button__reset-state\"\n                                size=\"s\"\n                                tuiButton\n                                type=\"reset\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Reset\n                            </button>\n                            <button\n                                automation-id=\"tui-demo-button__submit-state\"\n                                size=\"s\"\n                                tuiButton\n                                type=\"submit\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Submit\n                            </button>\n                        </div>\n                    </ng-template>\n                </tui-expand>\n            </form>\n            <ng-content></ng-content>\n        </div>\n    </div>\n    <div\n        #resizer\n        class=\"t-resizer\"\n        [tuiResizer]=\"[1, 0]\"\n        (tuiSizeChange)=\"updateWidth($event[0])\"\n    ></div>\n</div>\n"]}
@@ -1,127 +0,0 @@
1
- import { Location } from '@angular/common';
2
- import { Directive, EventEmitter, Inject, Input, Output, TemplateRef, } from '@angular/core';
3
- import { ActivatedRoute, UrlSerializer } from '@angular/router';
4
- import { TUI_DOC_URL_STATE_HANDLER } from '@taiga-ui/addon-doc/tokens';
5
- import { tuiCoerceValue } from '@taiga-ui/addon-doc/utils';
6
- import { tuiIsNumber } from '@taiga-ui/cdk';
7
- import { BehaviorSubject, Subject } from 'rxjs';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/common";
10
- import * as i2 from "@angular/router";
11
- const SERIALIZED_SUFFIX = '$';
12
- // @bad TODO: refactor output and value sync
13
- export class TuiDocDocumentationPropertyConnectorDirective {
14
- constructor(template, locationRef, activatedRoute, urlSerializer, urlStateHandler) {
15
- this.template = template;
16
- this.locationRef = locationRef;
17
- this.activatedRoute = activatedRoute;
18
- this.urlSerializer = urlSerializer;
19
- this.urlStateHandler = urlStateHandler;
20
- this.documentationPropertyName = '';
21
- this.documentationPropertyMode = null;
22
- this.documentationPropertyType = '';
23
- this.documentationPropertyDeprecated = false;
24
- this.documentationPropertyValues = null;
25
- this.documentationPropertyValueChange = new EventEmitter();
26
- this.changed$ = new Subject();
27
- this.emits$ = new BehaviorSubject(1);
28
- }
29
- ngOnInit() {
30
- this.parseParams(this.activatedRoute.snapshot.queryParams);
31
- }
32
- get attrName() {
33
- switch (this.documentationPropertyMode) {
34
- case 'input':
35
- return `[${this.documentationPropertyName}]`;
36
- case 'output':
37
- return `(${this.documentationPropertyName})`;
38
- case 'input-output':
39
- return `[(${this.documentationPropertyName})]`;
40
- default:
41
- return this.documentationPropertyName;
42
- }
43
- }
44
- get hasItems() {
45
- return !!this.documentationPropertyValues;
46
- }
47
- get shouldShowValues() {
48
- return this.documentationPropertyMode !== 'output';
49
- }
50
- ngOnChanges() {
51
- this.changed$.next();
52
- }
53
- onValueChange(value) {
54
- this.documentationPropertyValue = value;
55
- this.documentationPropertyValueChange.emit(value);
56
- this.setQueryParam(value);
57
- }
58
- emitEvent(event) {
59
- // For more convenient debugging
60
- console.info(this.attrName, event);
61
- this.emits$.next(this.emits$.value + 1);
62
- }
63
- parseParams(params) {
64
- const propertyValue = params[this.documentationPropertyName];
65
- const propertyValueWithSuffix = params[`${this.documentationPropertyName}${SERIALIZED_SUFFIX}`];
66
- if (!propertyValue && !propertyValueWithSuffix) {
67
- return;
68
- }
69
- let value = !!propertyValueWithSuffix && this.documentationPropertyValues
70
- ? this.documentationPropertyValues[propertyValueWithSuffix]
71
- : tuiCoerceValue(propertyValue);
72
- if (this.documentationPropertyType === 'string' && tuiIsNumber(value)) {
73
- value = value.toString();
74
- }
75
- this.onValueChange(value);
76
- }
77
- setQueryParam(value) {
78
- const tree = this.urlSerializer.parse(this.locationRef.path());
79
- const isValueAvailableByKey = value instanceof Object;
80
- const computedValue = isValueAvailableByKey && this.documentationPropertyValues
81
- ? this.documentationPropertyValues.indexOf(value)
82
- : value;
83
- const suffix = isValueAvailableByKey ? SERIALIZED_SUFFIX : '';
84
- const propName = this.documentationPropertyName + suffix;
85
- tree.queryParams = Object.assign(Object.assign({}, tree.queryParams), { [propName]: computedValue });
86
- this.locationRef.go(this.urlStateHandler(tree));
87
- }
88
- }
89
- TuiDocDocumentationPropertyConnectorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocDocumentationPropertyConnectorDirective, deps: [{ token: TemplateRef }, { token: Location }, { token: ActivatedRoute }, { token: UrlSerializer }, { token: TUI_DOC_URL_STATE_HANDLER }], target: i0.ɵɵFactoryTarget.Directive });
90
- TuiDocDocumentationPropertyConnectorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiDocDocumentationPropertyConnectorDirective, selector: "ng-template[documentationPropertyName]", inputs: { documentationPropertyName: "documentationPropertyName", documentationPropertyMode: "documentationPropertyMode", documentationPropertyType: "documentationPropertyType", documentationPropertyValue: "documentationPropertyValue", documentationPropertyDeprecated: "documentationPropertyDeprecated", documentationPropertyValues: "documentationPropertyValues" }, outputs: { documentationPropertyValueChange: "documentationPropertyValueChange" }, exportAs: ["documentationProperty"], usesOnChanges: true, ngImport: i0 });
91
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocDocumentationPropertyConnectorDirective, decorators: [{
92
- type: Directive,
93
- args: [{
94
- selector: 'ng-template[documentationPropertyName]',
95
- exportAs: 'documentationProperty',
96
- }]
97
- }], ctorParameters: function () { return [{ type: i0.TemplateRef, decorators: [{
98
- type: Inject,
99
- args: [TemplateRef]
100
- }] }, { type: i1.Location, decorators: [{
101
- type: Inject,
102
- args: [Location]
103
- }] }, { type: i2.ActivatedRoute, decorators: [{
104
- type: Inject,
105
- args: [ActivatedRoute]
106
- }] }, { type: i2.UrlSerializer, decorators: [{
107
- type: Inject,
108
- args: [UrlSerializer]
109
- }] }, { type: undefined, decorators: [{
110
- type: Inject,
111
- args: [TUI_DOC_URL_STATE_HANDLER]
112
- }] }]; }, propDecorators: { documentationPropertyName: [{
113
- type: Input
114
- }], documentationPropertyMode: [{
115
- type: Input
116
- }], documentationPropertyType: [{
117
- type: Input
118
- }], documentationPropertyValue: [{
119
- type: Input
120
- }], documentationPropertyDeprecated: [{
121
- type: Input
122
- }], documentationPropertyValues: [{
123
- type: Input
124
- }], documentationPropertyValueChange: [{
125
- type: Output
126
- }] } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation-property-connector.directive.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/documentation/documentation-property-connector.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Location} from '@angular/common';\nimport {\n    Directive,\n    EventEmitter,\n    Inject,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    TemplateRef,\n} from '@angular/core';\nimport {ActivatedRoute, Params, UrlSerializer, UrlTree} from '@angular/router';\nimport {TUI_DOC_URL_STATE_HANDLER} from '@taiga-ui/addon-doc/tokens';\nimport {tuiCoerceValue} from '@taiga-ui/addon-doc/utils';\nimport {tuiIsNumber, TuiStringHandler} from '@taiga-ui/cdk';\nimport {BehaviorSubject, Subject} from 'rxjs';\n\nconst SERIALIZED_SUFFIX = '$';\n\nexport type TuiDocumentationPropertyType = 'input-output' | 'input' | 'output' | null;\n\n/**\n * @deprecated: use {@link TuiDocumentationPropertyType}\n * TODO: remove in v4.0\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport type DocumentationPropertyType = TuiDocumentationPropertyType;\n\n// @bad TODO: refactor output and value sync\n@Directive({\n    selector: 'ng-template[documentationPropertyName]',\n    exportAs: 'documentationProperty',\n})\nexport class TuiDocDocumentationPropertyConnectorDirective<T>\n    implements OnInit, OnChanges\n{\n    @Input()\n    documentationPropertyName = '';\n\n    @Input()\n    documentationPropertyMode: TuiDocumentationPropertyType = null;\n\n    @Input()\n    documentationPropertyType = '';\n\n    @Input()\n    documentationPropertyValue!: T;\n\n    @Input()\n    documentationPropertyDeprecated = false;\n\n    @Input()\n    documentationPropertyValues: readonly T[] | null = null;\n\n    @Output()\n    readonly documentationPropertyValueChange = new EventEmitter<T>();\n\n    readonly changed$ = new Subject<void>();\n\n    readonly emits$ = new BehaviorSubject(1);\n\n    constructor(\n        @Inject(TemplateRef) readonly template: TemplateRef<Record<string, unknown>>,\n        @Inject(Location) private readonly locationRef: Location,\n        @Inject(ActivatedRoute) private readonly activatedRoute: ActivatedRoute,\n        @Inject(UrlSerializer) private readonly urlSerializer: UrlSerializer,\n        @Inject(TUI_DOC_URL_STATE_HANDLER)\n        private readonly urlStateHandler: TuiStringHandler<UrlTree>,\n    ) {}\n\n    ngOnInit(): void {\n        this.parseParams(this.activatedRoute.snapshot.queryParams);\n    }\n\n    get attrName(): string {\n        switch (this.documentationPropertyMode) {\n            case 'input':\n                return `[${this.documentationPropertyName}]`;\n            case 'output':\n                return `(${this.documentationPropertyName})`;\n            case 'input-output':\n                return `[(${this.documentationPropertyName})]`;\n            default:\n                return this.documentationPropertyName;\n        }\n    }\n\n    get hasItems(): boolean {\n        return !!this.documentationPropertyValues;\n    }\n\n    get shouldShowValues(): boolean {\n        return this.documentationPropertyMode !== 'output';\n    }\n\n    ngOnChanges(): void {\n        this.changed$.next();\n    }\n\n    onValueChange(value: T): void {\n        this.documentationPropertyValue = value;\n        this.documentationPropertyValueChange.emit(value);\n        this.setQueryParam(value);\n    }\n\n    emitEvent(event: unknown): void {\n        // For more convenient debugging\n        console.info(this.attrName, event);\n\n        this.emits$.next(this.emits$.value + 1);\n    }\n\n    private parseParams(params: Params): void {\n        const propertyValue: string | undefined = params[this.documentationPropertyName];\n        const propertyValueWithSuffix: number | string | undefined =\n            params[`${this.documentationPropertyName}${SERIALIZED_SUFFIX}`];\n\n        if (!propertyValue && !propertyValueWithSuffix) {\n            return;\n        }\n\n        let value =\n            !!propertyValueWithSuffix && this.documentationPropertyValues\n                ? this.documentationPropertyValues[propertyValueWithSuffix as number]\n                : tuiCoerceValue(propertyValue);\n\n        if (this.documentationPropertyType === 'string' && tuiIsNumber(value)) {\n            value = value.toString();\n        }\n\n        this.onValueChange(value as T);\n    }\n\n    private setQueryParam(value: T | boolean | number | string | null): void {\n        const tree = this.urlSerializer.parse(this.locationRef.path());\n\n        const isValueAvailableByKey = value instanceof Object;\n        const computedValue =\n            isValueAvailableByKey && this.documentationPropertyValues\n                ? this.documentationPropertyValues.indexOf(value as T)\n                : value;\n\n        const suffix = isValueAvailableByKey ? SERIALIZED_SUFFIX : '';\n        const propName = this.documentationPropertyName + suffix;\n\n        tree.queryParams = {\n            ...tree.queryParams,\n            [propName]: computedValue,\n        };\n\n        this.locationRef.go(this.urlStateHandler(tree));\n    }\n}\n"]}
@@ -1,117 +0,0 @@
1
- import { animate, style, transition, trigger } from '@angular/animations';
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, Inject, Input, Self, } from '@angular/core';
3
- import { TUI_DOC_DOCUMENTATION_TEXTS, TUI_DOC_EXCLUDED_PROPERTIES, } from '@taiga-ui/addon-doc/tokens';
4
- import { EMPTY_QUERY, TuiDestroyService, tuiHexToRgb, tuiQueryListChanges, tuiWatch, } from '@taiga-ui/cdk';
5
- import { merge } from 'rxjs';
6
- import { switchMap, takeUntil } from 'rxjs/operators';
7
- import { TuiDocDocumentationPropertyConnectorDirective } from './documentation-property-connector.directive';
8
- import { TuiGetColorPipe } from './pipes/color.pipe';
9
- import { TuiGetOpacityPipe } from './pipes/opacity.pipe';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "@taiga-ui/kit";
12
- import * as i2 from "@taiga-ui/core";
13
- import * as i3 from "@angular/common";
14
- import * as i4 from "@angular/forms";
15
- import * as i5 from "../internal/input-opacity/input-opacity.directive";
16
- import * as i6 from "@taiga-ui/cdk";
17
- import * as i7 from "./pipes/strip-optional.pipe";
18
- import * as i8 from "./pipes/optional.pipe";
19
- import * as i9 from "./pipes/type-reference.pipe";
20
- import * as i10 from "./pipes/cleaner.pipe";
21
- import * as i11 from "./pipes/inspect.pipe";
22
- import * as i12 from "./pipes/opacity.pipe";
23
- import * as i13 from "./pipes/color.pipe";
24
- import * as i14 from "./pipes/primitive-polymorpheus-content.pipe";
25
- // @bad TODO subscribe propertiesConnectors changes
26
- // @bad TODO refactor to make more flexible
27
- export class TuiDocDocumentationComponent {
28
- constructor(cdr, texts, excludedProperties, destroy$, getColor, getOpacity) {
29
- this.cdr = cdr;
30
- this.texts = texts;
31
- this.excludedProperties = excludedProperties;
32
- this.destroy$ = destroy$;
33
- this.getColor = getColor;
34
- this.getOpacity = getOpacity;
35
- this.heading = '';
36
- this.showValues = true;
37
- this.isAPI = false;
38
- this.propertiesConnectors = EMPTY_QUERY;
39
- this.activeItemIndex = 0;
40
- this.matcher = (item, exclusions) => !exclusions.has(item.documentationPropertyName);
41
- }
42
- ngAfterContentInit() {
43
- tuiQueryListChanges(this.propertiesConnectors)
44
- .pipe(switchMap(items => merge(...items.map(({ changed$ }) => changed$))), tuiWatch(this.cdr), takeUntil(this.destroy$))
45
- .subscribe();
46
- }
47
- get type() {
48
- return this.isAPI ? this.texts[0] : this.texts[1];
49
- }
50
- onColorChange(connector, color) {
51
- const opacity = this.getOpacity.transform(connector.documentationPropertyValue || '');
52
- if (opacity === 100) {
53
- connector.onValueChange(color);
54
- return;
55
- }
56
- const rgb = tuiHexToRgb(color).join(', ');
57
- const result = `rgba(${rgb}, ${opacity / 100})`;
58
- connector.onValueChange(result);
59
- }
60
- onOpacityChange(connector, opacity) {
61
- const hex = this.getColor.transform(connector.documentationPropertyValue || '');
62
- const rgb = tuiHexToRgb(hex);
63
- const result = `rgba(${rgb}, ${(opacity || 0) / 100})`;
64
- connector.onValueChange(result);
65
- }
66
- }
67
- TuiDocDocumentationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocDocumentationComponent, deps: [{ token: ChangeDetectorRef }, { token: TUI_DOC_DOCUMENTATION_TEXTS }, { token: TUI_DOC_EXCLUDED_PROPERTIES }, { token: TuiDestroyService, self: true }, { token: TuiGetColorPipe }, { token: TuiGetOpacityPipe }], target: i0.ɵɵFactoryTarget.Component });
68
- TuiDocDocumentationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiDocDocumentationComponent, selector: "tui-doc-documentation", inputs: { heading: "heading", showValues: "showValues", isAPI: "isAPI" }, providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService], queries: [{ propertyName: "propertiesConnectors", predicate: TuiDocDocumentationPropertyConnectorDirective }], ngImport: i0, template: "<h1\n *ngIf=\"heading\"\n class=\"t-heading\"\n>\n {{ heading }}\n</h1>\n<ng-content></ng-content>\n<ng-container *ngIf=\"$any(propertiesConnectors) | tuiFilter: matcher : excludedProperties as properties\">\n <table\n *ngIf=\"properties.length\"\n class=\"t-table\"\n >\n <tr class=\"t-row t-row_header\">\n <th class=\"t-th t-cell t-cell_prop\">{{ texts[2] }}</th>\n <th class=\"t-th\">{{ type }}</th>\n <th\n *ngIf=\"showValues && !isAPI\"\n class=\"t-th t-cell t-th_value\"\n >\n {{ texts[3] }}\n </th>\n </tr>\n <tr\n *ngFor=\"let propertyConnector of properties\"\n class=\"t-row\"\n [class.t-deprecated]=\"propertyConnector.documentationPropertyDeprecated\"\n >\n <td class=\"t-cell\">\n <div\n automation-id=\"tui-documentation__property-name\"\n class=\"t-property\"\n >\n <code [style.color]=\"'var(--tui-accent-active)'\">\n {{ propertyConnector.attrName | tuiStripOptionalPipe }}\n </code>\n <tui-badge\n *ngIf=\"propertyConnector.attrName | tuiIsOptionalPipe\"\n size=\"s\"\n value=\"Optional\"\n ></tui-badge>\n </div>\n <span\n *ngIf=\"propertyConnector.documentationPropertyDeprecated\"\n class=\"t-deprecated-label\"\n >\n deprecated\n </span>\n <ng-container [ngTemplateOutlet]=\"propertyConnector.template\"></ng-container>\n </td>\n <td class=\"t-cell\">\n <span class=\"type\">\n <code class=\"t-code-type\">\n <ng-container\n *ngFor=\"\n let item of propertyConnector.documentationPropertyType | tuiDocTypeReference;\n let last = last\n \"\n >\n <a\n *ngIf=\"item.reference; else default\"\n target=\"_blank\"\n class=\"t-code-reference\"\n [attr.href]=\"item.reference\"\n >\n {{ item.type }}\n </a>\n <ng-template #default>\n {{ item.type }}\n </ng-template>\n <span *ngIf=\"!last\">&nbsp;|&nbsp;</span>\n </ng-container>\n </code>\n </span>\n </td>\n <td\n *ngIf=\"showValues\"\n class=\"t-cell t-cell_value\"\n >\n <ng-container *ngIf=\"propertyConnector.shouldShowValues; else elseEmitter\">\n <tui-select\n *ngIf=\"propertyConnector.hasItems; else noItems\"\n tuiDropdownLimitWidth=\"min\"\n tuiTextfieldSize=\"m\"\n [nativeId]=\"propertyConnector.attrName\"\n [ngModel]=\"propertyConnector.documentationPropertyValue\"\n [tuiTextfieldCleaner]=\"propertyConnector.documentationPropertyType | tuiShowCleanerPipe\"\n [tuiTextfieldLabelOutside]=\"true\"\n [valueContent]=\"selectContent\"\n (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n >\n <code class=\"t-exception\">null</code>\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"selectContent\"\n [items]=\"propertyConnector.documentationPropertyValues\"\n ></tui-data-list-wrapper>\n </tui-select>\n <ng-template\n #selectContent\n let-data\n >\n <code>{{ data | tuiInspectAny }}</code>\n </ng-template>\n\n <ng-template #noItems>\n <ng-container [ngSwitch]=\"propertyConnector.documentationPropertyType\">\n <tui-toggle\n *ngSwitchCase=\"'boolean'\"\n size=\"l\"\n [nativeId]=\"propertyConnector.attrName\"\n [ngModel]=\"propertyConnector.documentationPropertyValue\"\n [showIcons]=\"true\"\n (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n ></tui-toggle>\n\n <tui-primitive-textfield\n *ngSwitchCase=\"'string'\"\n tuiTextfieldSize=\"m\"\n [nativeId]=\"propertyConnector.attrName\"\n [tuiTextfieldCleaner]=\"true\"\n [tuiTextfieldLabelOutside]=\"true\"\n [value]=\"propertyConnector.documentationPropertyValue || ''\"\n (valueChange)=\"propertyConnector.onValueChange($event)\"\n ></tui-primitive-textfield>\n\n <div\n *ngSwitchCase=\"'color'\"\n tuiGroup\n >\n <tui-primitive-textfield\n tuiTextfieldSize=\"m\"\n [attr.id]=\"propertyConnector.attrName\"\n [tuiInputOpacity]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n [tuiTextfieldLabelOutside]=\"true\"\n [value]=\"propertyConnector.documentationPropertyValue | tuiGetColorPipe\"\n (valueChange)=\"onColorChange(propertyConnector, $event)\"\n >\n <input\n tuiTextfield\n type=\"text\"\n />\n </tui-primitive-textfield>\n <tui-input-number\n tuiTextfieldSize=\"m\"\n [max]=\"100\"\n [min]=\"0\"\n [ngModel]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n [step]=\"1\"\n (ngModelChange)=\"onOpacityChange(propertyConnector, $event)\"\n >\n Opacity\n </tui-input-number>\n </div>\n\n <tui-input-number\n *ngSwitchCase=\"'number'\"\n tuiTextfieldSize=\"m\"\n [nativeId]=\"propertyConnector.attrName\"\n [ngModel]=\"propertyConnector.documentationPropertyValue\"\n [step]=\"1\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"propertyConnector.onValueChange($event || 0)\"\n ></tui-input-number>\n\n <ng-container *ngSwitchCase=\"'PolymorpheusContent'\">\n <tui-primitive-textfield\n *ngIf=\"\n propertyConnector.documentationPropertyValue\n | tuiIsPrimitivePolymorpheusContentPipe\n \"\n tuiTextfieldSize=\"m\"\n [nativeId]=\"propertyConnector.attrName\"\n [tuiTextfieldCleaner]=\"true\"\n [tuiTextfieldLabelOutside]=\"true\"\n [value]=\"propertyConnector.documentationPropertyValue.toString()\"\n (valueChange)=\"propertyConnector.onValueChange($event)\"\n >\n Default content\n </tui-primitive-textfield>\n </ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n\n <ng-template #elseEmitter>\n <tui-notification\n class=\"t-output\"\n [@emitEvent]=\"propertyConnector.emits$ | async\"\n >\n Emit!\n </tui-notification>\n </ng-template>\n </td>\n </tr>\n </table>\n</ng-container>\n", styles: [":host{display:block;min-width:100%}.t-table{width:100%;table-layout:fixed}.t-row:not(:last-child){border-bottom:1px solid var(--tui-base-03)}:host-context(tui-root._mobile) .t-row{display:flex;flex-wrap:wrap}:host-context(tui-root._mobile) .t-row_header{display:none}.t-cell{padding:1rem 1rem .875rem}.t-cell:first-child{padding-left:0}.t-cell:last-child{padding-right:0}.t-cell_prop{width:40%}.t-cell_value{text-align:right}:host-context(tui-root._mobile) .t-cell{width:100%;height:auto;padding:.5rem 0;text-align:left}.t-th{padding:.5rem 1rem;color:var(--tui-text-02);font-weight:normal;text-align:left}.t-th_value{max-width:20rem;text-align:right}:host-context(tui-root._mobile) .t-th_value{width:9.375rem}.t-property{font:var(--tui-font-text-m);margin-bottom:.25rem;font-family:monospace;color:#8f75d1}:host-context(tui-root._mobile) .t-property{padding:.5rem 0}.t-type{font-family:monospace}.t-deprecated{background-color:var(--tui-error-bg);box-shadow:-1rem 0 var(--tui-error-bg),1rem 0 var(--tui-error-bg)}.t-deprecated-label{margin-right:.125rem;color:var(--tui-error-fill)}.t-exception{display:block;width:-webkit-max-content;width:max-content}.t-output{text-align:left;opacity:0}.t-heading{font:var(--tui-font-heading-4)}.t-code-type{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start}.t-code-reference{display:inline-flex;color:var(--tui-link);text-decoration:none;align-items:center;justify-content:center;grid-gap:3px;gap:3px}.t-code-reference:after{content:\"\";font-size:1rem;width:1rem;height:1rem;background:currentColor;-webkit-mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"1rem\" height=\"1rem\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6\"></path><polyline points=\"15 3 21 3 21 9\"></polyline><line x1=\"10\" y1=\"14\" x2=\"21\" y2=\"3\"></line></svg>') center / 100%;mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"1rem\" height=\"1rem\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6\"></path><polyline points=\"15 3 21 3 21 9\"></polyline><line x1=\"10\" y1=\"14\" x2=\"21\" y2=\"3\"></line></svg>') center / 100%}\n"], components: [{ type: i1.TuiBadgeComponent, selector: "tui-badge", inputs: ["value", "size", "status", "hoverable"] }, { type: i1.TuiSelectComponent, selector: "tui-select", inputs: ["stringify", "identityMatcher", "valueContent"] }, { type: i1.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels])", inputs: ["items"] }, { type: i1.TuiToggleComponent, selector: "tui-toggle", inputs: ["singleColor", "showIcons", "showLoader", "size"] }, { type: i2.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i2.TuiTextfieldComponent, selector: "input[tuiTextfield], textarea[tuiTextfield]" }, { type: i1.TuiInputNumberComponent, selector: "tui-input-number", inputs: ["min", "max", "decimal", "precision", "step", "prefix", "postfix"] }, { type: i2.TuiNotificationComponent, selector: "tui-notification", inputs: ["hasIcon", "icon", "status", "size", "hideClose"], outputs: ["close"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.TuiSelectDirective, selector: "tui-select" }, { type: i2.TuiDropdownOptionsDirective, selector: "[tuiDropdownAlign], [tuiDropdownAppearance], [tuiDropdownDirection], [tuiDropdownLimitWidth], [tuiDropdownMinHeight], [tuiDropdownMaxHeight], [tuiDropdownOffset]", inputs: ["tuiDropdownAlign", "tuiDropdownAppearance", "tuiDropdownDirection", "tuiDropdownLimitWidth", "tuiDropdownMinHeight", "tuiDropdownMaxHeight", "tuiDropdownOffset"] }, { type: i2.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { type: i2.TuiTextfieldLabelOutsideDirective, selector: "[tuiTextfieldLabelOutside]", inputs: ["tuiTextfieldLabelOutside"] }, { type: i2.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i2.TuiGroupDirective, selector: "[tuiGroup]:not(ng-container)", inputs: ["orientation", "adaptive", "collapsed", "rounded", "size"] }, { type: i5.TuiInputOpacityDirective, selector: "[tuiInputOpacity]", inputs: ["tuiInputOpacity"] }, { type: i1.TuiInputNumberDirective, selector: "tui-input-number" }], pipes: { "tuiFilter": i6.TuiFilterPipe, "tuiStripOptionalPipe": i7.TuiStripOptionalPipe, "tuiIsOptionalPipe": i8.TuiIsOptionalPipe, "tuiDocTypeReference": i9.TuiDocTypeReferencePipe, "tuiShowCleanerPipe": i10.TuiShowCleanerPipe, "tuiInspectAny": i11.TuiInspectPipe, "tuiGetOpacity": i12.TuiGetOpacityPipe, "tuiGetColorPipe": i13.TuiGetColorPipe, "tuiIsPrimitivePolymorpheusContentPipe": i14.TuiIsPrimitivePolymorpheusContentPipe, "async": i3.AsyncPipe }, animations: [
69
- trigger('emitEvent', [
70
- transition(':increment', [style({ opacity: 1 }), animate('500ms ease-in')]),
71
- ]),
72
- ], changeDetection: i0.ChangeDetectionStrategy.OnPush });
73
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocDocumentationComponent, decorators: [{
74
- type: Component,
75
- args: [{
76
- selector: 'tui-doc-documentation',
77
- templateUrl: './documentation.template.html',
78
- styleUrls: ['./documentation.style.less'],
79
- changeDetection: ChangeDetectionStrategy.OnPush,
80
- providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService],
81
- animations: [
82
- trigger('emitEvent', [
83
- transition(':increment', [style({ opacity: 1 }), animate('500ms ease-in')]),
84
- ]),
85
- ],
86
- }]
87
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef, decorators: [{
88
- type: Inject,
89
- args: [ChangeDetectorRef]
90
- }] }, { type: undefined, decorators: [{
91
- type: Inject,
92
- args: [TUI_DOC_DOCUMENTATION_TEXTS]
93
- }] }, { type: Set, decorators: [{
94
- type: Inject,
95
- args: [TUI_DOC_EXCLUDED_PROPERTIES]
96
- }] }, { type: i6.TuiDestroyService, decorators: [{
97
- type: Self
98
- }, {
99
- type: Inject,
100
- args: [TuiDestroyService]
101
- }] }, { type: i13.TuiGetColorPipe, decorators: [{
102
- type: Inject,
103
- args: [TuiGetColorPipe]
104
- }] }, { type: i12.TuiGetOpacityPipe, decorators: [{
105
- type: Inject,
106
- args: [TuiGetOpacityPipe]
107
- }] }]; }, propDecorators: { heading: [{
108
- type: Input
109
- }], showValues: [{
110
- type: Input
111
- }], isAPI: [{
112
- type: Input
113
- }], propertiesConnectors: [{
114
- type: ContentChildren,
115
- args: [TuiDocDocumentationPropertyConnectorDirective]
116
- }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/documentation/documentation.component.ts","../../../../../projects/addon-doc/components/documentation/documentation.template.html"],"names":[],"mappings":"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","sourcesContent":["import {animate, style, transition, trigger} from '@angular/animations';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    Inject,\n    Input,\n    QueryList,\n    Self,\n} from '@angular/core';\nimport {\n    TUI_DOC_DOCUMENTATION_TEXTS,\n    TUI_DOC_EXCLUDED_PROPERTIES,\n} from '@taiga-ui/addon-doc/tokens';\nimport {\n    EMPTY_QUERY,\n    TuiDestroyService,\n    tuiHexToRgb,\n    tuiQueryListChanges,\n    TuiTypedMatcher,\n    tuiWatch,\n} from '@taiga-ui/cdk';\nimport {merge} from 'rxjs';\nimport {switchMap, takeUntil} from 'rxjs/operators';\n\nimport {TuiDocDocumentationPropertyConnectorDirective} from './documentation-property-connector.directive';\nimport {TuiGetColorPipe} from './pipes/color.pipe';\nimport {TuiGetOpacityPipe} from './pipes/opacity.pipe';\n\n// @bad TODO subscribe propertiesConnectors changes\n// @bad TODO refactor to make more flexible\n@Component({\n    selector: 'tui-doc-documentation',\n    templateUrl: './documentation.template.html',\n    styleUrls: ['./documentation.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService],\n    animations: [\n        trigger('emitEvent', [\n            transition(':increment', [style({opacity: 1}), animate('500ms ease-in')]),\n        ]),\n    ],\n})\nexport class TuiDocDocumentationComponent implements AfterContentInit {\n    @Input()\n    heading = '';\n\n    @Input()\n    showValues = true;\n\n    @Input()\n    isAPI = false;\n\n    @ContentChildren(TuiDocDocumentationPropertyConnectorDirective)\n    propertiesConnectors: QueryList<TuiDocDocumentationPropertyConnectorDirective<any>> =\n        EMPTY_QUERY;\n\n    activeItemIndex = 0;\n\n    constructor(\n        @Inject(ChangeDetectorRef) private readonly cdr: ChangeDetectorRef,\n        @Inject(TUI_DOC_DOCUMENTATION_TEXTS)\n        readonly texts: [string, string, string, string, string],\n        @Inject(TUI_DOC_EXCLUDED_PROPERTIES)\n        readonly excludedProperties: Set<string>,\n        @Self()\n        @Inject(TuiDestroyService)\n        private readonly destroy$: TuiDestroyService,\n        @Inject(TuiGetColorPipe)\n        private readonly getColor: TuiGetColorPipe,\n        @Inject(TuiGetOpacityPipe)\n        private readonly getOpacity: TuiGetOpacityPipe,\n    ) {}\n\n    ngAfterContentInit(): void {\n        tuiQueryListChanges(this.propertiesConnectors)\n            .pipe(\n                switchMap(items => merge(...items.map(({changed$}) => changed$))),\n                tuiWatch(this.cdr),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    get type(): string {\n        return this.isAPI ? this.texts[0] : this.texts[1];\n    }\n\n    matcher: TuiTypedMatcher<\n        [TuiDocDocumentationPropertyConnectorDirective<any>, Set<string>]\n    > = (item, exclusions) => !exclusions.has(item.documentationPropertyName);\n\n    onColorChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        color: string,\n    ): void {\n        const opacity = this.getOpacity.transform(\n            connector.documentationPropertyValue || '',\n        );\n\n        if (opacity === 100) {\n            connector.onValueChange(color);\n\n            return;\n        }\n\n        const rgb = tuiHexToRgb(color).join(', ');\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n\n    onOpacityChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        opacity: number | null,\n    ): void {\n        const hex = this.getColor.transform(connector.documentationPropertyValue || '');\n        const rgb = tuiHexToRgb(hex);\n        const result = `rgba(${rgb}, ${(opacity || 0) / 100})`;\n\n        connector.onValueChange(result);\n    }\n}\n","<h1\n    *ngIf=\"heading\"\n    class=\"t-heading\"\n>\n    {{ heading }}\n</h1>\n<ng-content></ng-content>\n<ng-container *ngIf=\"$any(propertiesConnectors) | tuiFilter: matcher : excludedProperties as properties\">\n    <table\n        *ngIf=\"properties.length\"\n        class=\"t-table\"\n    >\n        <tr class=\"t-row t-row_header\">\n            <th class=\"t-th t-cell t-cell_prop\">{{ texts[2] }}</th>\n            <th class=\"t-th\">{{ type }}</th>\n            <th\n                *ngIf=\"showValues && !isAPI\"\n                class=\"t-th t-cell t-th_value\"\n            >\n                {{ texts[3] }}\n            </th>\n        </tr>\n        <tr\n            *ngFor=\"let propertyConnector of properties\"\n            class=\"t-row\"\n            [class.t-deprecated]=\"propertyConnector.documentationPropertyDeprecated\"\n        >\n            <td class=\"t-cell\">\n                <div\n                    automation-id=\"tui-documentation__property-name\"\n                    class=\"t-property\"\n                >\n                    <code [style.color]=\"'var(--tui-accent-active)'\">\n                        {{ propertyConnector.attrName | tuiStripOptionalPipe }}\n                    </code>\n                    <tui-badge\n                        *ngIf=\"propertyConnector.attrName | tuiIsOptionalPipe\"\n                        size=\"s\"\n                        value=\"Optional\"\n                    ></tui-badge>\n                </div>\n                <span\n                    *ngIf=\"propertyConnector.documentationPropertyDeprecated\"\n                    class=\"t-deprecated-label\"\n                >\n                    deprecated\n                </span>\n                <ng-container [ngTemplateOutlet]=\"propertyConnector.template\"></ng-container>\n            </td>\n            <td class=\"t-cell\">\n                <span class=\"type\">\n                    <code class=\"t-code-type\">\n                        <ng-container\n                            *ngFor=\"\n                                let item of propertyConnector.documentationPropertyType | tuiDocTypeReference;\n                                let last = last\n                            \"\n                        >\n                            <a\n                                *ngIf=\"item.reference; else default\"\n                                target=\"_blank\"\n                                class=\"t-code-reference\"\n                                [attr.href]=\"item.reference\"\n                            >\n                                {{ item.type }}\n                            </a>\n                            <ng-template #default>\n                                {{ item.type }}\n                            </ng-template>\n                            <span *ngIf=\"!last\">&nbsp;|&nbsp;</span>\n                        </ng-container>\n                    </code>\n                </span>\n            </td>\n            <td\n                *ngIf=\"showValues\"\n                class=\"t-cell t-cell_value\"\n            >\n                <ng-container *ngIf=\"propertyConnector.shouldShowValues; else elseEmitter\">\n                    <tui-select\n                        *ngIf=\"propertyConnector.hasItems; else noItems\"\n                        tuiDropdownLimitWidth=\"min\"\n                        tuiTextfieldSize=\"m\"\n                        [nativeId]=\"propertyConnector.attrName\"\n                        [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                        [tuiTextfieldCleaner]=\"propertyConnector.documentationPropertyType | tuiShowCleanerPipe\"\n                        [tuiTextfieldLabelOutside]=\"true\"\n                        [valueContent]=\"selectContent\"\n                        (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                    >\n                        <code class=\"t-exception\">null</code>\n                        <tui-data-list-wrapper\n                            *tuiDataList\n                            [itemContent]=\"selectContent\"\n                            [items]=\"propertyConnector.documentationPropertyValues\"\n                        ></tui-data-list-wrapper>\n                    </tui-select>\n                    <ng-template\n                        #selectContent\n                        let-data\n                    >\n                        <code>{{ data | tuiInspectAny }}</code>\n                    </ng-template>\n\n                    <ng-template #noItems>\n                        <ng-container [ngSwitch]=\"propertyConnector.documentationPropertyType\">\n                            <tui-toggle\n                                *ngSwitchCase=\"'boolean'\"\n                                size=\"l\"\n                                [nativeId]=\"propertyConnector.attrName\"\n                                [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                                [showIcons]=\"true\"\n                                (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                            ></tui-toggle>\n\n                            <tui-primitive-textfield\n                                *ngSwitchCase=\"'string'\"\n                                tuiTextfieldSize=\"m\"\n                                [nativeId]=\"propertyConnector.attrName\"\n                                [tuiTextfieldCleaner]=\"true\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [value]=\"propertyConnector.documentationPropertyValue || ''\"\n                                (valueChange)=\"propertyConnector.onValueChange($event)\"\n                            ></tui-primitive-textfield>\n\n                            <div\n                                *ngSwitchCase=\"'color'\"\n                                tuiGroup\n                            >\n                                <tui-primitive-textfield\n                                    tuiTextfieldSize=\"m\"\n                                    [attr.id]=\"propertyConnector.attrName\"\n                                    [tuiInputOpacity]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                    [tuiTextfieldLabelOutside]=\"true\"\n                                    [value]=\"propertyConnector.documentationPropertyValue | tuiGetColorPipe\"\n                                    (valueChange)=\"onColorChange(propertyConnector, $event)\"\n                                >\n                                    <input\n                                        tuiTextfield\n                                        type=\"text\"\n                                    />\n                                </tui-primitive-textfield>\n                                <tui-input-number\n                                    tuiTextfieldSize=\"m\"\n                                    [max]=\"100\"\n                                    [min]=\"0\"\n                                    [ngModel]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                    [step]=\"1\"\n                                    (ngModelChange)=\"onOpacityChange(propertyConnector, $event)\"\n                                >\n                                    Opacity\n                                </tui-input-number>\n                            </div>\n\n                            <tui-input-number\n                                *ngSwitchCase=\"'number'\"\n                                tuiTextfieldSize=\"m\"\n                                [nativeId]=\"propertyConnector.attrName\"\n                                [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                                [step]=\"1\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                (ngModelChange)=\"propertyConnector.onValueChange($event || 0)\"\n                            ></tui-input-number>\n\n                            <ng-container *ngSwitchCase=\"'PolymorpheusContent'\">\n                                <tui-primitive-textfield\n                                    *ngIf=\"\n                                        propertyConnector.documentationPropertyValue\n                                            | tuiIsPrimitivePolymorpheusContentPipe\n                                    \"\n                                    tuiTextfieldSize=\"m\"\n                                    [nativeId]=\"propertyConnector.attrName\"\n                                    [tuiTextfieldCleaner]=\"true\"\n                                    [tuiTextfieldLabelOutside]=\"true\"\n                                    [value]=\"propertyConnector.documentationPropertyValue.toString()\"\n                                    (valueChange)=\"propertyConnector.onValueChange($event)\"\n                                >\n                                    Default content\n                                </tui-primitive-textfield>\n                            </ng-container>\n                        </ng-container>\n                    </ng-template>\n                </ng-container>\n\n                <ng-template #elseEmitter>\n                    <tui-notification\n                        class=\"t-output\"\n                        [@emitEvent]=\"propertyConnector.emits$ | async\"\n                    >\n                        Emit!\n                    </tui-notification>\n                </ng-template>\n            </td>\n        </tr>\n    </table>\n</ng-container>\n"]}