@taiga-ui/addon-doc 3.39.1 → 3.40.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taiga-ui-addon-doc-components.umd.js +49 -17
- package/bundles/taiga-ui-addon-doc-components.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-doc-tokens.umd.js +19 -4
- package/bundles/taiga-ui-addon-doc-tokens.umd.js.map +1 -1
- package/components/demo/demo.component.d.ts +3 -1
- package/components/example/example.component.d.ts +1 -1
- package/components/example/example.options.d.ts +1 -0
- package/components/internal/header/header.component.d.ts +3 -1
- package/components/internal/source-code/source-code.component.d.ts +3 -1
- package/components/main/main.component.d.ts +4 -1
- package/components/navigation/navigation.component.d.ts +6 -3
- package/esm2015/components/demo/demo.component.js +9 -4
- package/esm2015/components/example/example.component.js +2 -2
- package/esm2015/components/example/example.options.js +2 -1
- package/esm2015/components/internal/header/header.component.js +9 -5
- package/esm2015/components/internal/source-code/source-code.component.js +9 -5
- package/esm2015/components/main/main.component.js +13 -5
- package/esm2015/components/navigation/navigation.component.js +14 -6
- package/esm2015/tokens/doc-icons.js +13 -0
- package/esm2015/tokens/index.js +2 -1
- package/fesm2015/taiga-ui-addon-doc-components.js +48 -20
- package/fesm2015/taiga-ui-addon-doc-components.js.map +1 -1
- package/fesm2015/taiga-ui-addon-doc-tokens.js +14 -1
- package/fesm2015/taiga-ui-addon-doc-tokens.js.map +1 -1
- package/package.json +5 -5
- package/tokens/doc-icons.d.ts +11 -0
- package/tokens/index.d.ts +1 -0
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
(function (global, factory) {
|
|
2
|
-
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@taiga-ui/addon-doc/utils'), require('rxjs'), require('rxjs/operators')) :
|
|
3
|
-
typeof define === 'function' && define.amd ? define('@taiga-ui/addon-doc/tokens', ['exports', '@angular/core', '@taiga-ui/addon-doc/utils', 'rxjs', 'rxjs/operators'], factory) :
|
|
4
|
-
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["taiga-ui"] = global["taiga-ui"] || {}, global["taiga-ui"]["addon-doc"] = global["taiga-ui"]["addon-doc"] || {}, global["taiga-ui"]["addon-doc"].tokens = {}), global.ng.core, global["taiga-ui"]["addon-doc"].utils, global.rxjs, global.rxjs.operators));
|
|
5
|
-
})(this, (function (exports, core, utils, rxjs, operators) { 'use strict';
|
|
2
|
+
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@taiga-ui/cdk'), require('@taiga-ui/addon-doc/utils'), require('rxjs'), require('rxjs/operators')) :
|
|
3
|
+
typeof define === 'function' && define.amd ? define('@taiga-ui/addon-doc/tokens', ['exports', '@angular/core', '@taiga-ui/cdk', '@taiga-ui/addon-doc/utils', 'rxjs', 'rxjs/operators'], factory) :
|
|
4
|
+
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["taiga-ui"] = global["taiga-ui"] || {}, global["taiga-ui"]["addon-doc"] = global["taiga-ui"]["addon-doc"] || {}, global["taiga-ui"]["addon-doc"].tokens = {}), global.ng.core, global.cdk, global["taiga-ui"]["addon-doc"].utils, global.rxjs, global.rxjs.operators));
|
|
5
|
+
})(this, (function (exports, core, cdk, utils, rxjs, operators) { 'use strict';
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* Code actions for the opened tab with code example
|
|
@@ -23,6 +23,18 @@
|
|
|
23
23
|
factory: function () { return []; },
|
|
24
24
|
});
|
|
25
25
|
|
|
26
|
+
var TUI_DOC_DEFAULT_ICONS = {
|
|
27
|
+
search: "tuiIconSearch",
|
|
28
|
+
day: "tuiIconSun",
|
|
29
|
+
night: "tuiIconMoon",
|
|
30
|
+
code: "tuiIconCode",
|
|
31
|
+
menu: "tuiIconMenuLarge",
|
|
32
|
+
};
|
|
33
|
+
var TUI_DOC_ICONS = cdk.tuiCreateOptions(TUI_DOC_DEFAULT_ICONS);
|
|
34
|
+
function tuiDocIconsProvider(icons) {
|
|
35
|
+
return cdk.tuiProvideOptions(TUI_DOC_ICONS, icons, TUI_DOC_DEFAULT_ICONS);
|
|
36
|
+
}
|
|
37
|
+
|
|
26
38
|
/**
|
|
27
39
|
* Processes content in example
|
|
28
40
|
*/
|
|
@@ -161,6 +173,7 @@
|
|
|
161
173
|
|
|
162
174
|
exports.TUI_DOC_CODE_ACTIONS = TUI_DOC_CODE_ACTIONS;
|
|
163
175
|
exports.TUI_DOC_CODE_EDITOR = TUI_DOC_CODE_EDITOR;
|
|
176
|
+
exports.TUI_DOC_DEFAULT_ICONS = TUI_DOC_DEFAULT_ICONS;
|
|
164
177
|
exports.TUI_DOC_DEFAULT_TABS = TUI_DOC_DEFAULT_TABS;
|
|
165
178
|
exports.TUI_DOC_DEMO_TEXTS = TUI_DOC_DEMO_TEXTS;
|
|
166
179
|
exports.TUI_DOC_DOCUMENTATION_TEXTS = TUI_DOC_DOCUMENTATION_TEXTS;
|
|
@@ -168,6 +181,7 @@
|
|
|
168
181
|
exports.TUI_DOC_EXAMPLE_MARKDOWN_CODE_PROCESSOR = TUI_DOC_EXAMPLE_MARKDOWN_CODE_PROCESSOR;
|
|
169
182
|
exports.TUI_DOC_EXAMPLE_TEXTS = TUI_DOC_EXAMPLE_TEXTS;
|
|
170
183
|
exports.TUI_DOC_EXCLUDED_PROPERTIES = TUI_DOC_EXCLUDED_PROPERTIES;
|
|
184
|
+
exports.TUI_DOC_ICONS = TUI_DOC_ICONS;
|
|
171
185
|
exports.TUI_DOC_LOGO = TUI_DOC_LOGO;
|
|
172
186
|
exports.TUI_DOC_MAP_PAGES = TUI_DOC_MAP_PAGES;
|
|
173
187
|
exports.TUI_DOC_MENU_TEXT = TUI_DOC_MENU_TEXT;
|
|
@@ -182,6 +196,7 @@
|
|
|
182
196
|
exports.TUI_DOC_TITLE = TUI_DOC_TITLE;
|
|
183
197
|
exports.TUI_DOC_URL_STATE_HANDLER = TUI_DOC_URL_STATE_HANDLER;
|
|
184
198
|
exports.tuiDocExcludeProperties = tuiDocExcludeProperties;
|
|
199
|
+
exports.tuiDocIconsProvider = tuiDocIconsProvider;
|
|
185
200
|
|
|
186
201
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
187
202
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-addon-doc-tokens.umd.js","sources":["../../../projects/addon-doc/tokens/code-actions.ts","../../../projects/addon-doc/tokens/code-editor.ts","../../../projects/addon-doc/tokens/default-tabs.ts","../../../projects/addon-doc/tokens/example-content-processor.ts","../../../projects/addon-doc/tokens/excluded-properties.ts","../../../projects/addon-doc/tokens/i18n.ts","../../../projects/addon-doc/tokens/logo.ts","../../../projects/addon-doc/tokens/page-loaded.ts","../../../projects/addon-doc/tokens/pages.ts","../../../projects/addon-doc/tokens/scroll-behavior.ts","../../../projects/addon-doc/tokens/see-also.ts","../../../projects/addon-doc/tokens/source-code.ts","../../../projects/addon-doc/tokens/title.ts","../../../projects/addon-doc/tokens/url-state-handler.ts","../../../projects/addon-doc/tokens/taiga-ui-addon-doc-tokens.ts"],"sourcesContent":["import {InjectionToken} from '@angular/core';\nimport {TuiContextWithImplicit} from '@taiga-ui/cdk';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n/**\n * Code actions for the opened tab with code example\n */\nexport const TUI_DOC_CODE_ACTIONS = new InjectionToken<\n PolymorpheusContent<TuiContextWithImplicit<string>>\n>(`[TUI_DOC_CODE_ACTIONS]`, {\n factory: () => ``,\n});\n","import {InjectionToken} from '@angular/core';\nimport {TuiCodeEditor} from '@taiga-ui/addon-doc/interfaces';\n\n/**\n * Service for opening online IDE e.g. Stackblitz\n */\nexport const TUI_DOC_CODE_EDITOR = new InjectionToken<TuiCodeEditor>(\n `[TUI_DOC_CODE_EDITOR]`,\n);\n","import {InjectionToken} from '@angular/core';\n\n/**\n * Array of default tab names\n */\nexport const TUI_DOC_DEFAULT_TABS = new InjectionToken<readonly string[]>(\n `[TUI_DOC_DEFAULT_TABS]`,\n {\n factory: () => [],\n },\n);\n","import {InjectionToken} from '@angular/core';\nimport {tuiTryParseMarkdownCodeBlock} from '@taiga-ui/addon-doc/utils';\nimport {TuiHandler} from '@taiga-ui/cdk';\nimport {identity} from 'rxjs';\n\n/**\n * Processes content in example\n */\nexport const TUI_DOC_EXAMPLE_CONTENT_PROCESSOR = new InjectionToken<\n TuiHandler<Record<string, string>, Record<string, string>>\n>(`[TUI_DOC_EXAMPLE_CONTENT_PROCESSOR]`, {\n factory: () => identity,\n});\n\n/**\n * Processes markdown in code block\n */\nexport const TUI_DOC_EXAMPLE_MARKDOWN_CODE_PROCESSOR = new InjectionToken<\n TuiHandler<string, string[]>\n>(`[TUI_DOC_EXAMPLE_MARKDOWN_CODE_PROCESSOR]`, {\n factory: () => tuiTryParseMarkdownCodeBlock,\n});\n","import {InjectionToken, Provider} from '@angular/core';\n\n/**\n * Token to exclude inherited documentation properties\n */\nexport const TUI_DOC_EXCLUDED_PROPERTIES = new InjectionToken<Set<string>>(\n `[TUI_DOC_EXCLUDED_PROPERTIES]`,\n {factory: () => new Set([])},\n);\n\nexport function tuiDocExcludeProperties(properties: readonly string[]): Provider {\n return {provide: TUI_DOC_EXCLUDED_PROPERTIES, useValue: new Set(properties)};\n}\n","import {InjectionToken} from '@angular/core';\n\n/**\n * TODO: think about reorganization in @taiga-ui/i18n way\n */\n\n/**\n * tui-doc-demo i18n texts\n * Works with a tuple\n * [@string tuiMode tooltip content, @string word 'background', @string 'form value']\n */\nexport const TUI_DOC_DEMO_TEXTS = new InjectionToken<[string, string, string]>(\n `[TUI_DOC_DEMO_TEXTS]`,\n {\n factory: () => [`Read more more about modes: `, `Background`, `Form value`],\n },\n);\n\n/**\n * tui-doc-documentation i18n texts\n * Works with a tuple\n * [\n * @string word 'argument',\n * @string word 'type',\n * @string 'name and description',\n * @string word 'value'\n * @string message for tooltip about ng-polymorpheus\n * ]\n */\nexport const TUI_DOC_DOCUMENTATION_TEXTS = new InjectionToken<\n [string, string, string, string, string]\n>(`[TUI_DOC_DOCUMENTATION_TEXTS]`, {\n factory: () => [\n `Argument`,\n `Type`,\n `Name and description`,\n `Value`,\n `Learn about our dynamic templates from `,\n ],\n});\n\n/**\n * tui-doc-example i18n texts\n * Works with a tuple\n * [\n * @string default tab name,\n * @string link to a sample copied message text,\n * @string link to a sample copied message label\n * ]\n */\nexport const TUI_DOC_EXAMPLE_TEXTS = new InjectionToken<[string, string, string]>(\n `[TUI_DOC_EXAMPLE_TEXTS]`,\n {\n factory: () => [`Preview`, `Link to a sample was successfully copied`, `Done`],\n },\n);\n\nexport const TUI_DOC_MENU_TEXT = new InjectionToken<string>(`[TUI_DOC_MENU_TEXT]`, {\n factory: () => `Menu`,\n});\n\nexport const TUI_DOC_SEARCH_TEXT = new InjectionToken<string>(`[TUI_DOC_SEARCH_TEXT]`, {\n factory: () => `Search`,\n});\n\nexport const TUI_DOC_SEE_ALSO_TEXT = new InjectionToken<string>(\n `[TUI_DOC_SEE_ALSO_TEXT]`,\n {\n factory: () => `See also`,\n },\n);\n\nexport const TUI_DOC_SOURCE_CODE_TEXT = new InjectionToken<string>(\n `[TUI_DOC_SOURCE_CODE_TEXT]`,\n {\n factory: () => `Source code`,\n },\n);\n","import {InjectionToken} from '@angular/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n/**\n * Main logo\n */\nexport const TUI_DOC_LOGO = new InjectionToken<PolymorpheusContent>(`[TUI_DOC_LOGO]`, {\n factory: () => ``,\n});\n","import {InjectionToken} from '@angular/core';\nimport {defer, Observable, of, timer} from 'rxjs';\nimport {switchMap} from 'rxjs/operators';\n\n/**\n * Stream that emits if loading of page is over (for example, to begin scrollIntoView)\n */\nexport const TUI_DOC_PAGE_LOADED = new InjectionToken<Observable<boolean>>(\n `[TUI_DOC_PAGE_LOADED]`,\n {factory: () => defer(() => timer(200).pipe(switchMap(() => of(true))))},\n);\n","import {inject, InjectionToken} from '@angular/core';\nimport type {TuiDocPage} from '@taiga-ui/addon-doc/interfaces';\nimport type {TuiDocPages} from '@taiga-ui/addon-doc/types';\nimport {tuiToFlatMapPages} from '@taiga-ui/addon-doc/utils';\n\n/**\n * Documentation pages\n */\nexport const TUI_DOC_PAGES: InjectionToken<TuiDocPages> = new InjectionToken<TuiDocPages>(\n `[TUI_DOC_PAGES]`,\n {\n factory: () => [],\n },\n);\n\nexport const TUI_DOC_MAP_PAGES: InjectionToken<Map<string, TuiDocPage>> =\n new InjectionToken<Map<string, TuiDocPage>>(`[TUI_DOC_MAP_PAGES]`, {\n factory: () => {\n const pages: TuiDocPages = inject(TUI_DOC_PAGES);\n\n return tuiToFlatMapPages(pages);\n },\n });\n","import {InjectionToken} from '@angular/core';\n\n/**\n * Defines the transition animation for scroll\n */\nexport const TUI_DOC_SCROLL_BEHAVIOR = new InjectionToken<ScrollBehavior>(\n `[TUI_DOC_SCROLL_BEHAVIOR]`,\n {factory: () => `smooth`},\n);\n","import {InjectionToken} from '@angular/core';\n\n/**\n * Array of arrays of related pages\n */\nexport const TUI_DOC_SEE_ALSO = new InjectionToken<ReadonlyArray<readonly string[]>>(\n `[TUI_DOC_SEE_ALSO]`,\n {\n factory: () => [],\n },\n);\n","import {InjectionToken} from '@angular/core';\nimport {TuiDocSourceCodePathOptions} from '@taiga-ui/addon-doc/interfaces';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n/**\n * Source code link\n */\nexport const TUI_DOC_SOURCE_CODE: InjectionToken<\n PolymorpheusContent<TuiDocSourceCodePathOptions>\n> = new InjectionToken<PolymorpheusContent<TuiDocSourceCodePathOptions>>(\n `[TUI_DOC_SOURCE_CODE]`,\n {\n factory: () => null,\n },\n);\n","import {InjectionToken} from '@angular/core';\n\n/**\n * Page title prefix\n */\nexport const TUI_DOC_TITLE = new InjectionToken<string>(`[TUI_DOC_TITLE]`, {\n factory: () => ``,\n});\n","import {InjectionToken} from '@angular/core';\nimport type {UrlTree} from '@angular/router';\nimport type {TuiStringHandler} from '@taiga-ui/cdk';\n\nexport const TUI_DOC_URL_STATE_HANDLER: InjectionToken<TuiStringHandler<UrlTree>> =\n new InjectionToken<TuiStringHandler<UrlTree>>(`[TUI_DOC_URL_STATE_HANDLER]`, {\n factory: () => String,\n });\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["InjectionToken","identity","tuiTryParseMarkdownCodeBlock","defer","timer","switchMap","of","inject","tuiToFlatMapPages"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"taiga-ui-addon-doc-tokens.umd.js","sources":["../../../projects/addon-doc/tokens/code-actions.ts","../../../projects/addon-doc/tokens/code-editor.ts","../../../projects/addon-doc/tokens/default-tabs.ts","../../../projects/addon-doc/tokens/doc-icons.ts","../../../projects/addon-doc/tokens/example-content-processor.ts","../../../projects/addon-doc/tokens/excluded-properties.ts","../../../projects/addon-doc/tokens/i18n.ts","../../../projects/addon-doc/tokens/logo.ts","../../../projects/addon-doc/tokens/page-loaded.ts","../../../projects/addon-doc/tokens/pages.ts","../../../projects/addon-doc/tokens/scroll-behavior.ts","../../../projects/addon-doc/tokens/see-also.ts","../../../projects/addon-doc/tokens/source-code.ts","../../../projects/addon-doc/tokens/title.ts","../../../projects/addon-doc/tokens/url-state-handler.ts","../../../projects/addon-doc/tokens/taiga-ui-addon-doc-tokens.ts"],"sourcesContent":["import {InjectionToken} from '@angular/core';\nimport {TuiContextWithImplicit} from '@taiga-ui/cdk';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n/**\n * Code actions for the opened tab with code example\n */\nexport const TUI_DOC_CODE_ACTIONS = new InjectionToken<\n PolymorpheusContent<TuiContextWithImplicit<string>>\n>(`[TUI_DOC_CODE_ACTIONS]`, {\n factory: () => ``,\n});\n","import {InjectionToken} from '@angular/core';\nimport {TuiCodeEditor} from '@taiga-ui/addon-doc/interfaces';\n\n/**\n * Service for opening online IDE e.g. Stackblitz\n */\nexport const TUI_DOC_CODE_EDITOR = new InjectionToken<TuiCodeEditor>(\n `[TUI_DOC_CODE_EDITOR]`,\n);\n","import {InjectionToken} from '@angular/core';\n\n/**\n * Array of default tab names\n */\nexport const TUI_DOC_DEFAULT_TABS = new InjectionToken<readonly string[]>(\n `[TUI_DOC_DEFAULT_TABS]`,\n {\n factory: () => [],\n },\n);\n","import {Provider} from '@angular/core';\nimport {tuiCreateOptions, tuiProvideOptions} from '@taiga-ui/cdk';\n\nexport interface TuiDocIcons {\n readonly search: string;\n readonly day: string;\n readonly night: string;\n readonly code: string;\n readonly menu: string;\n}\n\nexport const TUI_DOC_DEFAULT_ICONS: TuiDocIcons = {\n search: `tuiIconSearch`,\n day: `tuiIconSun`,\n night: `tuiIconMoon`,\n code: `tuiIconCode`,\n menu: `tuiIconMenuLarge`,\n};\n\nexport const TUI_DOC_ICONS = tuiCreateOptions(TUI_DOC_DEFAULT_ICONS);\n\nexport function tuiDocIconsProvider(icons: Partial<TuiDocIcons>): Provider {\n return tuiProvideOptions(TUI_DOC_ICONS, icons, TUI_DOC_DEFAULT_ICONS);\n}\n","import {InjectionToken} from '@angular/core';\nimport {tuiTryParseMarkdownCodeBlock} from '@taiga-ui/addon-doc/utils';\nimport {TuiHandler} from '@taiga-ui/cdk';\nimport {identity} from 'rxjs';\n\n/**\n * Processes content in example\n */\nexport const TUI_DOC_EXAMPLE_CONTENT_PROCESSOR = new InjectionToken<\n TuiHandler<Record<string, string>, Record<string, string>>\n>(`[TUI_DOC_EXAMPLE_CONTENT_PROCESSOR]`, {\n factory: () => identity,\n});\n\n/**\n * Processes markdown in code block\n */\nexport const TUI_DOC_EXAMPLE_MARKDOWN_CODE_PROCESSOR = new InjectionToken<\n TuiHandler<string, string[]>\n>(`[TUI_DOC_EXAMPLE_MARKDOWN_CODE_PROCESSOR]`, {\n factory: () => tuiTryParseMarkdownCodeBlock,\n});\n","import {InjectionToken, Provider} from '@angular/core';\n\n/**\n * Token to exclude inherited documentation properties\n */\nexport const TUI_DOC_EXCLUDED_PROPERTIES = new InjectionToken<Set<string>>(\n `[TUI_DOC_EXCLUDED_PROPERTIES]`,\n {factory: () => new Set([])},\n);\n\nexport function tuiDocExcludeProperties(properties: readonly string[]): Provider {\n return {provide: TUI_DOC_EXCLUDED_PROPERTIES, useValue: new Set(properties)};\n}\n","import {InjectionToken} from '@angular/core';\n\n/**\n * TODO: think about reorganization in @taiga-ui/i18n way\n */\n\n/**\n * tui-doc-demo i18n texts\n * Works with a tuple\n * [@string tuiMode tooltip content, @string word 'background', @string 'form value']\n */\nexport const TUI_DOC_DEMO_TEXTS = new InjectionToken<[string, string, string]>(\n `[TUI_DOC_DEMO_TEXTS]`,\n {\n factory: () => [`Read more more about modes: `, `Background`, `Form value`],\n },\n);\n\n/**\n * tui-doc-documentation i18n texts\n * Works with a tuple\n * [\n * @string word 'argument',\n * @string word 'type',\n * @string 'name and description',\n * @string word 'value'\n * @string message for tooltip about ng-polymorpheus\n * ]\n */\nexport const TUI_DOC_DOCUMENTATION_TEXTS = new InjectionToken<\n [string, string, string, string, string]\n>(`[TUI_DOC_DOCUMENTATION_TEXTS]`, {\n factory: () => [\n `Argument`,\n `Type`,\n `Name and description`,\n `Value`,\n `Learn about our dynamic templates from `,\n ],\n});\n\n/**\n * tui-doc-example i18n texts\n * Works with a tuple\n * [\n * @string default tab name,\n * @string link to a sample copied message text,\n * @string link to a sample copied message label\n * ]\n */\nexport const TUI_DOC_EXAMPLE_TEXTS = new InjectionToken<[string, string, string]>(\n `[TUI_DOC_EXAMPLE_TEXTS]`,\n {\n factory: () => [`Preview`, `Link to a sample was successfully copied`, `Done`],\n },\n);\n\nexport const TUI_DOC_MENU_TEXT = new InjectionToken<string>(`[TUI_DOC_MENU_TEXT]`, {\n factory: () => `Menu`,\n});\n\nexport const TUI_DOC_SEARCH_TEXT = new InjectionToken<string>(`[TUI_DOC_SEARCH_TEXT]`, {\n factory: () => `Search`,\n});\n\nexport const TUI_DOC_SEE_ALSO_TEXT = new InjectionToken<string>(\n `[TUI_DOC_SEE_ALSO_TEXT]`,\n {\n factory: () => `See also`,\n },\n);\n\nexport const TUI_DOC_SOURCE_CODE_TEXT = new InjectionToken<string>(\n `[TUI_DOC_SOURCE_CODE_TEXT]`,\n {\n factory: () => `Source code`,\n },\n);\n","import {InjectionToken} from '@angular/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n/**\n * Main logo\n */\nexport const TUI_DOC_LOGO = new InjectionToken<PolymorpheusContent>(`[TUI_DOC_LOGO]`, {\n factory: () => ``,\n});\n","import {InjectionToken} from '@angular/core';\nimport {defer, Observable, of, timer} from 'rxjs';\nimport {switchMap} from 'rxjs/operators';\n\n/**\n * Stream that emits if loading of page is over (for example, to begin scrollIntoView)\n */\nexport const TUI_DOC_PAGE_LOADED = new InjectionToken<Observable<boolean>>(\n `[TUI_DOC_PAGE_LOADED]`,\n {factory: () => defer(() => timer(200).pipe(switchMap(() => of(true))))},\n);\n","import {inject, InjectionToken} from '@angular/core';\nimport type {TuiDocPage} from '@taiga-ui/addon-doc/interfaces';\nimport type {TuiDocPages} from '@taiga-ui/addon-doc/types';\nimport {tuiToFlatMapPages} from '@taiga-ui/addon-doc/utils';\n\n/**\n * Documentation pages\n */\nexport const TUI_DOC_PAGES: InjectionToken<TuiDocPages> = new InjectionToken<TuiDocPages>(\n `[TUI_DOC_PAGES]`,\n {\n factory: () => [],\n },\n);\n\nexport const TUI_DOC_MAP_PAGES: InjectionToken<Map<string, TuiDocPage>> =\n new InjectionToken<Map<string, TuiDocPage>>(`[TUI_DOC_MAP_PAGES]`, {\n factory: () => {\n const pages: TuiDocPages = inject(TUI_DOC_PAGES);\n\n return tuiToFlatMapPages(pages);\n },\n });\n","import {InjectionToken} from '@angular/core';\n\n/**\n * Defines the transition animation for scroll\n */\nexport const TUI_DOC_SCROLL_BEHAVIOR = new InjectionToken<ScrollBehavior>(\n `[TUI_DOC_SCROLL_BEHAVIOR]`,\n {factory: () => `smooth`},\n);\n","import {InjectionToken} from '@angular/core';\n\n/**\n * Array of arrays of related pages\n */\nexport const TUI_DOC_SEE_ALSO = new InjectionToken<ReadonlyArray<readonly string[]>>(\n `[TUI_DOC_SEE_ALSO]`,\n {\n factory: () => [],\n },\n);\n","import {InjectionToken} from '@angular/core';\nimport {TuiDocSourceCodePathOptions} from '@taiga-ui/addon-doc/interfaces';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n/**\n * Source code link\n */\nexport const TUI_DOC_SOURCE_CODE: InjectionToken<\n PolymorpheusContent<TuiDocSourceCodePathOptions>\n> = new InjectionToken<PolymorpheusContent<TuiDocSourceCodePathOptions>>(\n `[TUI_DOC_SOURCE_CODE]`,\n {\n factory: () => null,\n },\n);\n","import {InjectionToken} from '@angular/core';\n\n/**\n * Page title prefix\n */\nexport const TUI_DOC_TITLE = new InjectionToken<string>(`[TUI_DOC_TITLE]`, {\n factory: () => ``,\n});\n","import {InjectionToken} from '@angular/core';\nimport type {UrlTree} from '@angular/router';\nimport type {TuiStringHandler} from '@taiga-ui/cdk';\n\nexport const TUI_DOC_URL_STATE_HANDLER: InjectionToken<TuiStringHandler<UrlTree>> =\n new InjectionToken<TuiStringHandler<UrlTree>>(`[TUI_DOC_URL_STATE_HANDLER]`, {\n factory: () => String,\n });\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["InjectionToken","tuiCreateOptions","tuiProvideOptions","identity","tuiTryParseMarkdownCodeBlock","defer","timer","switchMap","of","inject","tuiToFlatMapPages"],"mappings":"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"}
|
|
@@ -4,9 +4,11 @@ import { AbstractControl, FormGroup } from '@angular/forms';
|
|
|
4
4
|
import { UrlSerializer, UrlTree } from '@angular/router';
|
|
5
5
|
import { TuiStringHandler } from '@taiga-ui/cdk';
|
|
6
6
|
import { TuiBrightness } from '@taiga-ui/core';
|
|
7
|
+
import { TuiArrowOptions } from '@taiga-ui/kit';
|
|
7
8
|
import { Subject } from 'rxjs';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
export declare class TuiDocDemoComponent implements OnInit {
|
|
11
|
+
readonly options: TuiArrowOptions;
|
|
10
12
|
readonly isMobile: boolean;
|
|
11
13
|
private readonly el;
|
|
12
14
|
private readonly locationRef;
|
|
@@ -28,7 +30,7 @@ export declare class TuiDocDemoComponent implements OnInit {
|
|
|
28
30
|
sandboxWidth: number;
|
|
29
31
|
readonly change$: Subject<void>;
|
|
30
32
|
readonly items: readonly TuiBrightness[];
|
|
31
|
-
constructor(isMobile: boolean, el: ElementRef<HTMLElement>, locationRef: Location, urlSerializer: UrlSerializer, texts: [string, string, string], urlStateHandler: TuiStringHandler<UrlTree>);
|
|
33
|
+
constructor(options: TuiArrowOptions, isMobile: boolean, el: ElementRef<HTMLElement>, locationRef: Location, urlSerializer: UrlSerializer, texts: [string, string, string], urlStateHandler: TuiStringHandler<UrlTree>);
|
|
32
34
|
onResize(): void;
|
|
33
35
|
onMouseUp(): void;
|
|
34
36
|
ngOnInit(): void;
|
|
@@ -21,7 +21,7 @@ export declare class TuiDocExampleComponent {
|
|
|
21
21
|
private readonly router;
|
|
22
22
|
private readonly route;
|
|
23
23
|
private readonly ngLocation;
|
|
24
|
-
|
|
24
|
+
readonly options: TuiDocExampleOptions;
|
|
25
25
|
private readonly rawLoader$$;
|
|
26
26
|
id: string | null;
|
|
27
27
|
heading: PolymorpheusContent;
|
|
@@ -5,6 +5,7 @@ export interface TuiDocExampleOptions {
|
|
|
5
5
|
codeEditorVisibilityHandler: TuiBooleanHandler<Record<string, string>>;
|
|
6
6
|
tabTitles: Map<unknown, PolymorpheusContent>;
|
|
7
7
|
fullsize: boolean;
|
|
8
|
+
linkIcon: string;
|
|
8
9
|
}
|
|
9
10
|
export declare const TUI_DOC_EXAMPLE_DEFAULT_OPTIONS: TuiDocExampleOptions;
|
|
10
11
|
/**
|
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
import { Router } from '@angular/router';
|
|
2
|
+
import { TuiDocIcons } from '@taiga-ui/addon-doc/tokens';
|
|
2
3
|
import { TuiSwipeService } from '@taiga-ui/cdk';
|
|
3
4
|
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
export declare class TuiDocHeaderComponent {
|
|
7
|
+
readonly icons: TuiDocIcons;
|
|
6
8
|
readonly logo: PolymorpheusContent;
|
|
7
9
|
readonly menu: string;
|
|
8
10
|
private readonly router;
|
|
9
11
|
private readonly swipes$;
|
|
10
12
|
private readonly stream$;
|
|
11
13
|
readonly open$: import("rxjs").Observable<boolean>;
|
|
12
|
-
constructor(logo: PolymorpheusContent, menu: string, router: Router, swipes$: TuiSwipeService);
|
|
14
|
+
constructor(icons: TuiDocIcons, logo: PolymorpheusContent, menu: string, router: Router, swipes$: TuiSwipeService);
|
|
13
15
|
onClick(): void;
|
|
14
16
|
onActiveZone(active: boolean): void;
|
|
15
17
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocHeaderComponent, never>;
|
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
import { TuiDocSourceCodePathOptions } from '@taiga-ui/addon-doc/interfaces';
|
|
2
|
+
import { TuiDocIcons } from '@taiga-ui/addon-doc/tokens';
|
|
2
3
|
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export declare class TuiDocSourceCodeComponent {
|
|
6
|
+
readonly icons: TuiDocIcons;
|
|
5
7
|
readonly sourceCode: PolymorpheusContent<TuiDocSourceCodePathOptions>;
|
|
6
8
|
readonly text: string;
|
|
7
9
|
header: string;
|
|
8
10
|
package: string;
|
|
9
11
|
type: string;
|
|
10
12
|
path: string;
|
|
11
|
-
constructor(sourceCode: PolymorpheusContent<TuiDocSourceCodePathOptions>, text: string);
|
|
13
|
+
constructor(icons: TuiDocIcons, sourceCode: PolymorpheusContent<TuiDocSourceCodePathOptions>, text: string);
|
|
12
14
|
get pathOptions(): TuiDocSourceCodePathOptions;
|
|
13
15
|
private getPathOptions;
|
|
14
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocSourceCodeComponent, never>;
|
|
@@ -1,13 +1,16 @@
|
|
|
1
1
|
import { TuiThemeNightService, TuiThemeService } from '@taiga-ui/addon-doc/services';
|
|
2
|
+
import { TuiDocIcons } from '@taiga-ui/addon-doc/tokens';
|
|
2
3
|
import { TuiBrightness } from '@taiga-ui/core';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export declare class TuiDocMainComponent {
|
|
6
|
+
private readonly icons;
|
|
5
7
|
readonly theme: TuiThemeService;
|
|
6
8
|
readonly night: TuiThemeNightService;
|
|
7
9
|
readonly change$: TuiThemeNightService;
|
|
8
10
|
readonly night$: import("rxjs").Observable<boolean>;
|
|
9
|
-
constructor(theme: TuiThemeService, night: TuiThemeNightService);
|
|
11
|
+
constructor(icons: TuiDocIcons, theme: TuiThemeService, night: TuiThemeNightService);
|
|
10
12
|
get mode(): TuiBrightness | null;
|
|
13
|
+
get icon(): string;
|
|
11
14
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocMainComponent, never>;
|
|
12
15
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDocMainComponent, "tui-doc-main", never, {}, {}, never, ["tuiDocNavigation", "tuiDocHeader", "tuiOverContent", "tuiOverDialogs", "tuiOverAlerts", "tuiOverPortals", "tuiOverHints"]>;
|
|
13
16
|
}
|
|
@@ -3,8 +3,9 @@ import { FormControl } from '@angular/forms';
|
|
|
3
3
|
import { Title } from '@angular/platform-browser';
|
|
4
4
|
import { ActivatedRoute, Router } from '@angular/router';
|
|
5
5
|
import { TuiDocPage } from '@taiga-ui/addon-doc/interfaces';
|
|
6
|
+
import { TuiDocIcons } from '@taiga-ui/addon-doc/tokens';
|
|
6
7
|
import { TuiDocPages } from '@taiga-ui/addon-doc/types';
|
|
7
|
-
import { TuiBrightness, TuiModeDirective } from '@taiga-ui/core';
|
|
8
|
+
import { TuiBrightness, TuiCommonIcons, TuiModeDirective } from '@taiga-ui/core';
|
|
8
9
|
import { TuiInputComponent } from '@taiga-ui/kit';
|
|
9
10
|
import { Observable } from 'rxjs';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
@@ -20,6 +21,8 @@ export declare class TuiDocNavigationComponent {
|
|
|
20
21
|
private readonly destroy$;
|
|
21
22
|
private readonly readyToScroll$;
|
|
22
23
|
private readonly scrollBehavior;
|
|
24
|
+
readonly docIcons: TuiDocIcons;
|
|
25
|
+
readonly icons: TuiCommonIcons;
|
|
23
26
|
menuOpen: boolean;
|
|
24
27
|
openPagesArr: boolean[];
|
|
25
28
|
openPagesGroupsArr: boolean[];
|
|
@@ -27,7 +30,7 @@ export declare class TuiDocNavigationComponent {
|
|
|
27
30
|
readonly search: FormControl;
|
|
28
31
|
readonly filtered$: Observable<readonly (readonly TuiDocPage[])[]>;
|
|
29
32
|
readonly mode$: Observable<TuiBrightness>;
|
|
30
|
-
constructor(cdr: ChangeDetectorRef, titleService: Title, title$: Observable<string>, doc: Document, mode: TuiModeDirective, sidebar: unknown, labels: string[], items: readonly TuiDocPages[], searchText: string, router: Router, activatedRoute: ActivatedRoute, destroy$: Observable<void>, readyToScroll$: Observable<boolean>, scrollBehavior: ScrollBehavior);
|
|
33
|
+
constructor(cdr: ChangeDetectorRef, titleService: Title, title$: Observable<string>, doc: Document, mode: TuiModeDirective, sidebar: unknown, labels: string[], items: readonly TuiDocPages[], searchText: string, router: Router, activatedRoute: ActivatedRoute, destroy$: Observable<void>, readyToScroll$: Observable<boolean>, scrollBehavior: ScrollBehavior, docIcons: TuiDocIcons, icons: TuiCommonIcons);
|
|
31
34
|
get canOpen(): boolean;
|
|
32
35
|
get itemsWithoutSections(): TuiDocPages;
|
|
33
36
|
$pages(pages: any): readonly TuiDocPage[];
|
|
@@ -41,6 +44,6 @@ export declare class TuiDocNavigationComponent {
|
|
|
41
44
|
private handleAnchorLink;
|
|
42
45
|
private openActivePageGroup;
|
|
43
46
|
private navigateToAnchorLink;
|
|
44
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocNavigationComponent, [null, null, null, null, null, { optional: true; }, null, null, null, null, null, { self: true; }, null, null]>;
|
|
47
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocNavigationComponent, [null, null, null, null, null, { optional: true; }, null, null, null, null, null, { self: true; }, null, null, null, null]>;
|
|
45
48
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDocNavigationComponent, "tui-doc-navigation", never, {}, {}, never, ["*"]>;
|
|
46
49
|
}
|
|
@@ -7,6 +7,7 @@ import { TUI_DOC_DEMO_TEXTS, TUI_DOC_URL_STATE_HANDLER } from '@taiga-ui/addon-d
|
|
|
7
7
|
import { tuiCoerceValueIsTrue } from '@taiga-ui/addon-doc/utils';
|
|
8
8
|
import { TUI_IS_MOBILE, tuiClamp, tuiCleanObject, TuiDestroyService, tuiPure, tuiPx, TuiResizeableDirective, tuiToInteger, } from '@taiga-ui/cdk';
|
|
9
9
|
import { TuiModeDirective } from '@taiga-ui/core';
|
|
10
|
+
import { TUI_ARROW_OPTIONS } from '@taiga-ui/kit';
|
|
10
11
|
import { Subject } from 'rxjs';
|
|
11
12
|
import * as i0 from "@angular/core";
|
|
12
13
|
import * as i1 from "@taiga-ui/core";
|
|
@@ -17,8 +18,9 @@ import * as i5 from "@angular/forms";
|
|
|
17
18
|
import * as i6 from "@taiga-ui/cdk";
|
|
18
19
|
const MIN_WIDTH = 160;
|
|
19
20
|
export class TuiDocDemoComponent {
|
|
20
|
-
constructor(isMobile, el, locationRef, urlSerializer, texts, urlStateHandler) {
|
|
21
|
+
constructor(options, isMobile, el, locationRef, urlSerializer, texts, urlStateHandler) {
|
|
21
22
|
var _a, _b;
|
|
23
|
+
this.options = options;
|
|
22
24
|
this.isMobile = isMobile;
|
|
23
25
|
this.el = el;
|
|
24
26
|
this.locationRef = locationRef;
|
|
@@ -105,14 +107,14 @@ export class TuiDocDemoComponent {
|
|
|
105
107
|
return this.getUrlTree().queryParams;
|
|
106
108
|
}
|
|
107
109
|
}
|
|
108
|
-
TuiDocDemoComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocDemoComponent, deps: [{ 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 });
|
|
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 });
|
|
109
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: [
|
|
110
112
|
TuiDestroyService,
|
|
111
113
|
{
|
|
112
114
|
provide: TuiModeDirective,
|
|
113
115
|
useExisting: forwardRef(() => TuiDocDemoComponent),
|
|
114
116
|
},
|
|
115
|
-
], 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 tuiLink\n tuiMode=\"onDark\"\n routerLink=\"/directives/mode\"\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 [tuiTextfieldCleaner]=\"true\"\n [tuiHintContent]=\"tooltip\"\n [ngModel]=\"mode\"\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 size=\"s\"\n nativeId=\"form\"\n class=\"tui-group__auto-width-item\"\n [item]=\"null\"\n [hideRadio]=\"true\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n null\n </tui-radio-block>\n <tui-radio-block\n item=\"onDark\"\n size=\"s\"\n nativeId=\"form\"\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 size=\"s\"\n nativeId=\"form\"\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 tuiButton\n type=\"button\"\n size=\"s\"\n automation-id=\"tui-demo-button__toggle-details\"\n class=\"t-button\"\n [iconRight]=\"icon\"\n (click)=\"toggleDetails()\"\n >\n {{ texts[2] }}\n </button>\n <ng-template #icon>\n <tui-svg\n src=\"tuiIconChevronDown\"\n class=\"t-icon\"\n [class.t-icon_rotated]=\"expanded\"\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 tuiTextfieldSize=\"s\"\n automation-id=\"tui-demo-select__expand-update-on\"\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 tuiButton\n type=\"reset\"\n size=\"s\"\n automation-id=\"tui-demo-button__reset-state\"\n class=\"tui-group__auto-width-item\"\n >\n Reset\n </button>\n <button\n tuiButton\n type=\"submit\"\n size=\"s\"\n automation-id=\"tui-demo-button__submit-state\"\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:0 1.5rem 1rem #00000008,0 .75rem .75rem #0000000a,0 .25rem .375rem #0000000d;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:0 1.5rem 1rem #00000008,0 .75rem .75rem #0000000a,0 .25rem .375rem #0000000d;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"] }, { 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: i1.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { type: i1.TuiHintOptionsDirective, selector: "[tuiHintContent]", inputs: ["tuiHintContent", "tuiHintDirection", "tuiHintAppearance", "tuiHintShowDelay", "tuiHintHideDelay"] }, { 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.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 });
|
|
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 tuiLink\n tuiMode=\"onDark\"\n routerLink=\"/directives/mode\"\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 [tuiTextfieldCleaner]=\"true\"\n [tuiHintContent]=\"tooltip\"\n [ngModel]=\"mode\"\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 size=\"s\"\n nativeId=\"form\"\n class=\"tui-group__auto-width-item\"\n [item]=\"null\"\n [hideRadio]=\"true\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n null\n </tui-radio-block>\n <tui-radio-block\n item=\"onDark\"\n size=\"s\"\n nativeId=\"form\"\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 size=\"s\"\n nativeId=\"form\"\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 tuiButton\n type=\"button\"\n size=\"s\"\n automation-id=\"tui-demo-button__toggle-details\"\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 tuiTextfieldSize=\"s\"\n automation-id=\"tui-demo-select__expand-update-on\"\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 tuiButton\n type=\"reset\"\n size=\"s\"\n automation-id=\"tui-demo-button__reset-state\"\n class=\"tui-group__auto-width-item\"\n >\n Reset\n </button>\n <button\n tuiButton\n type=\"submit\"\n size=\"s\"\n automation-id=\"tui-demo-button__submit-state\"\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:0 1.5rem 1rem #00000008,0 .75rem .75rem #0000000a,0 .25rem .375rem #0000000d;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:0 1.5rem 1rem #00000008,0 .75rem .75rem #0000000a,0 .25rem .375rem #0000000d;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"] }, { 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: i1.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { type: i1.TuiHintOptionsDirective, selector: "[tuiHintContent]", inputs: ["tuiHintContent", "tuiHintDirection", "tuiHintAppearance", "tuiHintShowDelay", "tuiHintHideDelay"] }, { 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.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 });
|
|
116
118
|
__decorate([
|
|
117
119
|
tuiPure
|
|
118
120
|
], TuiDocDemoComponent.prototype, "updateUrl", null);
|
|
@@ -132,6 +134,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
132
134
|
],
|
|
133
135
|
}]
|
|
134
136
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
137
|
+
type: Inject,
|
|
138
|
+
args: [TUI_ARROW_OPTIONS]
|
|
139
|
+
}] }, { type: undefined, decorators: [{
|
|
135
140
|
type: Inject,
|
|
136
141
|
args: [TUI_IS_MOBILE]
|
|
137
142
|
}] }, { type: i0.ElementRef, decorators: [{
|
|
@@ -175,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
175
180
|
type: HostListener,
|
|
176
181
|
args: ['document:mouseup.silent']
|
|
177
182
|
}], updateUrl: [] } });
|
|
178
|
-
//# 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":"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","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 {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_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            tuiLink\n            tuiMode=\"onDark\"\n            routerLink=\"/directives/mode\"\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            [tuiTextfieldCleaner]=\"true\"\n            [tuiHintContent]=\"tooltip\"\n            [ngModel]=\"mode\"\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                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [item]=\"null\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                null\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onDark\"\n                size=\"s\"\n                nativeId=\"form\"\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                size=\"s\"\n                nativeId=\"form\"\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                    tuiButton\n                    type=\"button\"\n                    size=\"s\"\n                    automation-id=\"tui-demo-button__toggle-details\"\n                    class=\"t-button\"\n                    [iconRight]=\"icon\"\n                    (click)=\"toggleDetails()\"\n                >\n                    {{ texts[2] }}\n                </button>\n                <ng-template #icon>\n                    <tui-svg\n                        src=\"tuiIconChevronDown\"\n                        class=\"t-icon\"\n                        [class.t-icon_rotated]=\"expanded\"\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                                tuiTextfieldSize=\"s\"\n                                automation-id=\"tui-demo-select__expand-update-on\"\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                                tuiButton\n                                type=\"reset\"\n                                size=\"s\"\n                                automation-id=\"tui-demo-button__reset-state\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Reset\n                            </button>\n                            <button\n                                tuiButton\n                                type=\"submit\"\n                                size=\"s\"\n                                automation-id=\"tui-demo-button__submit-state\"\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"]}
|
|
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":"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","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            tuiLink\n            tuiMode=\"onDark\"\n            routerLink=\"/directives/mode\"\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            [tuiTextfieldCleaner]=\"true\"\n            [tuiHintContent]=\"tooltip\"\n            [ngModel]=\"mode\"\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                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [item]=\"null\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                null\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onDark\"\n                size=\"s\"\n                nativeId=\"form\"\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                size=\"s\"\n                nativeId=\"form\"\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                    tuiButton\n                    type=\"button\"\n                    size=\"s\"\n                    automation-id=\"tui-demo-button__toggle-details\"\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                                tuiTextfieldSize=\"s\"\n                                automation-id=\"tui-demo-select__expand-update-on\"\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                                tuiButton\n                                type=\"reset\"\n                                size=\"s\"\n                                automation-id=\"tui-demo-button__reset-state\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Reset\n                            </button>\n                            <button\n                                tuiButton\n                                type=\"submit\"\n                                size=\"s\"\n                                automation-id=\"tui-demo-button__submit-state\"\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"]}
|