Skip to content

Commit

Permalink
fix: overlay clipping issues
Browse files Browse the repository at this point in the history
Signed-off-by: Ivan Donchev <idonchev@vmware.com>
  • Loading branch information
Jinnie committed Jun 9, 2022
1 parent 81a9030 commit 5e38d6a
Show file tree
Hide file tree
Showing 7 changed files with 252 additions and 4 deletions.
1 change: 0 additions & 1 deletion projects/angular/src/data/datagrid/_datagrid.clarity.scss
Expand Up @@ -656,7 +656,6 @@
flex-direction: column;
flex: 1 1 auto;
align-content: flex-start;
position: relative;

.datagrid-body {
width: auto;
Expand Down
3 changes: 0 additions & 3 deletions projects/angular/src/data/stack-view/_stack-view.clarity.scss
Expand Up @@ -78,9 +78,6 @@ $styledInputs: 'input[type=text], input[type=password], input[type=number], inpu
@include css-var(background-color, clr-stack-view-bg-color, $clr-stack-view-bg-color, $clr-use-custom-properties);
word-wrap: break-word;

/* this fixes the overflow problem of children elements in a wrapper with a border-radius in Chrome */
-webkit-mask-image: url();

dd,
dt {
// One of the caveats of using definition lists here. Browsers automatically style them in unpredictable ways... :(
Expand Down
5 changes: 5 additions & 0 deletions projects/demo/src/app/app.routing.ts
Expand Up @@ -74,6 +74,11 @@ export const APP_ROUTES: Routes = [
{ path: 'login', loadChildren: () => import('./login/login.demo.module').then(m => m.LoginDemoModule) },
{ path: 'modal', loadChildren: () => import('./modal/modal.demo.module').then(m => m.ModalDemoModule) },
{ path: 'navigation', loadChildren: () => import('./nav/nav.demo.module').then(m => m.NavDemoModule) },
{
path: 'overlay-clipping',
loadChildren: () =>
import('./overlay-clipping/overlay-clipping.demo.module').then(m => m.OverlayClippingDemoModule),
},
{
path: 'password',
loadChildren: () => import('./password/password.demo.module').then(m => m.PasswordDemoModule),
Expand Down
197 changes: 197 additions & 0 deletions projects/demo/src/app/overlay-clipping/overlay-clipping.demo.html
@@ -0,0 +1,197 @@
<h3>Component overlays visual tests</h3>
<p>(Signposts and tooltips should not get clipped by their containers)</p>

<h5>Datagrid</h5>
<clr-datagrid style="width: 300px">
<clr-dg-column>Name</clr-dg-column>

<clr-dg-row *clrDgItems="let user of [{name: 'Binky'}]">
<clr-dg-cell>
{{user.name}}
<ng-content *ngTemplateOutlet="signpostDemo"></ng-content>
</clr-dg-cell>
</clr-dg-row>

<clr-dg-footer></clr-dg-footer>
</clr-datagrid>

<h5>Modal</h5>
<clr-modal [(clrModalOpen)]="open" [clrModalSize]="'sm'">
<h3 class="modal-title">I have a nice title</h3>
<div class="modal-body">
<ng-content *ngTemplateOutlet="signpostDemo"></ng-content>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>.</p>
<p>long content for scrolling</p>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-outline" (click)="open = false">Cancel</button>
<button type="button" class="btn btn-primary" (click)="open = false">Ok</button>
</div>
</clr-modal>
<button type="button" class="btn btn-outline" (click)="open = true">Open modal</button>

<h5>Stack view</h5>

<clr-stack-view>
<clr-stack-block>
<clr-stack-label> Block 1 </clr-stack-label>
<clr-stack-content>Block content</clr-stack-content>
</clr-stack-block>
<clr-stack-block>
<clr-stack-label> Block 1 </clr-stack-label>
<clr-stack-content>
Block content
<ng-content *ngTemplateOutlet="signpostDemo"></ng-content>
</clr-stack-content>
</clr-stack-block>
</clr-stack-view>

<h5>Card</h5>

<div class="card">
<div class="card-block">
<h3 class="card-title">Card 1</h3>
<p class="card-text">
<ng-content *ngTemplateOutlet="signpostDemo"></ng-content>
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore
magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo
consequat.
</p>
</div>
<div class="card-footer">
<a href="javascript://" class="btn btn-sm btn-link">Action 1</a>
</div>
</div>

<h5>Accordion</h5>

<clr-accordion>
<clr-accordion-panel>
<clr-accordion-title>Step 1</clr-accordion-title>
<clr-accordion-content>
<ng-content *ngTemplateOutlet="signpostDemo"></ng-content>
Content 1
</clr-accordion-content>
</clr-accordion-panel>

<clr-accordion-panel>
<clr-accordion-title>Step 2</clr-accordion-title>
<clr-accordion-content>
Content 2
<ng-content *ngTemplateOutlet="signpostDemo"></ng-content>
</clr-accordion-content>
</clr-accordion-panel>
</clr-accordion>

<h5>Wizard</h5>

<button class="btn btn-primary" (click)="wizard.open()">Open Wizard</button>

<clr-wizard #wizard [(clrWizardOpen)]="wizOpen">
<clr-wizard-title>Wizard Title</clr-wizard-title>

<clr-wizard-button [type]="'cancel'">Cancel</clr-wizard-button>
<clr-wizard-button [type]="'previous'">Back</clr-wizard-button>
<clr-wizard-button [type]="'next'">Next</clr-wizard-button>
<clr-wizard-button [type]="'finish'">Finish</clr-wizard-button>

<clr-wizard-page>
<ng-template clrPageTitle>Title for page 1</ng-template>
<!-- mandatory -->
<ng-template clrPageNavTitle>Step 1</ng-template>
<!-- optional -->
<ng-content *ngTemplateOutlet="signpostDemo"></ng-content>
<p class="content-for-page-1">Content for step 1</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque eu odio nisi. Vestibulum dignissim eget massa sit
amet feugiat. Quisque auctor mattis quam eu suscipit. Morbi ipsum risus, feugiat vitae sem at, tincidunt elementum
magna. Phasellus tristique posuere dui, ut tempus felis sagittis quis. Integer iaculis ultrices elit, sed
venenatis eros. Vivamus interdum semper velit eget gravida. Sed finibus eget lacus sed semper. Suspendisse
fringilla, tellus in molestie cursus, sapien purus volutpat lacus, eget venenatis erat est vitae libero. Aliquam
et orci hendrerit, consequat purus non, imperdiet ipsum.
</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque eu odio nisi. Vestibulum dignissim eget massa sit
amet feugiat. Quisque auctor mattis quam eu suscipit. Morbi ipsum risus, feugiat vitae sem at, tincidunt elementum
magna. Phasellus tristique posuere dui, ut tempus felis sagittis quis. Integer iaculis ultrices elit, sed
venenatis eros. Vivamus interdum semper velit eget gravida. Sed finibus eget lacus sed semper. Suspendisse
fringilla, tellus in molestie cursus, sapien purus volutpat lacus, eget venenatis erat est vitae libero. Aliquam
et orci hendrerit, consequat purus non, imperdiet ipsum.
</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque eu odio nisi. Vestibulum dignissim eget massa sit
amet feugiat. Quisque auctor mattis quam eu suscipit. Morbi ipsum risus, feugiat vitae sem at, tincidunt elementum
magna. Phasellus tristique posuere dui, ut tempus felis sagittis quis. Integer iaculis ultrices elit, sed
venenatis eros. Vivamus interdum semper velit eget gravida. Sed finibus eget lacus sed semper. Suspendisse
fringilla, tellus in molestie cursus, sapien purus volutpat lacus, eget venenatis erat est vitae libero. Aliquam
et orci hendrerit, consequat purus non, imperdiet ipsum.
</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque eu odio nisi. Vestibulum dignissim eget massa sit
amet feugiat. Quisque auctor mattis quam eu suscipit. Morbi ipsum risus, feugiat vitae sem at, tincidunt elementum
magna. Phasellus tristique posuere dui, ut tempus felis sagittis quis. Integer iaculis ultrices elit, sed
venenatis eros. Vivamus interdum semper velit eget gravida. Sed finibus eget lacus sed semper. Suspendisse
fringilla, tellus in molestie cursus, sapien purus volutpat lacus, eget venenatis erat est vitae libero. Aliquam
et orci hendrerit, consequat purus non, imperdiet ipsum.
</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque eu odio nisi. Vestibulum dignissim eget massa sit
amet feugiat. Quisque auctor mattis quam eu suscipit. Morbi ipsum risus, feugiat vitae sem at, tincidunt elementum
magna. Phasellus tristique posuere dui, ut tempus felis sagittis quis. Integer iaculis ultrices elit, sed
venenatis eros. Vivamus interdum semper velit eget gravida. Sed finibus eget lacus sed semper. Suspendisse
fringilla, tellus in molestie cursus, sapien purus volutpat lacus, eget venenatis erat est vitae libero. Aliquam
et orci hendrerit, consequat purus non, imperdiet ipsum.
</p>
</clr-wizard-page>

<clr-wizard-page>
<ng-template clrPageTitle>Title for page 2</ng-template>
<!-- mandatory -->
<ng-template clrPageNavTitle>Step 2</ng-template>
<!-- optional -->
<p class="content-for-page-2">Content for step 2</p>
</clr-wizard-page>
</clr-wizard>

<ng-template #signpostDemo>
<clr-signpost>
<clr-signpost-content *clrIfOpen>
<h3>Default Signpost</h3>
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo
consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
</clr-signpost-content>
</clr-signpost>
<clr-tooltip>
<cds-icon
status="info"
title="Tooltip icon"
clrTooltipTrigger
shape="info-standard"
size="18"
aria-label="blank id string"
></cds-icon>
<clr-tooltip-content [id]="blankStringId" clrPosition="top-right" clrSize="md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo
consequat.
</clr-tooltip-content>
</clr-tooltip>
</ng-template>
@@ -0,0 +1,20 @@
/*
* Copyright (c) 2016-2022 VMware, Inc. All Rights Reserved.
* This software is released under MIT license.
* The full license information can be found in LICENSE in the root directory of this project.
*/

import { CommonModule } from '@angular/common';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { ClarityModule } from '@clr/angular';

import { OverlayClippingDemo } from './overlay-clipping.demo';
import { ROUTING } from './overlay-clipping.routing';

@NgModule({
imports: [CommonModule, FormsModule, ClarityModule, ROUTING],
declarations: [OverlayClippingDemo],
exports: [OverlayClippingDemo],
})
export class OverlayClippingDemoModule {}
16 changes: 16 additions & 0 deletions projects/demo/src/app/overlay-clipping/overlay-clipping.demo.ts
@@ -0,0 +1,16 @@
/*
* Copyright (c) 2016-2022 VMware, Inc. All Rights Reserved.
* This software is released under MIT license.
* The full license information can be found in LICENSE in the root directory of this project.
*/

import { Component } from '@angular/core';

@Component({
selector: 'overlay-clipping-demo',
templateUrl: './overlay-clipping.demo.html',
})
export class OverlayClippingDemo {
open = false;
wizOpen = false;
}
14 changes: 14 additions & 0 deletions projects/demo/src/app/overlay-clipping/overlay-clipping.routing.ts
@@ -0,0 +1,14 @@
/*
* Copyright (c) 2016-2022 VMware, Inc. All Rights Reserved.
* This software is released under MIT license.
* The full license information can be found in LICENSE in the root directory of this project.
*/

import { ModuleWithProviders } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';

import { OverlayClippingDemo } from './overlay-clipping.demo';

const ROUTES: Routes = [{ path: '', component: OverlayClippingDemo }];

export const ROUTING: ModuleWithProviders<RouterModule> = RouterModule.forChild(ROUTES);

0 comments on commit 5e38d6a

Please sign in to comment.