@3dsource/source-ui 0.0.1
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/LICENSE +14 -0
- package/README.md +31 -0
- package/fesm2022/3dsource-source-ui.mjs +402 -0
- package/fesm2022/3dsource-source-ui.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/source-modal/components/source-modal.component.d.ts +20 -0
- package/lib/components/source-modal/constants/sourceModalSize.const.d.ts +5 -0
- package/lib/components/source-modal/index.d.ts +3 -0
- package/lib/components/source-modal/interfaces/index.d.ts +1 -0
- package/lib/components/source-modal/interfaces/sourceModalData.interface.d.ts +20 -0
- package/lib/components/source-popover/components/source-popover-trigger.component.d.ts +30 -0
- package/lib/components/source-popover/components/source-popover.component.d.ts +12 -0
- package/lib/components/source-popover/index.d.ts +4 -0
- package/lib/components/source-popover/interfaces/defaultSourcePopover.config.d.ts +2 -0
- package/lib/components/source-popover/interfaces/index.d.ts +2 -0
- package/lib/components/source-popover/interfaces/sourcePopoverData.interface.d.ts +27 -0
- package/lib/components/source-popover/services/index.d.ts +1 -0
- package/lib/components/source-popover/services/sourcePopover.service.d.ts +19 -0
- package/lib/components/source-popover/tokens/sourcePopoverDataToken.d.ts +3 -0
- package/lib/components/source-tab-line/components/source-tab-line.component.d.ts +26 -0
- package/lib/components/source-tab-line/index.d.ts +1 -0
- package/lib/components/source-tabs/components/source-tab/source-tab.component.d.ts +6 -0
- package/lib/components/source-tabs/components/source-tabs/source-tabs.component.d.ts +19 -0
- package/lib/components/source-tabs/index.d.ts +3 -0
- package/lib/components/source-tabs/interfaces/index.d.ts +1 -0
- package/lib/components/source-tabs/interfaces/sourceTabData.interface.d.ts +6 -0
- package/lib/components/source-ui.component.d.ts +5 -0
- package/package.json +44 -0
- package/public-api.d.ts +5 -0
- package/styles/material/checkbox.scss +48 -0
- package/styles/material/form-field.scss +56 -0
- package/styles/material/radio.scss +37 -0
- package/styles/material/select.scss +97 -0
- package/styles/material/theme.scss +328 -0
- package/styles/material/toggle.scss +47 -0
- package/styles/source.ui.scss +11 -0
- package/styles/toastr/toastr.scss +79 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"3dsource-source-ui.mjs","sources":["../../../../projects/3dsource/source-ui/src/lib/components/source-ui.component.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-modal/constants/sourceModalSize.const.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-modal/components/source-modal.component.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-modal/components/source-modal.component.html","../../../../projects/3dsource/source-ui/src/lib/components/source-popover/tokens/sourcePopoverDataToken.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-popover/interfaces/defaultSourcePopover.config.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-popover/services/sourcePopover.service.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-popover/components/source-popover.component.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-popover/components/source-popover.component.html","../../../../projects/3dsource/source-ui/src/lib/components/source-popover/components/source-popover-trigger.component.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-popover/components/source-popover-trigger.component.html","../../../../projects/3dsource/source-ui/src/lib/components/source-tab-line/components/source-tab-line.component.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-tab-line/components/source-tab-line.component.html","../../../../projects/3dsource/source-ui/src/lib/components/source-tabs/components/source-tabs/source-tabs.component.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-tabs/components/source-tabs/source-tabs.component.html","../../../../projects/3dsource/source-ui/src/lib/components/source-tabs/components/source-tab/source-tab.component.ts","../../../../projects/3dsource/source-ui/src/lib/components/source-tabs/components/source-tab/source-tab.component.html","../../../../projects/3dsource/source-ui/src/3dsource-source-ui.ts"],"sourcesContent":["import { Component } from '@angular/core';\n\n@Component({\n selector: 'lib-source-ui',\n imports: [],\n template: ` <p>source-ui works!</p> `,\n styles: ``,\n})\nexport class SourceUiComponent {}\n","export const SourceModalSize = {\n SMALL: 'small',\n DEFAULT: 'default',\n};\nexport type SourceModalSizeKeys =\n (typeof SourceModalSize)[keyof typeof SourceModalSize];\n","import { DIALOG_DATA, DialogRef } from '@angular/cdk/dialog';\nimport {\n ChangeDetectionStrategy,\n Component,\n inject,\n OnInit,\n ViewEncapsulation,\n} from '@angular/core';\n\nimport { NgClass } from '@angular/common';\nimport {\n SourceModalSize,\n SourceModalSizeKeys,\n} from '../constants/sourceModalSize.const';\nimport {\n defaultSourceButtonConfig,\n SourceButton,\n SourceButtonComponent,\n SourceIconButtonComponent,\n} from '@3dsource/source-ui-native';\nimport { SourceModalData } from '../interfaces';\nimport { NgScrollbarModule } from 'ngx-scrollbar';\n\n@Component({\n selector: 'src-modal',\n templateUrl: './source-modal.component.html',\n styleUrls: ['./source-modal.component.scss'],\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [\n NgClass,\n SourceIconButtonComponent,\n NgScrollbarModule,\n SourceButtonComponent,\n ],\n})\nexport class SourceModalComponent implements OnInit {\n size: SourceModalSizeKeys = 'default';\n testID = 'modal';\n stringContent: string | null = null;\n readonly data: SourceModalData = inject(DIALOG_DATA);\n private readonly dialogRef = inject(DialogRef<SourceModalComponent>);\n defaultButtonConfig = defaultSourceButtonConfig;\n\n ngOnInit() {\n this.initModal();\n }\n\n close(result?: any) {\n this.dialogRef.close(result);\n }\n\n goBack() {\n this.dialogRef.close();\n }\n\n private initModal() {\n this.size = this.data?.size || SourceModalSize.DEFAULT;\n this.testID = this.data?.testID || this.testID;\n this.stringContent =\n typeof this.data.content === 'string' ? this.data.content : null;\n }\n\n getButtonConfig(\n externalConfig: Partial<SourceButton> | undefined,\n ): SourceButton {\n return {\n ...this.defaultButtonConfig,\n ...externalConfig,\n };\n }\n}\n","<div\n class=\"src-modal\"\n [attr.data-testid]=\"testID\"\n [ngClass]=\"{ 'src-modal--small': size === 'small' }\"\n>\n <div class=\"src-modal__header\">\n @if (data['backButton']) {\n <src-icon-button\n class=\"src-modal__back\"\n shape=\"round\"\n size=\"sm\"\n [data-testid]=\"testID + '-header-back'\"\n (onClick)=\"goBack()\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 -960 960 960\"\n fill=\"currentColor\"\n >\n <path\n d=\"m438-480 164 164q11 11 11 25.5T602-265q-11 11-25.5 11t-25.84-11.34L361-455q-5-5.4-7.5-11.7-2.5-6.3-2.5-13.5t2.5-13.5Q356-500 361-505l189.66-189.66Q562-706 576.5-706t25.5 11q11 11 11 25.5T602-644L438-480Z\"\n />\n </svg>\n </src-icon-button>\n }\n\n <div class=\"src-modal__title\" [attr.data-testid]=\"testID + '-header-title'\">\n {{ data['headerTitle'] }}\n </div>\n\n @if (data['closeButton']) {\n <src-icon-button\n class=\"src-modal__close\"\n shape=\"round\"\n size=\"sm\"\n [data-testid]=\"testID + '-header-close'\"\n (onClick)=\"close()\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M10.0001 11.229L6.68618 14.5429C6.51951 14.7096 6.31818 14.7896 6.08218 14.7829C5.84618 14.7756 5.64485 14.6886 5.47818 14.5219C5.31151 14.3553 5.22818 14.1506 5.22818 13.9079C5.22818 13.6646 5.31151 13.4596 5.47818 13.2929L8.77107 10L5.45718 6.68615C5.29051 6.51949 5.21051 6.31482 5.21718 6.07215C5.22451 5.82882 5.31151 5.62382 5.47818 5.45715C5.64485 5.29049 5.84951 5.20715 6.09218 5.20715C6.33551 5.20715 6.54051 5.29049 6.70718 5.45715L10.0001 8.77105L13.314 5.45715C13.4806 5.29049 13.6853 5.20715 13.928 5.20715C14.1713 5.20715 14.3763 5.29049 14.543 5.45715C14.7096 5.62382 14.793 5.82882 14.793 6.07215C14.793 6.31482 14.7096 6.51949 14.543 6.68615L11.2291 10L14.543 13.3139C14.7096 13.4806 14.793 13.6819 14.793 13.9179C14.793 14.1539 14.7096 14.3553 14.543 14.5219C14.3763 14.6886 14.1713 14.7719 13.928 14.7719C13.6853 14.7719 13.4806 14.6886 13.314 14.5219L10.0001 11.229Z\"\n fill=\"currentColor\"\n />\n </svg>\n </src-icon-button>\n }\n </div>\n\n <div\n class=\"src-modal__body\"\n [class.src-modal__body--scrollable]=\"scrollbar.isVerticallyScrollable()\"\n >\n <ng-scrollbar #scrollbar class=\"src-modal__scroll-box\">\n @if (stringContent; as content) {\n <div [innerHTML]=\"content\"></div>\n }\n </ng-scrollbar>\n </div>\n\n @if (data.footerButtons) {\n <div class=\"src-modal__footer\">\n @for (footerButton of data.footerButtons; track footerButton.label) {\n <src-button\n [srcButtonConfig]=\"getButtonConfig(footerButton.srcButtonConfig)\"\n [customClass]=\"footerButton.className\"\n (onClick)=\"close(footerButton.action())\"\n >\n {{ footerButton.label }}</src-button\n >\n }\n </div>\n }\n</div>\n","import { InjectionToken } from '@angular/core';\nimport type { SourcePopoverData } from '../interfaces/sourcePopoverData.interface';\n\nexport const SOURCE_POPOVER_DATA = new InjectionToken<SourcePopoverData>(\n 'SourcePopoverData',\n);\n","import type {\n HorizontalConnectionPos,\n VerticalConnectionPos,\n} from '@angular/cdk/overlay';\nimport type { SourcePopoverData } from './sourcePopoverData.interface';\n\nexport const defaultSourcePopoverConfig: SourcePopoverData = {\n headerTitle: undefined,\n backButton: false,\n closeButton: true,\n popoverMaxHeight: 'auto',\n panelCustomClass: '',\n breakpointDesktop: '(min-width: 1024px)',\n hasBackdrop: true,\n closeOnBackdropClick: true,\n position: [\n {\n originX: 'start' as HorizontalConnectionPos,\n originY: 'bottom' as VerticalConnectionPos,\n overlayX: 'start' as HorizontalConnectionPos,\n overlayY: 'top' as VerticalConnectionPos,\n offsetY: 4,\n },\n {\n originX: 'start' as HorizontalConnectionPos,\n originY: 'top' as VerticalConnectionPos,\n overlayX: 'start' as HorizontalConnectionPos,\n overlayY: 'bottom' as VerticalConnectionPos,\n offsetY: -8,\n },\n ],\n testID: '',\n};\n","import {\n DestroyRef,\n inject,\n Injectable,\n Injector,\n signal,\n ViewContainerRef,\n} from '@angular/core';\nimport type { SourcePopoverData } from '../interfaces';\nimport { defaultSourcePopoverConfig } from '../interfaces';\nimport {\n CdkOverlayOrigin,\n Overlay,\n OverlayConfig,\n OverlayRef,\n PositionStrategy,\n} from '@angular/cdk/overlay';\nimport { SOURCE_POPOVER_DATA } from '../tokens/sourcePopoverDataToken';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { SourcePopoverComponent } from '../components/source-popover.component';\nimport { Subject } from 'rxjs';\nimport { BreakpointObserver } from '@angular/cdk/layout';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Injectable()\nexport class SourcePopoverService {\n private readonly breakpointObserver = inject(BreakpointObserver);\n private readonly overlay = inject(Overlay);\n private readonly destroyRef$ = inject(DestroyRef);\n private readonly defaultSourcePopoverConfig = defaultSourcePopoverConfig;\n private readonly isMobile = signal(false);\n private readonly backButtonClickedSubject = new Subject<OverlayRef>();\n\n get backButtonClicked$() {\n return this.backButtonClickedSubject.asObservable();\n }\n\n show(\n overlayOrigin: CdkOverlayOrigin,\n viewContainerRef: ViewContainerRef,\n override: Partial<SourcePopoverData>,\n ): OverlayRef {\n const addedPanelClasses = ['src-popover-panel'];\n const backdropClasses = ['src-popover-backdrop'];\n const updatedConfig = this.getUpdatedConfig(override);\n\n if (updatedConfig.panelCustomClass) {\n addedPanelClasses.push(updatedConfig.panelCustomClass);\n }\n this.breakpointObserver\n .observe(updatedConfig.breakpointDesktop)\n .pipe(takeUntilDestroyed(this.destroyRef$))\n .subscribe((res) => this.isMobile.set(!res.matches));\n\n if (this.isMobile()) {\n addedPanelClasses.push('src-popover-panel--mobile');\n backdropClasses.push('src-popover-backdrop--mobile');\n }\n\n const dropdownPositionStrategy: PositionStrategy = this.overlay\n .position()\n .flexibleConnectedTo(overlayOrigin.elementRef)\n .withPositions(updatedConfig.position);\n\n // mobile position\n const drawerPositionStrategy: PositionStrategy = this.overlay\n .position()\n .global()\n .centerHorizontally()\n .bottom('0px');\n\n // close popover when scrolls\n const scrollStrategy = this.overlay.scrollStrategies.reposition();\n\n const config = new OverlayConfig({\n panelClass: addedPanelClasses,\n hasBackdrop: updatedConfig.hasBackdrop,\n backdropClass: backdropClasses,\n positionStrategy: this.isMobile()\n ? drawerPositionStrategy\n : dropdownPositionStrategy,\n scrollStrategy: scrollStrategy,\n width: this.isMobile() ? '100%' : 'auto',\n });\n\n const overlayRef: OverlayRef = this.overlay.create(config);\n const data: SourcePopoverData = {\n ...updatedConfig,\n overlayRef,\n };\n const injector = Injector.create({\n parent: viewContainerRef.injector,\n providers: [{ provide: SOURCE_POPOVER_DATA, useValue: data }],\n });\n const template = new ComponentPortal(\n SourcePopoverComponent,\n viewContainerRef,\n injector,\n );\n overlayRef.attach(template);\n return overlayRef;\n }\n\n closePopover(overlayRef: OverlayRef) {\n overlayRef.dispose();\n }\n\n emitBackAction(menuRef: OverlayRef) {\n this.backButtonClickedSubject.next(menuRef);\n }\n\n getUpdatedConfig(override: Partial<SourcePopoverData>): SourcePopoverData {\n return {\n srcPopoverTpl: override?.srcPopoverTpl,\n headerTitle:\n override?.headerTitle ?? this.defaultSourcePopoverConfig.headerTitle,\n hasBackButton:\n override?.hasBackButton ??\n this.defaultSourcePopoverConfig.hasBackButton,\n hasCloseButton:\n override?.hasCloseButton ??\n this.defaultSourcePopoverConfig.hasCloseButton,\n popoverMaxHeight:\n override?.popoverMaxHeight ??\n this.defaultSourcePopoverConfig.popoverMaxHeight,\n panelCustomClass:\n override?.panelCustomClass ??\n this.defaultSourcePopoverConfig.panelCustomClass,\n breakpointDesktop:\n override?.breakpointDesktop ??\n this.defaultSourcePopoverConfig.breakpointDesktop,\n position: override?.position\n ? override?.position\n : this.defaultSourcePopoverConfig.position,\n closeOnBackdropClick:\n override?.closeOnBackdropClick ??\n this.defaultSourcePopoverConfig.closeOnBackdropClick,\n hasBackdrop:\n override?.hasBackdrop ?? this.defaultSourcePopoverConfig.hasBackdrop,\n testID: override?.testID ?? this.defaultSourcePopoverConfig.testID,\n };\n }\n}\n","import {\n ChangeDetectionStrategy,\n Component,\n inject,\n signal,\n TemplateRef,\n ViewEncapsulation,\n} from '@angular/core';\nimport { SOURCE_POPOVER_DATA } from '../tokens/sourcePopoverDataToken';\nimport { SourcePopoverService } from '../services';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { SourceIconButtonComponent } from '@3dsource/source-ui-native';\n\n@Component({\n selector: 'src-popover',\n templateUrl: './source-popover.component.html',\n styleUrls: ['./source-popover.component.scss'],\n imports: [SourceIconButtonComponent, NgTemplateOutlet],\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SourcePopoverComponent {\n readonly data = inject(SOURCE_POPOVER_DATA);\n template = signal(\n this.data.srcPopoverTpl instanceof TemplateRef\n ? this.data.srcPopoverTpl\n : null,\n );\n testID = signal(this.data.testID || 'popover');\n #sourcePopoverService = inject(SourcePopoverService);\n\n close() {\n this.#sourcePopoverService.closePopover(this.data.overlayRef!);\n }\n\n emitBackAction() {\n this.#sourcePopoverService.emitBackAction(this.data.overlayRef!);\n }\n}\n","<div\n class=\"src-popover\"\n [style.maxHeight]=\"data.popoverMaxHeight\"\n [attr.data-testid]=\"testID()\"\n>\n @if (\n data['hasBackButton'] ||\n data['hasCloseButton'] ||\n (data['headerTitle'] && data['headerTitle'] !== '')\n ) {\n <div class=\"src-popover__header\">\n @if (data['hasBackButton']) {\n <src-icon-button\n class=\"src-popover__back\"\n shape=\"round\"\n size=\"sm\"\n [data-testid]=\"testID() + '-header-back'\"\n (onClick)=\"emitBackAction()\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 -960 960 960\"\n fill=\"currentColor\"\n >\n <path\n d=\"m438-480 164 164q11 11 11 25.5T602-265q-11 11-25.5 11t-25.84-11.34L361-455q-5-5.4-7.5-11.7-2.5-6.3-2.5-13.5t2.5-13.5Q356-500 361-505l189.66-189.66Q562-706 576.5-706t25.5 11q11 11 11 25.5T602-644L438-480Z\"\n />\n </svg>\n </src-icon-button>\n }\n\n <div\n class=\"src-popover__title\"\n [attr.data-testid]=\"testID() + '-header-title'\"\n >\n {{ data.headerTitle }}\n </div>\n\n @if (data['hasCloseButton']) {\n <src-icon-button\n class=\"src-popover__close\"\n shape=\"round\"\n size=\"sm\"\n [data-testid]=\"testID() + '-header-close'\"\n (click)=\"close()\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n >\n <path\n d=\"M10.0001 11.229L6.68618 14.5429C6.51951 14.7096 6.31818 14.7896 6.08218 14.7829C5.84618 14.7756 5.64485 14.6886 5.47818 14.5219C5.31151 14.3553 5.22818 14.1506 5.22818 13.9079C5.22818 13.6646 5.31151 13.4596 5.47818 13.2929L8.77107 10L5.45718 6.68615C5.29051 6.51949 5.21051 6.31482 5.21718 6.07215C5.22451 5.82882 5.31151 5.62382 5.47818 5.45715C5.64485 5.29049 5.84951 5.20715 6.09218 5.20715C6.33551 5.20715 6.54051 5.29049 6.70718 5.45715L10.0001 8.77105L13.314 5.45715C13.4806 5.29049 13.6853 5.20715 13.928 5.20715C14.1713 5.20715 14.3763 5.29049 14.543 5.45715C14.7096 5.62382 14.793 5.82882 14.793 6.07215C14.793 6.31482 14.7096 6.51949 14.543 6.68615L11.2291 10L14.543 13.3139C14.7096 13.4806 14.793 13.6819 14.793 13.9179C14.793 14.1539 14.7096 14.3553 14.543 14.5219C14.3763 14.6886 14.1713 14.7719 13.928 14.7719C13.6853 14.7719 13.4806 14.6886 13.314 14.5219L10.0001 11.229Z\"\n fill=\"currentColor\"\n />\n </svg>\n </src-icon-button>\n }\n </div>\n }\n\n <div class=\"src-popover__body\">\n @if (template()) {\n <ng-template [ngTemplateOutlet]=\"template()\"></ng-template>\n }\n </div>\n</div>\n","import {\n ChangeDetectionStrategy,\n Component,\n DestroyRef,\n inject,\n input,\n OnInit,\n output,\n signal,\n TemplateRef,\n ViewChild,\n ViewContainerRef,\n ViewEncapsulation,\n} from '@angular/core';\nimport {\n CdkOverlayOrigin,\n ConnectedPosition,\n OverlayRef,\n} from '@angular/cdk/overlay';\nimport type { SourcePopoverData } from '../interfaces';\nimport { SourcePopoverService } from '../services';\nimport { take } from 'rxjs/operators';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n selector: 'src-popover-trigger',\n templateUrl: './source-popover-trigger.component.html',\n encapsulation: ViewEncapsulation.None,\n providers: [SourcePopoverService],\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [CdkOverlayOrigin],\n})\nexport class SourcePopoverTriggerComponent implements OnInit {\n srcPopoverTpl = input.required<TemplateRef<HTMLElement>>();\n headerTitle = input<string>();\n activeClass = input<string>();\n hasBackButton = input(false);\n hasCloseButton = input(true);\n hasBackdrop = input(true);\n closeOnBackdropClick = input(true);\n popoverMaxHeight = input('auto');\n panelCustomClass = input<string>();\n testID = input('', { alias: 'data-testid' });\n breakpointDesktop = input('(min-width: 1024px)');\n positions = input<ConnectedPosition[]>([\n {\n originX: 'start',\n originY: 'bottom',\n overlayX: 'start',\n overlayY: 'top',\n offsetY: 4,\n },\n {\n originX: 'start',\n originY: 'top',\n overlayX: 'start',\n overlayY: 'bottom',\n offsetY: -8,\n },\n ]);\n\n @ViewChild(CdkOverlayOrigin) overlayOrigin!: CdkOverlayOrigin;\n popoverShown = signal(false);\n onPopoverShown = output<boolean>();\n onBackButtonClick = output<OverlayRef>();\n overlayRef: OverlayRef | null = null;\n readonly sourcePopoverService = inject(SourcePopoverService, { self: true });\n private readonly viewContainerRef = inject(ViewContainerRef);\n private readonly destroyRef = inject(DestroyRef);\n\n ngOnInit() {\n this.sourcePopoverService.backButtonClicked$\n .pipe(takeUntilDestroyed(this.destroyRef))\n .subscribe(() => {\n this.onBackButtonClick.emit(this.overlayRef!);\n });\n }\n\n showPopover() {\n const config: Partial<SourcePopoverData> = {\n srcPopoverTpl: this.srcPopoverTpl(),\n overlayOrigin: this.overlayOrigin,\n headerTitle: this.headerTitle(),\n hasBackButton: this.hasBackButton(),\n hasCloseButton: this.hasCloseButton(),\n popoverMaxHeight: this.popoverMaxHeight(),\n panelCustomClass: this.panelCustomClass(),\n breakpointDesktop: this.breakpointDesktop(),\n position: this.positions(),\n hasBackdrop: this.hasBackdrop(),\n closeOnBackdropClick: this.closeOnBackdropClick(),\n testID: this.testID(),\n };\n\n this.overlayRef = this.sourcePopoverService.show(\n this.overlayOrigin,\n this.viewContainerRef,\n config,\n );\n\n this.popoverShown.set(true);\n this.onPopoverShown.emit(true);\n\n this.overlayRef\n .detachments()\n .pipe(take(1))\n .subscribe(() => {\n this.popoverShown.set(false);\n this.onPopoverShown.emit(false);\n this.overlayRef = null;\n });\n\n this.overlayRef\n .backdropClick()\n .pipe(take(1))\n .subscribe(() => this.overlayRef?.detach());\n }\n}\n","<div\n cdkOverlayOrigin\n [attr.data-testid]=\"testID()\"\n (click)=\"showPopover()\"\n [class]=\"popoverShown() ? activeClass() || 'active' : ''\"\n>\n <ng-content></ng-content>\n</div>\n","import {\n ChangeDetectionStrategy,\n Component,\n computed,\n CUSTOM_ELEMENTS_SCHEMA,\n effect,\n ElementRef,\n input,\n linkedSignal,\n output,\n untracked,\n viewChild,\n ViewEncapsulation,\n} from '@angular/core';\nimport { register } from 'swiper/element/bundle';\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\n\nregister();\n\n@Component({\n selector: 'src-tab-line',\n templateUrl: './source-tab-line.component.html',\n styleUrls: ['./source-tab-line.component.scss'],\n imports: [NgClass, NgTemplateOutlet],\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class SourceTabLineComponent {\n swiperRef = viewChild<ElementRef>('swiperRef');\n tabs = input.required<any[]>();\n\n label = input.required<string>();\n selectedIndex = input(0);\n isCompact = input(false);\n offsetBefore = input(0);\n offsetAfter = input(0);\n spaceBetween = input(0);\n isFullWidth = input(false);\n isSwiper = input(false);\n testID = input('', { alias: 'data-testid' });\n tabsSelectedIndex = linkedSignal(() => this.selectedIndex());\n onSelectTab = output<number>();\n\n classes = computed(() =>\n this.isFullWidth() ? ['src-tab-line--full-width'] : [],\n );\n variables = computed(\n () =>\n `--srcTabsOffsetBefore: ${this.tabsOffsetBefore()}px; --srcTabsOffsetAfter: ${this.tabsOffsetAfter()}px; --srcTabsSpaceBetween: ${this.spacing()}px;`,\n );\n tabsOffsetBefore = computed(\n () => this.offsetBefore() || (this.isCompact() ? 8 : 16),\n );\n tabsOffsetAfter = computed(\n () => this.offsetAfter() || (this.isCompact() ? 8 : 16),\n );\n spacing = computed(() => this.spaceBetween() || (this.isCompact() ? 0 : 4));\n\n _ = effect(() => {\n const swiperRef = this.swiperRef();\n untracked(() => {\n if (!swiperRef?.nativeElement || !this.isSwiper()) return;\n Object.assign(swiperRef.nativeElement, {\n spaceBetween: this.spacing(),\n slidesOffsetBefore: this.tabsOffsetBefore(),\n slidesOffsetAfter: this.tabsOffsetAfter(),\n slidesPerView: 'auto',\n centeredSlides: false,\n slideToClickedSlide: true,\n });\n swiperRef.nativeElement.initialize();\n });\n });\n\n selectTab(tabIndex: number) {\n this.tabsSelectedIndex.set(tabIndex);\n this.onSelectTab.emit(tabIndex);\n }\n}\n","<div class=\"src-tab-line\" [ngClass]=\"classes()\" [attr.data-testid]=\"testID()\">\n @if (isSwiper()) {\n <div class=\"src-tabs__nav src-tabs__nav--swiper\">\n <swiper-container #swiperRef init=\"false\">\n @for (tab of tabs(); track tab) {\n <swiper-slide\n class=\"src-tabs__nav-slide\"\n [attr.data-testid]=\"testID() + '-slide-' + $index\"\n >\n <ng-container\n [ngTemplateOutlet]=\"slideTemplate\"\n [ngTemplateOutletContext]=\"{ tab: tab, index: $index }\"\n >\n </ng-container>\n </swiper-slide>\n }\n </swiper-container>\n </div>\n } @else {\n <div class=\"src-tabs__nav\" [style]=\"variables()\">\n @for (tab of tabs(); track tab) {\n <div\n class=\"src-tabs__nav-slide\"\n [attr.data-testid]=\"testID() + '-slide-' + $index\"\n >\n <ng-container\n [ngTemplateOutlet]=\"slideTemplate\"\n [ngTemplateOutletContext]=\"{ tab: tab, index: $index }\"\n >\n </ng-container>\n </div>\n }\n </div>\n }\n</div>\n\n<ng-template #slideTemplate let-tab=\"tab\" let-i=\"index\">\n <div\n class=\"src-tabs__nav-item\"\n (click)=\"selectTab(i)\"\n [class.src-tabs__nav-item--active]=\"i === tabsSelectedIndex()\"\n [class.src-disabled]=\"tab.isDisabled\"\n >\n <div class=\"text-label\" [attr.data-testid]=\"testID() + '-tab-label-' + i\">\n {{ tab[label()] }}\n </div>\n </div>\n</ng-template>\n","import {\n ChangeDetectionStrategy,\n Component,\n input,\n output,\n TemplateRef,\n ViewEncapsulation,\n} from '@angular/core';\nimport type { SourceTabData } from '../../interfaces';\n\nimport { NgTemplateOutlet } from '@angular/common';\nimport type { SwiperOptions } from 'swiper/types';\nimport { SourceTabLineComponent } from '../../../source-tab-line';\n\n@Component({\n selector: 'src-tabs',\n templateUrl: './source-tabs.component.html',\n imports: [NgTemplateOutlet, SourceTabLineComponent],\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SourceTabsComponent {\n label = input.required<string>();\n data = input.required<SourceTabData[]>();\n selectedIndex = input(0);\n headerTemplate = input<TemplateRef<any>>();\n isCompact = input(false);\n isFullWidth = input(false);\n isSwiper = input(false);\n swiperConfig = input<SwiperOptions>();\n testID = input('', { alias: 'data-testid' });\n onSelectTab = output<number>();\n\n setActive(idx: number) {\n this.onSelectTab.emit(idx);\n }\n}\n","<div class=\"src-tabs\">\n <ng-template #defaultTabsHeader>\n <src-tab-line\n [tabs]=\"data()\"\n [label]=\"label()\"\n [isCompact]=\"isCompact()\"\n [isFullWidth]=\"isFullWidth()\"\n [selectedIndex]=\"selectedIndex()\"\n [isSwiper]=\"isSwiper()\"\n [data-testid]=\"testID()\"\n (onSelectTab)=\"setActive($event)\"\n ></src-tab-line>\n </ng-template>\n\n <ng-container\n *ngTemplateOutlet=\"\n headerTemplate() ? headerTemplate()! : defaultTabsHeader;\n context: { tabs: this.data }\n \"\n >\n </ng-container>\n\n <ng-content></ng-content>\n</div>\n","import {\n ChangeDetectionStrategy,\n Component,\n input,\n ViewEncapsulation,\n} from '@angular/core';\n\n@Component({\n selector: 'src-tab',\n templateUrl: './source-tab.component.html',\n styleUrls: ['./source-tab.component.scss'],\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SourceTabComponent {\n isActive = input(false);\n}\n","<div [hidden]=\"!isActive()\" class=\"src-tab-content\">\n <ng-content></ng-content>\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
package/index.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { SourceModalSizeKeys } from '../constants/sourceModalSize.const';
|
|
3
|
+
import { SourceButton } from '@3dsource/source-ui-native';
|
|
4
|
+
import { SourceModalData } from '../interfaces';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export declare class SourceModalComponent implements OnInit {
|
|
7
|
+
size: SourceModalSizeKeys;
|
|
8
|
+
testID: string;
|
|
9
|
+
stringContent: string | null;
|
|
10
|
+
readonly data: SourceModalData;
|
|
11
|
+
private readonly dialogRef;
|
|
12
|
+
defaultButtonConfig: SourceButton;
|
|
13
|
+
ngOnInit(): void;
|
|
14
|
+
close(result?: any): void;
|
|
15
|
+
goBack(): void;
|
|
16
|
+
private initModal;
|
|
17
|
+
getButtonConfig(externalConfig: Partial<SourceButton> | undefined): SourceButton;
|
|
18
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SourceModalComponent, never>;
|
|
19
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SourceModalComponent, "src-modal", never, {}, {}, never, never, true, never>;
|
|
20
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './sourceModalData.interface';
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { SourceModalSizeKeys } from '../constants/sourceModalSize.const';
|
|
2
|
+
import { SourceButton } from '@3dsource/source-ui-native';
|
|
3
|
+
export interface SourceModalData {
|
|
4
|
+
headerTitle?: string;
|
|
5
|
+
size?: SourceModalSizeKeys;
|
|
6
|
+
backButton?: boolean;
|
|
7
|
+
closeButton?: boolean;
|
|
8
|
+
content?: string;
|
|
9
|
+
componentData?: unknown;
|
|
10
|
+
footerButtons?: DialogButtonsData;
|
|
11
|
+
testID?: string;
|
|
12
|
+
[key: string]: unknown;
|
|
13
|
+
}
|
|
14
|
+
export interface DialogButtonData {
|
|
15
|
+
className?: string | string[];
|
|
16
|
+
label: string;
|
|
17
|
+
srcButtonConfig?: Partial<SourceButton>;
|
|
18
|
+
action: (...data: any) => any;
|
|
19
|
+
}
|
|
20
|
+
export type DialogButtonsData = DialogButtonData[];
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { OnInit, TemplateRef } from '@angular/core';
|
|
2
|
+
import { CdkOverlayOrigin, ConnectedPosition, OverlayRef } from '@angular/cdk/overlay';
|
|
3
|
+
import { SourcePopoverService } from '../services';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class SourcePopoverTriggerComponent implements OnInit {
|
|
6
|
+
srcPopoverTpl: import("@angular/core").InputSignal<TemplateRef<HTMLElement>>;
|
|
7
|
+
headerTitle: import("@angular/core").InputSignal<string | undefined>;
|
|
8
|
+
activeClass: import("@angular/core").InputSignal<string | undefined>;
|
|
9
|
+
hasBackButton: import("@angular/core").InputSignal<boolean>;
|
|
10
|
+
hasCloseButton: import("@angular/core").InputSignal<boolean>;
|
|
11
|
+
hasBackdrop: import("@angular/core").InputSignal<boolean>;
|
|
12
|
+
closeOnBackdropClick: import("@angular/core").InputSignal<boolean>;
|
|
13
|
+
popoverMaxHeight: import("@angular/core").InputSignal<string>;
|
|
14
|
+
panelCustomClass: import("@angular/core").InputSignal<string | undefined>;
|
|
15
|
+
testID: import("@angular/core").InputSignal<string>;
|
|
16
|
+
breakpointDesktop: import("@angular/core").InputSignal<string>;
|
|
17
|
+
positions: import("@angular/core").InputSignal<ConnectedPosition[]>;
|
|
18
|
+
overlayOrigin: CdkOverlayOrigin;
|
|
19
|
+
popoverShown: import("@angular/core").WritableSignal<boolean>;
|
|
20
|
+
onPopoverShown: import("@angular/core").OutputEmitterRef<boolean>;
|
|
21
|
+
onBackButtonClick: import("@angular/core").OutputEmitterRef<OverlayRef>;
|
|
22
|
+
overlayRef: OverlayRef | null;
|
|
23
|
+
readonly sourcePopoverService: SourcePopoverService;
|
|
24
|
+
private readonly viewContainerRef;
|
|
25
|
+
private readonly destroyRef;
|
|
26
|
+
ngOnInit(): void;
|
|
27
|
+
showPopover(): void;
|
|
28
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SourcePopoverTriggerComponent, never>;
|
|
29
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SourcePopoverTriggerComponent, "src-popover-trigger", never, { "srcPopoverTpl": { "alias": "srcPopoverTpl"; "required": true; "isSignal": true; }; "headerTitle": { "alias": "headerTitle"; "required": false; "isSignal": true; }; "activeClass": { "alias": "activeClass"; "required": false; "isSignal": true; }; "hasBackButton": { "alias": "hasBackButton"; "required": false; "isSignal": true; }; "hasCloseButton": { "alias": "hasCloseButton"; "required": false; "isSignal": true; }; "hasBackdrop": { "alias": "hasBackdrop"; "required": false; "isSignal": true; }; "closeOnBackdropClick": { "alias": "closeOnBackdropClick"; "required": false; "isSignal": true; }; "popoverMaxHeight": { "alias": "popoverMaxHeight"; "required": false; "isSignal": true; }; "panelCustomClass": { "alias": "panelCustomClass"; "required": false; "isSignal": true; }; "testID": { "alias": "data-testid"; "required": false; "isSignal": true; }; "breakpointDesktop": { "alias": "breakpointDesktop"; "required": false; "isSignal": true; }; "positions": { "alias": "positions"; "required": false; "isSignal": true; }; }, { "onPopoverShown": "onPopoverShown"; "onBackButtonClick": "onBackButtonClick"; }, never, ["*"], true, never>;
|
|
30
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class SourcePopoverComponent {
|
|
4
|
+
#private;
|
|
5
|
+
readonly data: import("@3dsource/source-ui").SourcePopoverData;
|
|
6
|
+
template: import("@angular/core").WritableSignal<TemplateRef<HTMLElement> | null>;
|
|
7
|
+
testID: import("@angular/core").WritableSignal<string>;
|
|
8
|
+
close(): void;
|
|
9
|
+
emitBackAction(): void;
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SourcePopoverComponent, never>;
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SourcePopoverComponent, "src-popover", never, {}, {}, never, never, true, never>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { ConnectedPosition, HorizontalConnectionPos, VerticalConnectionPos } from '@angular/cdk/overlay';
|
|
2
|
+
import { OverlayRef } from '@angular/cdk/overlay';
|
|
3
|
+
import { TemplateRef } from '@angular/core';
|
|
4
|
+
export interface SourcePopoverData {
|
|
5
|
+
srcPopoverTpl?: TemplateRef<HTMLElement>;
|
|
6
|
+
headerTitle?: string;
|
|
7
|
+
hasBackButton?: boolean;
|
|
8
|
+
hasCloseButton?: boolean;
|
|
9
|
+
popoverMaxHeight?: string;
|
|
10
|
+
panelCustomClass: string;
|
|
11
|
+
breakpointDesktop: string;
|
|
12
|
+
position: ConnectedPosition[] | {
|
|
13
|
+
originX: HorizontalConnectionPos;
|
|
14
|
+
originY: VerticalConnectionPos;
|
|
15
|
+
overlayX: HorizontalConnectionPos;
|
|
16
|
+
overlayY: VerticalConnectionPos;
|
|
17
|
+
offsetY?: number;
|
|
18
|
+
offsetX?: number;
|
|
19
|
+
panelClass?: string | string[];
|
|
20
|
+
weight?: number;
|
|
21
|
+
}[];
|
|
22
|
+
hasBackdrop: boolean;
|
|
23
|
+
closeOnBackdropClick: boolean;
|
|
24
|
+
overlayRef?: OverlayRef;
|
|
25
|
+
testID?: string;
|
|
26
|
+
[key: string]: any;
|
|
27
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './sourcePopover.service';
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ViewContainerRef } from '@angular/core';
|
|
2
|
+
import type { SourcePopoverData } from '../interfaces';
|
|
3
|
+
import { CdkOverlayOrigin, OverlayRef } from '@angular/cdk/overlay';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class SourcePopoverService {
|
|
6
|
+
private readonly breakpointObserver;
|
|
7
|
+
private readonly overlay;
|
|
8
|
+
private readonly destroyRef$;
|
|
9
|
+
private readonly defaultSourcePopoverConfig;
|
|
10
|
+
private readonly isMobile;
|
|
11
|
+
private readonly backButtonClickedSubject;
|
|
12
|
+
get backButtonClicked$(): import("rxjs").Observable<OverlayRef>;
|
|
13
|
+
show(overlayOrigin: CdkOverlayOrigin, viewContainerRef: ViewContainerRef, override: Partial<SourcePopoverData>): OverlayRef;
|
|
14
|
+
closePopover(overlayRef: OverlayRef): void;
|
|
15
|
+
emitBackAction(menuRef: OverlayRef): void;
|
|
16
|
+
getUpdatedConfig(override: Partial<SourcePopoverData>): SourcePopoverData;
|
|
17
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SourcePopoverService, never>;
|
|
18
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<SourcePopoverService>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ElementRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class SourceTabLineComponent {
|
|
4
|
+
swiperRef: import("@angular/core").Signal<ElementRef<any> | undefined>;
|
|
5
|
+
tabs: import("@angular/core").InputSignal<any[]>;
|
|
6
|
+
label: import("@angular/core").InputSignal<string>;
|
|
7
|
+
selectedIndex: import("@angular/core").InputSignal<number>;
|
|
8
|
+
isCompact: import("@angular/core").InputSignal<boolean>;
|
|
9
|
+
offsetBefore: import("@angular/core").InputSignal<number>;
|
|
10
|
+
offsetAfter: import("@angular/core").InputSignal<number>;
|
|
11
|
+
spaceBetween: import("@angular/core").InputSignal<number>;
|
|
12
|
+
isFullWidth: import("@angular/core").InputSignal<boolean>;
|
|
13
|
+
isSwiper: import("@angular/core").InputSignal<boolean>;
|
|
14
|
+
testID: import("@angular/core").InputSignal<string>;
|
|
15
|
+
tabsSelectedIndex: import("@angular/core").WritableSignal<number>;
|
|
16
|
+
onSelectTab: import("@angular/core").OutputEmitterRef<number>;
|
|
17
|
+
classes: import("@angular/core").Signal<string[]>;
|
|
18
|
+
variables: import("@angular/core").Signal<string>;
|
|
19
|
+
tabsOffsetBefore: import("@angular/core").Signal<number>;
|
|
20
|
+
tabsOffsetAfter: import("@angular/core").Signal<number>;
|
|
21
|
+
spacing: import("@angular/core").Signal<number>;
|
|
22
|
+
_: import("@angular/core").EffectRef;
|
|
23
|
+
selectTab(tabIndex: number): void;
|
|
24
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SourceTabLineComponent, never>;
|
|
25
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SourceTabLineComponent, "src-tab-line", never, { "tabs": { "alias": "tabs"; "required": true; "isSignal": true; }; "label": { "alias": "label"; "required": true; "isSignal": true; }; "selectedIndex": { "alias": "selectedIndex"; "required": false; "isSignal": true; }; "isCompact": { "alias": "isCompact"; "required": false; "isSignal": true; }; "offsetBefore": { "alias": "offsetBefore"; "required": false; "isSignal": true; }; "offsetAfter": { "alias": "offsetAfter"; "required": false; "isSignal": true; }; "spaceBetween": { "alias": "spaceBetween"; "required": false; "isSignal": true; }; "isFullWidth": { "alias": "isFullWidth"; "required": false; "isSignal": true; }; "isSwiper": { "alias": "isSwiper"; "required": false; "isSignal": true; }; "testID": { "alias": "data-testid"; "required": false; "isSignal": true; }; }, { "onSelectTab": "onSelectTab"; }, never, never, true, never>;
|
|
26
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './components/source-tab-line.component';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class SourceTabComponent {
|
|
3
|
+
isActive: import("@angular/core").InputSignal<boolean>;
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SourceTabComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SourceTabComponent, "src-tab", never, { "isActive": { "alias": "isActive"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, never>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { TemplateRef } from '@angular/core';
|
|
2
|
+
import type { SourceTabData } from '../../interfaces';
|
|
3
|
+
import type { SwiperOptions } from 'swiper/types';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class SourceTabsComponent {
|
|
6
|
+
label: import("@angular/core").InputSignal<string>;
|
|
7
|
+
data: import("@angular/core").InputSignal<SourceTabData[]>;
|
|
8
|
+
selectedIndex: import("@angular/core").InputSignal<number>;
|
|
9
|
+
headerTemplate: import("@angular/core").InputSignal<TemplateRef<any> | undefined>;
|
|
10
|
+
isCompact: import("@angular/core").InputSignal<boolean>;
|
|
11
|
+
isFullWidth: import("@angular/core").InputSignal<boolean>;
|
|
12
|
+
isSwiper: import("@angular/core").InputSignal<boolean>;
|
|
13
|
+
swiperConfig: import("@angular/core").InputSignal<SwiperOptions | undefined>;
|
|
14
|
+
testID: import("@angular/core").InputSignal<string>;
|
|
15
|
+
onSelectTab: import("@angular/core").OutputEmitterRef<number>;
|
|
16
|
+
setActive(idx: number): void;
|
|
17
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SourceTabsComponent, never>;
|
|
18
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SourceTabsComponent, "src-tabs", never, { "label": { "alias": "label"; "required": true; "isSignal": true; }; "data": { "alias": "data"; "required": true; "isSignal": true; }; "selectedIndex": { "alias": "selectedIndex"; "required": false; "isSignal": true; }; "headerTemplate": { "alias": "headerTemplate"; "required": false; "isSignal": true; }; "isCompact": { "alias": "isCompact"; "required": false; "isSignal": true; }; "isFullWidth": { "alias": "isFullWidth"; "required": false; "isSignal": true; }; "isSwiper": { "alias": "isSwiper"; "required": false; "isSignal": true; }; "swiperConfig": { "alias": "swiperConfig"; "required": false; "isSignal": true; }; "testID": { "alias": "data-testid"; "required": false; "isSignal": true; }; }, { "onSelectTab": "onSelectTab"; }, never, ["*"], true, never>;
|
|
19
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './sourceTabData.interface';
|
package/package.json
ADDED
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@3dsource/source-ui",
|
|
3
|
+
"version": "0.0.1",
|
|
4
|
+
"description": "A bunch of native ui elements with angular",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"3dsource",
|
|
7
|
+
"elements",
|
|
8
|
+
"ui",
|
|
9
|
+
"angular",
|
|
10
|
+
"angular cdk"
|
|
11
|
+
],
|
|
12
|
+
"repository": {
|
|
13
|
+
"type": "git",
|
|
14
|
+
"url": "private"
|
|
15
|
+
},
|
|
16
|
+
"license": "UNLICENSED",
|
|
17
|
+
"author": "3dsource",
|
|
18
|
+
"sideEffects": false,
|
|
19
|
+
"dependencies": {
|
|
20
|
+
"tslib": "^2.8.1"
|
|
21
|
+
},
|
|
22
|
+
"peerDependencies": {
|
|
23
|
+
"@angular/common": "^19.2.0",
|
|
24
|
+
"@angular/core": "^19.2.0",
|
|
25
|
+
"@angular/material": "19.2.11",
|
|
26
|
+
"ngx-scrollbar": "18.0.0",
|
|
27
|
+
"swiper": "11.2.6"
|
|
28
|
+
},
|
|
29
|
+
"engines": {
|
|
30
|
+
"node": ">=20",
|
|
31
|
+
"npm": ">9"
|
|
32
|
+
},
|
|
33
|
+
"module": "fesm2022/3dsource-source-ui.mjs",
|
|
34
|
+
"typings": "index.d.ts",
|
|
35
|
+
"exports": {
|
|
36
|
+
"./package.json": {
|
|
37
|
+
"default": "./package.json"
|
|
38
|
+
},
|
|
39
|
+
".": {
|
|
40
|
+
"types": "./index.d.ts",
|
|
41
|
+
"default": "./fesm2022/3dsource-source-ui.mjs"
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
package/public-api.d.ts
ADDED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
@use '@angular/material' as mat;
|
|
2
|
+
:root {
|
|
3
|
+
@include mat.checkbox-overrides(
|
|
4
|
+
(
|
|
5
|
+
state-layer-size: 20px,
|
|
6
|
+
selected-hover-state-layer-opacity: 0,
|
|
7
|
+
selected-focus-state-layer-opacity: 0,
|
|
8
|
+
unselected-hover-state-layer-opacity: 0,
|
|
9
|
+
unselected-focus-state-layer-opacity: 0,
|
|
10
|
+
unselected-hover-icon-color: var(--src-color-border-strong-hover),
|
|
11
|
+
unselected-focus-icon-color: var(--src-color-border-strong-hover),
|
|
12
|
+
)
|
|
13
|
+
);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
.mat-mdc-checkbox {
|
|
17
|
+
.mdc-checkbox__background {
|
|
18
|
+
width: 20px;
|
|
19
|
+
height: 20px;
|
|
20
|
+
padding: 2px;
|
|
21
|
+
border-radius: var(--src-br-small);
|
|
22
|
+
border: 2px solid var(--src-color-border-strong);
|
|
23
|
+
border-color: var(--src-color-border-strong);
|
|
24
|
+
transform: none;
|
|
25
|
+
|
|
26
|
+
.mdc-checkbox__checkmark {
|
|
27
|
+
width: 80%;
|
|
28
|
+
height: 80%;
|
|
29
|
+
top: 10%;
|
|
30
|
+
left: 10%;
|
|
31
|
+
right: 10%;
|
|
32
|
+
bottom: 10%;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.mat-internal-form-field > label {
|
|
37
|
+
padding-left: 8px;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.mat-pseudo-checkbox.mat-pseudo-checkbox-full {
|
|
42
|
+
--mat-full-pseudo-checkbox-unselected-icon-color: var(
|
|
43
|
+
--src-color-border-strong
|
|
44
|
+
);
|
|
45
|
+
width: 20px;
|
|
46
|
+
height: 20px;
|
|
47
|
+
border-radius: var(--src-br-small);
|
|
48
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
@use '@angular/material' as mat;
|
|
2
|
+
|
|
3
|
+
// Customize the entire app. Change :root to your selector if you want to scope the styles.
|
|
4
|
+
:root {
|
|
5
|
+
@include mat.form-field-overrides(
|
|
6
|
+
(
|
|
7
|
+
outlined-container-shape: var(--src-br-small),
|
|
8
|
+
outlined-outline-width: 1px,
|
|
9
|
+
container-text-size: var(--src-fs-base),
|
|
10
|
+
outlined-hover-outline-color: var(--src-color-border-strong),
|
|
11
|
+
outlined-focus-outline-width: 1px,
|
|
12
|
+
outlined-focus-outline-color: var(--src-color-border-strong),
|
|
13
|
+
container-vertical-padding: 6px,
|
|
14
|
+
container-height: auto,
|
|
15
|
+
outlined-label-text-size: var(--src-fs-base),
|
|
16
|
+
leading-icon-color: var(--src-color-icon-default),
|
|
17
|
+
disabled-leading-icon-color: var(--src-color-icon-disabled),
|
|
18
|
+
trailing-icon-color: var(--src-color-icon-default),
|
|
19
|
+
)
|
|
20
|
+
);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
.mat-mdc-text-field-wrapper {
|
|
24
|
+
box-shadow: 0px 1px 0px 0px rgba(0, 0, 0, 0.05);
|
|
25
|
+
}
|
|
26
|
+
// Mat Hints are disabled in favour of using SourceHint Component
|
|
27
|
+
.mat-mdc-form-field-subscript-wrapper.mat-mdc-form-field-bottom-align {
|
|
28
|
+
display: none;
|
|
29
|
+
height: 0;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
.mdc-text-field.mdc-text-field--outlined {
|
|
33
|
+
border-top-left-radius: var(--src-br-small);
|
|
34
|
+
border-top-right-radius: var(--src-br-small);
|
|
35
|
+
border-bottom-right-radius: var(--src-br-small);
|
|
36
|
+
border-bottom-left-radius: var(--src-br-small);
|
|
37
|
+
}
|
|
38
|
+
.mat-mdc-form-field.mat-focused .mdc-text-field--outlined {
|
|
39
|
+
box-shadow:
|
|
40
|
+
0 0 0 1px #fff,
|
|
41
|
+
0 0 0 3px var(--src-color-border-primary);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
.mat-mdc-form-field-icon-prefix,
|
|
45
|
+
.mat-mdc-form-field-icon-suffix {
|
|
46
|
+
aspect-ratio: 1;
|
|
47
|
+
width: 100%;
|
|
48
|
+
height: 100%;
|
|
49
|
+
max-height: 36px;
|
|
50
|
+
max-width: 36px;
|
|
51
|
+
display: flex;
|
|
52
|
+
align-items: center;
|
|
53
|
+
justify-content: center;
|
|
54
|
+
// TODO: make better decision.
|
|
55
|
+
padding: 0 4px !important;
|
|
56
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
@use '@angular/material' as mat;
|
|
2
|
+
:root {
|
|
3
|
+
@include mat.radio-overrides(
|
|
4
|
+
(
|
|
5
|
+
state-layer-size: 20px,
|
|
6
|
+
unselected-hover-icon-color: var(--src-color-border-strong-hover),
|
|
7
|
+
unselected-focus-icon-color: var(--src-color-border-strong-hover),
|
|
8
|
+
unselected-icon-color: var(--src-color-border-strong),
|
|
9
|
+
ripple-color: transparent,
|
|
10
|
+
checked-ripple-color: transparent,
|
|
11
|
+
selected-hover-icon-color: #fff,
|
|
12
|
+
)
|
|
13
|
+
);
|
|
14
|
+
}
|
|
15
|
+
.mat-mdc-radio-button {
|
|
16
|
+
--mdc-radio-selected-icon-color: transparent;
|
|
17
|
+
&.mat-mdc-radio-checked {
|
|
18
|
+
--mdc-radio-selected-icon-color: var(--src-color-border-primary);
|
|
19
|
+
--mdc-radio-selected-hover-icon-color: var(--src-color-border-primary);
|
|
20
|
+
|
|
21
|
+
.mdc-radio__inner-circle {
|
|
22
|
+
border-color: #fff !important;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
.mat-mdc-radio-button
|
|
27
|
+
.mdc-radio__native-control:enabled:checked
|
|
28
|
+
+ .mdc-radio__background
|
|
29
|
+
> .mdc-radio__outer-circle {
|
|
30
|
+
border-width: 5px;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.mat-mdc-radio-group {
|
|
34
|
+
display: flex;
|
|
35
|
+
flex-direction: column;
|
|
36
|
+
gap: 6px;
|
|
37
|
+
}
|