Skip to content

Commit

Permalink
fix(addon-doc): glitch width content between value from DOM and sandb…
Browse files Browse the repository at this point in the history
…ox width from url
  • Loading branch information
splincode authored and nsbarsukov committed Oct 4, 2024
1 parent 2c9a668 commit bd635df
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 11 deletions.
3 changes: 2 additions & 1 deletion projects/addon-doc/components/demo/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -25,16 +25,17 @@
class="t-wrapper"
[attr.tuiTheme]="theme()"
[class.t-wrapper_transparent]="!opaque"
[style.visibility]="rendered() ? 'visible' : 'hidden'"
>
<div class="t-content">
<div
#content
id="demo-content"
>
<form
*ngIf="testForm"
class="t-form"
[formGroup]="testForm"
[style.display]="testForm.get('testValue')?.value ? 'block' : 'none'"
>
<div class="t-input-wrapper">
<ng-container [ngTemplateOutlet]="template" />
Expand Down
33 changes: 23 additions & 10 deletions projects/addon-doc/components/demo/index.ts
Original file line number Diff line number Diff line change
@@ -1,25 +1,28 @@
import {JsonPipe, Location, NgIf, NgTemplateOutlet} from '@angular/common';
import type {ElementRef, OnInit} from '@angular/core';
import {JsonPipe, Location, NgTemplateOutlet} from '@angular/common';
import type {AfterViewInit, ElementRef} from '@angular/core';
import {
ChangeDetectionStrategy,
Component,
computed,
ContentChild,
DestroyRef,
inject,
Input,
NgZone,
signal,
TemplateRef,
ViewChild,
} from '@angular/core';
import {takeUntilDestroyed, toObservable} from '@angular/core/rxjs-interop';
import type {AbstractControl} from '@angular/forms';
import {FormGroup, FormsModule, ReactiveFormsModule} from '@angular/forms';
import {FormControl, FormGroup, FormsModule, ReactiveFormsModule} from '@angular/forms';
import type {Params, UrlTree} from '@angular/router';
import {UrlSerializer} from '@angular/router';
import {TUI_DOC_DEMO_TEXTS, TUI_DOC_URL_STATE_HANDLER} from '@taiga-ui/addon-doc/tokens';
import type {TuiDemoParams} from '@taiga-ui/addon-doc/types';
import {tuiCleanObject, tuiCoerceValueIsTrue} from '@taiga-ui/addon-doc/utils';
import {TuiResizable, TuiResizer} from '@taiga-ui/cdk/directives/resizer';
import {tuiZonefreeScheduler} from '@taiga-ui/cdk/observables';
import {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';
import {tuiClamp, tuiToInteger} from '@taiga-ui/cdk/utils/math';
import {tuiPure, tuiPx} from '@taiga-ui/cdk/utils/miscellaneous';
Expand All @@ -32,7 +35,7 @@ import {TuiSwitch} from '@taiga-ui/kit/components/switch';
import {TuiChevron} from '@taiga-ui/kit/directives/chevron';
import {TuiSelectModule} from '@taiga-ui/legacy/components/select';
import {TuiTextfieldControllerModule} from '@taiga-ui/legacy/directives/textfield-controller';
import {skip} from 'rxjs';
import {skip, timer} from 'rxjs';

const MIN_WIDTH = 160;

Expand All @@ -42,7 +45,6 @@ const MIN_WIDTH = 160;
imports: [
FormsModule,
JsonPipe,
NgIf,
NgTemplateOutlet,
ReactiveFormsModule,
TuiButton,
Expand All @@ -65,7 +67,7 @@ const MIN_WIDTH = 160;
'(document:mouseup.silent)': 'onMouseUp()',
},
})
export class TuiDocDemo implements OnInit {
export class TuiDocDemo implements AfterViewInit {
@ViewChild(TuiResizable, {static: true})
private readonly resizable?: ElementRef<HTMLElement>;

Expand All @@ -76,6 +78,8 @@ export class TuiDocDemo implements OnInit {
private readonly resizer?: ElementRef<HTMLElement>;

private readonly el = tuiInjectElement();
private readonly destroyRef = inject(DestroyRef);
private readonly ngZone = inject(NgZone);
private readonly locationRef = inject(Location);
private readonly urlSerializer = inject(UrlSerializer);
private readonly urlStateHandler = inject(TUI_DOC_URL_STATE_HANDLER);
Expand All @@ -84,6 +88,8 @@ export class TuiDocDemo implements OnInit {
@ContentChild(TemplateRef)
protected readonly template: TemplateRef<Record<string, unknown>> | null = null;

protected readonly rendered = signal(false);

protected theme = computed(() => (this.dark() ? 'dark' : 'light'));

protected dark = signal(
Expand All @@ -94,7 +100,9 @@ export class TuiDocDemo implements OnInit {
.pipe(skip(1), takeUntilDestroyed())
.subscribe((mode) => this.onModeChange(mode));

protected testForm?: FormGroup;
protected testForm = new FormGroup<{testValue: AbstractControl}>({
testValue: new FormControl(null),
});

protected readonly updateOnVariants = ['change', 'blur', 'submit'] as const;

Expand All @@ -112,9 +120,14 @@ export class TuiDocDemo implements OnInit {
@Input()
public sticky = true;

public ngOnInit(): void {
this.createForm();
this.updateWidth(this.sandboxWidth + this.delta);
public ngAfterViewInit(): void {
timer(0, tuiZonefreeScheduler(this.ngZone))
.pipe(takeUntilDestroyed(this.destroyRef))
.subscribe(() => {
this.createForm();
this.updateWidth(this.sandboxWidth + this.delta);
this.rendered.set(true);
});
}

protected onResize(): void {
Expand Down

0 comments on commit bd635df

Please sign in to comment.