cats-ui-lib 1.0.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/README.md +63 -0
- package/assets/images/activity.svg +1 -0
- package/assets/images/airplay.svg +1 -0
- package/assets/images/alert-circle.svg +1 -0
- package/assets/images/alert-octagon.svg +1 -0
- package/assets/images/alert-triangle.svg +1 -0
- package/assets/images/align-center.svg +1 -0
- package/assets/images/align-justify.svg +1 -0
- package/assets/images/align-left.svg +1 -0
- package/assets/images/align-right.svg +1 -0
- package/assets/images/anchor.svg +1 -0
- package/assets/images/aperture.svg +1 -0
- package/assets/images/archive.svg +1 -0
- package/assets/images/arrow-down-circle.svg +1 -0
- package/assets/images/arrow-down-left.svg +1 -0
- package/assets/images/arrow-down-right.svg +1 -0
- package/assets/images/arrow-down.svg +1 -0
- package/assets/images/arrow-left-circle.svg +1 -0
- package/assets/images/arrow-left.svg +1 -0
- package/assets/images/arrow-right-circle.svg +1 -0
- package/assets/images/arrow-right.svg +1 -0
- package/assets/images/arrow-up-circle.svg +1 -0
- package/assets/images/arrow-up-left.svg +1 -0
- package/assets/images/arrow-up-right.svg +1 -0
- package/assets/images/arrow-up.svg +1 -0
- package/assets/images/at-sign.svg +1 -0
- package/assets/images/award.svg +1 -0
- package/assets/images/bar-chart-2.svg +1 -0
- package/assets/images/bar-chart.svg +1 -0
- package/assets/images/battery-charging.svg +1 -0
- package/assets/images/battery.svg +1 -0
- package/assets/images/bell-off.svg +1 -0
- package/assets/images/bell.svg +1 -0
- package/assets/images/bluetooth.svg +1 -0
- package/assets/images/bold.svg +1 -0
- package/assets/images/book-open.svg +1 -0
- package/assets/images/book.svg +1 -0
- package/assets/images/bookmark.svg +1 -0
- package/assets/images/box.svg +1 -0
- package/assets/images/briefcase.svg +1 -0
- package/assets/images/calendar.svg +1 -0
- package/assets/images/camera-off.svg +1 -0
- package/assets/images/camera.svg +1 -0
- package/assets/images/cast.svg +1 -0
- package/assets/images/check-circle.svg +1 -0
- package/assets/images/check-square.svg +1 -0
- package/assets/images/check.svg +1 -0
- package/assets/images/chevron-down.svg +1 -0
- package/assets/images/chevron-left.svg +1 -0
- package/assets/images/chevron-right.svg +1 -0
- package/assets/images/chevron-up.svg +1 -0
- package/assets/images/chevrons-down.svg +1 -0
- package/assets/images/chevrons-left.svg +1 -0
- package/assets/images/chevrons-right.svg +1 -0
- package/assets/images/chevrons-up.svg +1 -0
- package/assets/images/chrome.svg +1 -0
- package/assets/images/circle.svg +1 -0
- package/assets/images/clipboard.svg +1 -0
- package/assets/images/clock.svg +1 -0
- package/assets/images/cloud-drizzle.svg +1 -0
- package/assets/images/cloud-lightning.svg +1 -0
- package/assets/images/cloud-off.svg +1 -0
- package/assets/images/cloud-rain.svg +1 -0
- package/assets/images/cloud-snow.svg +1 -0
- package/assets/images/cloud.svg +1 -0
- package/assets/images/code.svg +1 -0
- package/assets/images/codepen.svg +1 -0
- package/assets/images/codesandbox.svg +1 -0
- package/assets/images/coffee.svg +1 -0
- package/assets/images/columns.svg +1 -0
- package/assets/images/command.svg +1 -0
- package/assets/images/compass.svg +1 -0
- package/assets/images/copy.svg +1 -0
- package/assets/images/corner-down-left.svg +1 -0
- package/assets/images/corner-down-right.svg +1 -0
- package/assets/images/corner-left-down.svg +1 -0
- package/assets/images/corner-left-up.svg +1 -0
- package/assets/images/corner-right-down.svg +1 -0
- package/assets/images/corner-right-up.svg +1 -0
- package/assets/images/corner-up-left.svg +1 -0
- package/assets/images/corner-up-right.svg +1 -0
- package/assets/images/cpu.svg +1 -0
- package/assets/images/credit-card.svg +1 -0
- package/assets/images/crop.svg +1 -0
- package/assets/images/crosshair.svg +1 -0
- package/assets/images/database.svg +1 -0
- package/assets/images/delete.svg +1 -0
- package/assets/images/disc.svg +1 -0
- package/assets/images/divide-circle.svg +1 -0
- package/assets/images/divide-square.svg +1 -0
- package/assets/images/divide.svg +1 -0
- package/assets/images/dollar-sign.svg +1 -0
- package/assets/images/download-cloud.svg +1 -0
- package/assets/images/download.svg +1 -0
- package/assets/images/dribbble.svg +1 -0
- package/assets/images/droplet.svg +1 -0
- package/assets/images/edit-2.svg +1 -0
- package/assets/images/edit-3.svg +1 -0
- package/assets/images/edit.svg +1 -0
- package/assets/images/external-link.svg +1 -0
- package/assets/images/eye-off.svg +1 -0
- package/assets/images/eye.svg +1 -0
- package/assets/images/facebook.svg +1 -0
- package/assets/images/fast-forward.svg +1 -0
- package/assets/images/feather.svg +1 -0
- package/assets/images/figma.svg +1 -0
- package/assets/images/file-minus.svg +1 -0
- package/assets/images/file-plus.svg +1 -0
- package/assets/images/file-text.svg +1 -0
- package/assets/images/file.svg +1 -0
- package/assets/images/film.svg +1 -0
- package/assets/images/filter.svg +1 -0
- package/assets/images/flag.svg +1 -0
- package/assets/images/folder-minus.svg +1 -0
- package/assets/images/folder-plus.svg +1 -0
- package/assets/images/folder.svg +1 -0
- package/assets/images/framer.svg +1 -0
- package/assets/images/frown.svg +1 -0
- package/assets/images/gift.svg +1 -0
- package/assets/images/git-branch.svg +1 -0
- package/assets/images/git-commit.svg +1 -0
- package/assets/images/git-merge.svg +1 -0
- package/assets/images/git-pull-request.svg +1 -0
- package/assets/images/github.svg +1 -0
- package/assets/images/gitlab.svg +1 -0
- package/assets/images/globe.svg +1 -0
- package/assets/images/grid.svg +1 -0
- package/assets/images/hard-drive.svg +1 -0
- package/assets/images/hash.svg +1 -0
- package/assets/images/headphones.svg +1 -0
- package/assets/images/heart.svg +1 -0
- package/assets/images/help-circle.svg +1 -0
- package/assets/images/hexagon.svg +1 -0
- package/assets/images/home.svg +1 -0
- package/assets/images/icon-checked.svg +1 -0
- package/assets/images/image.svg +1 -0
- package/assets/images/inbox.svg +1 -0
- package/assets/images/indeterminate.svg +3 -0
- package/assets/images/info.svg +1 -0
- package/assets/images/instagram.svg +1 -0
- package/assets/images/italic.svg +1 -0
- package/assets/images/key.svg +1 -0
- package/assets/images/layers.svg +1 -0
- package/assets/images/layout.svg +1 -0
- package/assets/images/life-buoy.svg +1 -0
- package/assets/images/link-2.svg +1 -0
- package/assets/images/link.svg +1 -0
- package/assets/images/linkedin.svg +1 -0
- package/assets/images/list.svg +1 -0
- package/assets/images/loader.svg +1 -0
- package/assets/images/lock.svg +1 -0
- package/assets/images/log-in.svg +1 -0
- package/assets/images/log-out.svg +1 -0
- package/assets/images/mail.svg +1 -0
- package/assets/images/map-pin.svg +1 -0
- package/assets/images/map.svg +1 -0
- package/assets/images/maximize-2.svg +1 -0
- package/assets/images/maximize.svg +1 -0
- package/assets/images/meh.svg +1 -0
- package/assets/images/menu.svg +1 -0
- package/assets/images/message-circle.svg +1 -0
- package/assets/images/message-square.svg +1 -0
- package/assets/images/mic-off.svg +1 -0
- package/assets/images/mic.svg +1 -0
- package/assets/images/minimize-2.svg +1 -0
- package/assets/images/minimize.svg +1 -0
- package/assets/images/minus-circle.svg +1 -0
- package/assets/images/minus-square.svg +1 -0
- package/assets/images/minus.svg +1 -0
- package/assets/images/monitor.svg +1 -0
- package/assets/images/moon.svg +1 -0
- package/assets/images/more-horizontal.svg +1 -0
- package/assets/images/more-vertical.svg +1 -0
- package/assets/images/mouse-pointer.svg +1 -0
- package/assets/images/move.svg +1 -0
- package/assets/images/music.svg +1 -0
- package/assets/images/navigation-2.svg +1 -0
- package/assets/images/navigation.svg +1 -0
- package/assets/images/octagon.svg +1 -0
- package/assets/images/package.svg +1 -0
- package/assets/images/paperclip.svg +1 -0
- package/assets/images/pause-circle.svg +1 -0
- package/assets/images/pause.svg +1 -0
- package/assets/images/pen-tool.svg +1 -0
- package/assets/images/percent.svg +1 -0
- package/assets/images/phone-call.svg +1 -0
- package/assets/images/phone-forwarded.svg +1 -0
- package/assets/images/phone-incoming.svg +1 -0
- package/assets/images/phone-missed.svg +1 -0
- package/assets/images/phone-off.svg +1 -0
- package/assets/images/phone-outgoing.svg +1 -0
- package/assets/images/phone.svg +1 -0
- package/assets/images/pie-chart.svg +1 -0
- package/assets/images/play-circle.svg +1 -0
- package/assets/images/play.svg +1 -0
- package/assets/images/plus-circle.svg +1 -0
- package/assets/images/plus-square.svg +1 -0
- package/assets/images/plus.svg +1 -0
- package/assets/images/pocket.svg +1 -0
- package/assets/images/power.svg +1 -0
- package/assets/images/printer.svg +1 -0
- package/assets/images/radio.svg +1 -0
- package/assets/images/refresh-ccw.svg +1 -0
- package/assets/images/refresh-cw.svg +1 -0
- package/assets/images/repeat.svg +1 -0
- package/assets/images/rewind.svg +1 -0
- package/assets/images/rotate-ccw.svg +1 -0
- package/assets/images/rotate-cw.svg +1 -0
- package/assets/images/rss.svg +1 -0
- package/assets/images/save.svg +1 -0
- package/assets/images/scissors.svg +1 -0
- package/assets/images/search.svg +1 -0
- package/assets/images/send.svg +1 -0
- package/assets/images/server.svg +1 -0
- package/assets/images/settings.svg +1 -0
- package/assets/images/share-2.svg +1 -0
- package/assets/images/share.svg +1 -0
- package/assets/images/shield-off.svg +1 -0
- package/assets/images/shield.svg +1 -0
- package/assets/images/shopping-bag.svg +1 -0
- package/assets/images/shopping-cart.svg +1 -0
- package/assets/images/shuffle.svg +1 -0
- package/assets/images/sidebar.svg +1 -0
- package/assets/images/skip-back.svg +1 -0
- package/assets/images/skip-forward.svg +1 -0
- package/assets/images/slack.svg +1 -0
- package/assets/images/slash.svg +1 -0
- package/assets/images/sliders.svg +1 -0
- package/assets/images/smartphone.svg +1 -0
- package/assets/images/smile.svg +1 -0
- package/assets/images/speaker.svg +1 -0
- package/assets/images/square.svg +1 -0
- package/assets/images/star.svg +1 -0
- package/assets/images/stop-circle.svg +1 -0
- package/assets/images/sun.svg +1 -0
- package/assets/images/sunrise.svg +1 -0
- package/assets/images/sunset.svg +1 -0
- package/assets/images/table.svg +1 -0
- package/assets/images/tablet.svg +1 -0
- package/assets/images/tag.svg +1 -0
- package/assets/images/target.svg +1 -0
- package/assets/images/terminal.svg +1 -0
- package/assets/images/thermometer.svg +1 -0
- package/assets/images/thumbs-down.svg +1 -0
- package/assets/images/thumbs-up.svg +1 -0
- package/assets/images/toggle-left.svg +1 -0
- package/assets/images/toggle-right.svg +1 -0
- package/assets/images/tool.svg +1 -0
- package/assets/images/trash-2.svg +1 -0
- package/assets/images/trash.svg +1 -0
- package/assets/images/trello.svg +1 -0
- package/assets/images/trending-down.svg +1 -0
- package/assets/images/trending-up.svg +1 -0
- package/assets/images/triangle.svg +1 -0
- package/assets/images/truck.svg +1 -0
- package/assets/images/tv.svg +1 -0
- package/assets/images/twitch.svg +1 -0
- package/assets/images/twitter.svg +1 -0
- package/assets/images/type.svg +1 -0
- package/assets/images/umbrella.svg +1 -0
- package/assets/images/underline.svg +1 -0
- package/assets/images/unlock.svg +1 -0
- package/assets/images/upload-cloud.svg +1 -0
- package/assets/images/upload.svg +1 -0
- package/assets/images/user-check.svg +1 -0
- package/assets/images/user-minus.svg +1 -0
- package/assets/images/user-plus.svg +1 -0
- package/assets/images/user-x.svg +1 -0
- package/assets/images/user.svg +1 -0
- package/assets/images/users.svg +1 -0
- package/assets/images/video-off.svg +1 -0
- package/assets/images/video.svg +1 -0
- package/assets/images/voicemail.svg +1 -0
- package/assets/images/volume-1.svg +1 -0
- package/assets/images/volume-2.svg +1 -0
- package/assets/images/volume-x.svg +1 -0
- package/assets/images/volume.svg +1 -0
- package/assets/images/watch.svg +1 -0
- package/assets/images/wifi-off.svg +1 -0
- package/assets/images/wifi.svg +1 -0
- package/assets/images/wind.svg +1 -0
- package/assets/images/x-circle.svg +1 -0
- package/assets/images/x-octagon.svg +1 -0
- package/assets/images/x-square.svg +1 -0
- package/assets/images/x.svg +1 -0
- package/assets/images/youtube.svg +1 -0
- package/assets/images/zap-off.svg +1 -0
- package/assets/images/zap.svg +1 -0
- package/assets/images/zoom-in.svg +1 -0
- package/assets/images/zoom-out.svg +1 -0
- package/fesm2022/cats-ui.mjs +1394 -0
- package/fesm2022/cats-ui.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/auto-complete-multi-select/auto-complete-multi-select.component.d.ts +69 -0
- package/lib/components/auto-complete-multi-select/index.d.ts +1 -0
- package/lib/components/auto-complete-single-select/auto-complete-single-select.component.d.ts +58 -0
- package/lib/components/auto-complete-single-select/index.d.ts +1 -0
- package/lib/components/checkbox-button/checkbox-button.component.d.ts +29 -0
- package/lib/components/checkbox-button/index.d.ts +1 -0
- package/lib/components/directives/outside-click.directive.d.ts +10 -0
- package/lib/components/input/index.d.ts +1 -0
- package/lib/components/input/input.component.d.ts +54 -0
- package/lib/components/multi-select/index.d.ts +1 -0
- package/lib/components/multi-select/multi-select.component.d.ts +83 -0
- package/lib/components/radio-button/index.d.ts +1 -0
- package/lib/components/radio-button/radio-button.component.d.ts +5 -0
- package/lib/components/search-box/index.d.ts +1 -0
- package/lib/components/search-box/search-box.component.d.ts +30 -0
- package/lib/components/single-select/index.d.ts +1 -0
- package/lib/components/single-select/single-select.component.d.ts +89 -0
- package/lib/components/toogle-button/index.d.ts +1 -0
- package/lib/components/toogle-button/toogle-button.component.d.ts +16 -0
- package/lib/modal/cats-ui.modal.d.ts +71 -0
- package/lib/services/cats-ui.service.d.ts +6 -0
- package/package.json +23 -0
- package/public-api.d.ts +12 -0
- package/styles/_fonts.scss +74 -0
- package/styles/_functions.scss +10 -0
- package/styles/_index.scss +6 -0
- package/styles/_mixins.scss +65 -0
- package/styles/_reset.scss +69 -0
- package/styles/_utilities.scss +80 -0
- package/styles/_variables.scss +92 -0
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
|
+
import { ControlValueAccessor } from '@angular/forms';
|
|
3
|
+
import { SearchConfig } from '../../modal/cats-ui.modal';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class SearchBoxComponent implements ControlValueAccessor {
|
|
6
|
+
searchParam: string;
|
|
7
|
+
searchConfig: SearchConfig;
|
|
8
|
+
onClose: EventEmitter<void>;
|
|
9
|
+
searchParamValue: EventEmitter<string>;
|
|
10
|
+
private onChange;
|
|
11
|
+
onTouched: () => void;
|
|
12
|
+
isDisabled: boolean;
|
|
13
|
+
ngOnInit(): void;
|
|
14
|
+
/**
|
|
15
|
+
* @description Method to Called when input changes
|
|
16
|
+
* @author Shiva Kant
|
|
17
|
+
*/
|
|
18
|
+
onInputChange(event: any): void;
|
|
19
|
+
/**
|
|
20
|
+
* @description Method to closeSearchBar
|
|
21
|
+
* @author Shiva Kant
|
|
22
|
+
*/
|
|
23
|
+
closeSearchBar(): void;
|
|
24
|
+
writeValue(value: string): void;
|
|
25
|
+
registerOnChange(fn: (value: string) => void): void;
|
|
26
|
+
registerOnTouched(fn: () => void): void;
|
|
27
|
+
setDisabledState?(isDisabled: boolean): void;
|
|
28
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SearchBoxComponent, never>;
|
|
29
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SearchBoxComponent, "cats-ui-search-box", never, { "searchConfig": { "alias": "searchConfig"; "required": false; }; }, { "onClose": "onClose"; "searchParamValue": "searchParamValue"; }, never, never, true, never>;
|
|
30
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./single-select.component";
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { ChangeDetectorRef, ElementRef, EventEmitter, OnChanges, OnInit, SimpleChanges, TemplateRef } from '@angular/core';
|
|
2
|
+
import { ControlValueAccessor, FormControl } from '@angular/forms';
|
|
3
|
+
import { SingleSelectConfig } from '../../modal/cats-ui.modal';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare const SINGLE_SELECT_CONTROL_VALUE_ACCESSOR: any;
|
|
6
|
+
export declare const SINGLE_SELECT_CONTROL_VALUE_VALIDATOR: any;
|
|
7
|
+
export declare class SingleSelectComponent implements OnInit, OnChanges, ControlValueAccessor {
|
|
8
|
+
private cd;
|
|
9
|
+
private el;
|
|
10
|
+
optionList: any[];
|
|
11
|
+
singleSelectConfig: SingleSelectConfig;
|
|
12
|
+
selectedOption: any;
|
|
13
|
+
onSelection: EventEmitter<any>;
|
|
14
|
+
showDropdown: boolean;
|
|
15
|
+
searchText: string;
|
|
16
|
+
inValid: boolean;
|
|
17
|
+
control: FormControl<any> | null;
|
|
18
|
+
disableControl: boolean;
|
|
19
|
+
onScroll: any;
|
|
20
|
+
parentNativeElement: any;
|
|
21
|
+
selectedData: TemplateRef<any>;
|
|
22
|
+
constructor(cd: ChangeDetectorRef, el: ElementRef);
|
|
23
|
+
ngOnInit(): void;
|
|
24
|
+
ngOnChanges(_changes: SimpleChanges): void;
|
|
25
|
+
/**
|
|
26
|
+
* @description Method to toggle dropdown list
|
|
27
|
+
* @author Shiva Kant
|
|
28
|
+
*/
|
|
29
|
+
toggleDropdown(): void;
|
|
30
|
+
/**
|
|
31
|
+
* @description Method to check if provide arg is an object or not
|
|
32
|
+
* @author Shiva Kant
|
|
33
|
+
* @param Obj:any
|
|
34
|
+
* @returns boolean
|
|
35
|
+
*/
|
|
36
|
+
isObjEmpty(obj: any): boolean;
|
|
37
|
+
/**
|
|
38
|
+
* @description Method is to update selected option and then
|
|
39
|
+
* update formcontrol by call onChangeCallback.
|
|
40
|
+
* @author Shiva Kant
|
|
41
|
+
* @param item
|
|
42
|
+
* @returns void
|
|
43
|
+
*/
|
|
44
|
+
updateSelectedOption(item: any): void;
|
|
45
|
+
validate(control: FormControl): void;
|
|
46
|
+
private onTouchedCallback;
|
|
47
|
+
private onChangeCallback;
|
|
48
|
+
/**
|
|
49
|
+
* @description method to update value of selectedOption
|
|
50
|
+
* @author Shiva Kant
|
|
51
|
+
* @param obj this is provided by formcontrol
|
|
52
|
+
* @returns void
|
|
53
|
+
*/
|
|
54
|
+
writeValue(obj: any): void;
|
|
55
|
+
/**
|
|
56
|
+
* @description method to register on change callback from form API
|
|
57
|
+
* @author Shiva Kant
|
|
58
|
+
* @param fn
|
|
59
|
+
* @returns void
|
|
60
|
+
*/
|
|
61
|
+
registerOnChange(fn: any): void;
|
|
62
|
+
/**
|
|
63
|
+
* @description method to register on touch callback from form API
|
|
64
|
+
* @author Shiva Kant
|
|
65
|
+
* @param fn
|
|
66
|
+
* @returns void
|
|
67
|
+
*/
|
|
68
|
+
registerOnTouched(fn: any): void;
|
|
69
|
+
setDisabledState(isDisabled: boolean): void;
|
|
70
|
+
/**
|
|
71
|
+
* @description method to update ontouchcallback on blur
|
|
72
|
+
* @author Shiva Kant
|
|
73
|
+
*/
|
|
74
|
+
onTouched(): void;
|
|
75
|
+
/**
|
|
76
|
+
* @description method to toggle dropdown on outside click
|
|
77
|
+
* @author Shiva Kant
|
|
78
|
+
*/
|
|
79
|
+
closeDropdown(event: any): void;
|
|
80
|
+
/**
|
|
81
|
+
* @description method to load more list
|
|
82
|
+
* @author Shiva Kant
|
|
83
|
+
* @param event
|
|
84
|
+
*/
|
|
85
|
+
onDivScroll(event: any): void;
|
|
86
|
+
get filteredOptionsValue(): any[];
|
|
87
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SingleSelectComponent, never>;
|
|
88
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SingleSelectComponent, "cats-ui-single-select", never, { "optionList": { "alias": "optionList"; "required": false; }; "singleSelectConfig": { "alias": "singleSelectConfig"; "required": false; }; "selectedOption": { "alias": "selectedOption"; "required": false; }; "parentNativeElement": { "alias": "parentNativeElement"; "required": false; }; }, { "onSelection": "onSelection"; "onScroll": "onScroll"; }, ["selectedData"], never, true, never>;
|
|
89
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./toogle-button.component";
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
|
+
import { ToggleConfig } from '../../modal/cats-ui.modal';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class ToogleButtonComponent {
|
|
5
|
+
toggleConfig: ToggleConfig;
|
|
6
|
+
onToggled: EventEmitter<boolean>;
|
|
7
|
+
private onChange;
|
|
8
|
+
private onTouched;
|
|
9
|
+
toggle(): void;
|
|
10
|
+
writeValue(value: boolean): void;
|
|
11
|
+
registerOnChange(fn: any): void;
|
|
12
|
+
registerOnTouched(fn: any): void;
|
|
13
|
+
setDisabledState(isDisabled: boolean): void;
|
|
14
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ToogleButtonComponent, never>;
|
|
15
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ToogleButtonComponent, "cats-ui-toogle-button", never, { "toggleConfig": { "alias": "toggleConfig"; "required": false; }; }, { "onToggled": "onToggled"; }, never, never, true, never>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
export declare class SingleSelectConfig {
|
|
2
|
+
idField: string;
|
|
3
|
+
textField: string;
|
|
4
|
+
disabledField?: string;
|
|
5
|
+
placeholder?: string;
|
|
6
|
+
prefixLabel?: string;
|
|
7
|
+
enableSearch?: boolean;
|
|
8
|
+
required?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare class MultiSelectConfig {
|
|
11
|
+
idField: string;
|
|
12
|
+
textField: string;
|
|
13
|
+
disabledField?: string;
|
|
14
|
+
placeholder?: string;
|
|
15
|
+
prefixLabel?: string;
|
|
16
|
+
enableSearch?: boolean;
|
|
17
|
+
chipLimit: number;
|
|
18
|
+
selectAll?: boolean;
|
|
19
|
+
required?: boolean;
|
|
20
|
+
}
|
|
21
|
+
export declare class SearchConfig {
|
|
22
|
+
serachValue: string;
|
|
23
|
+
borderRequired?: boolean;
|
|
24
|
+
placeholder?: string;
|
|
25
|
+
}
|
|
26
|
+
export declare class InputConfig {
|
|
27
|
+
type: 'text' | 'email' | 'password' | 'number';
|
|
28
|
+
placeholder?: string;
|
|
29
|
+
label?: string;
|
|
30
|
+
}
|
|
31
|
+
export declare class AutoCompleteSingleSelectConfig {
|
|
32
|
+
idField: string;
|
|
33
|
+
textField: string;
|
|
34
|
+
disabledField?: string;
|
|
35
|
+
placeholder?: string;
|
|
36
|
+
required?: boolean;
|
|
37
|
+
customInput: boolean;
|
|
38
|
+
}
|
|
39
|
+
export declare class AutoCompleteMultiSelectConfig {
|
|
40
|
+
idField: string;
|
|
41
|
+
textField: string;
|
|
42
|
+
disabledField?: string;
|
|
43
|
+
selectAll?: boolean;
|
|
44
|
+
placeholder?: string;
|
|
45
|
+
required?: boolean;
|
|
46
|
+
chipLimit: number;
|
|
47
|
+
customInput: boolean;
|
|
48
|
+
pattern?: string;
|
|
49
|
+
}
|
|
50
|
+
export declare class ToggleConfig {
|
|
51
|
+
checked: boolean;
|
|
52
|
+
disabled?: boolean;
|
|
53
|
+
}
|
|
54
|
+
export declare class CheckBoxSubtask {
|
|
55
|
+
name: string;
|
|
56
|
+
id: string;
|
|
57
|
+
checked?: boolean;
|
|
58
|
+
}
|
|
59
|
+
export declare class CheckBoxConfig {
|
|
60
|
+
id: string;
|
|
61
|
+
name: string;
|
|
62
|
+
checked?: boolean;
|
|
63
|
+
subtasks?: CheckBoxSubtask[];
|
|
64
|
+
}
|
|
65
|
+
export interface RadioButtonConfig {
|
|
66
|
+
label?: string;
|
|
67
|
+
disabled?: boolean;
|
|
68
|
+
valueField?: string;
|
|
69
|
+
textField?: string;
|
|
70
|
+
layout?: 'horizontal' | 'vertical';
|
|
71
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "cats-ui-lib",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"peerDependencies": {
|
|
5
|
+
"@angular/common": "^19.2.0",
|
|
6
|
+
"@angular/core": "^19.2.0"
|
|
7
|
+
},
|
|
8
|
+
"dependencies": {
|
|
9
|
+
"tslib": "^2.3.0"
|
|
10
|
+
},
|
|
11
|
+
"sideEffects": false,
|
|
12
|
+
"module": "fesm2022/cats-ui.mjs",
|
|
13
|
+
"typings": "index.d.ts",
|
|
14
|
+
"exports": {
|
|
15
|
+
"./package.json": {
|
|
16
|
+
"default": "./package.json"
|
|
17
|
+
},
|
|
18
|
+
".": {
|
|
19
|
+
"types": "./index.d.ts",
|
|
20
|
+
"default": "./fesm2022/cats-ui.mjs"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
package/public-api.d.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export * from './lib/services/cats-ui.service';
|
|
2
|
+
export * from './lib/components/input';
|
|
3
|
+
export * from './lib/components/single-select';
|
|
4
|
+
export * from './lib/components/multi-select';
|
|
5
|
+
export * from './lib/components/search-box';
|
|
6
|
+
export * from './lib/components/auto-complete-single-select';
|
|
7
|
+
export * from './lib/components/directives/outside-click.directive';
|
|
8
|
+
export * from './lib/components/auto-complete-multi-select';
|
|
9
|
+
export * from './lib/modal/cats-ui.modal';
|
|
10
|
+
export * from './lib/components/toogle-button';
|
|
11
|
+
export * from './lib/components/checkbox-button';
|
|
12
|
+
export * from './lib/components/radio-button';
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
// @use url("https://fonts.googleapis.com/css2?family=Rethink+Sans:ital,wght@0,400..800;1,400..800&display=swap");
|
|
2
|
+
|
|
3
|
+
@use "mixins" as *;
|
|
4
|
+
|
|
5
|
+
:root {
|
|
6
|
+
--fs-6: 6px;
|
|
7
|
+
--fs-12: 12px;
|
|
8
|
+
--fs-14: 14px;
|
|
9
|
+
--fs-16: 16px;
|
|
10
|
+
--fs-18: 18px;
|
|
11
|
+
--fs-20: 20px;
|
|
12
|
+
--fs-24: 24px;
|
|
13
|
+
--fs-28: 28px;
|
|
14
|
+
--fs-30: 30px;
|
|
15
|
+
--fs-32: 32px;
|
|
16
|
+
--fs-42: 42px;
|
|
17
|
+
--fs-48: 48px;
|
|
18
|
+
--img-w: 28px;
|
|
19
|
+
--scale: 1;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
@include width-range($tablet, $mediumDesktop) {
|
|
23
|
+
:root {
|
|
24
|
+
--scale: 1.5;
|
|
25
|
+
--fs-6: calc(6px / var(--scale));
|
|
26
|
+
--fs-12: calc(12px / var(--scale));
|
|
27
|
+
--fs-14: calc(14px / var(--scale));
|
|
28
|
+
--fs-16: calc(16px / var(--scale));
|
|
29
|
+
--fs-18: calc(18px / var(--scale));
|
|
30
|
+
--fs-20: calc(20px / var(--scale));
|
|
31
|
+
--fs-24: calc(24px / var(--scale));
|
|
32
|
+
--fs-28: calc(28px / var(--scale));
|
|
33
|
+
--fs-30: calc(30px / var(--scale));
|
|
34
|
+
--fs-32: calc(32px / var(--scale));
|
|
35
|
+
--fs-42: calc(42px / var(--scale));
|
|
36
|
+
--fs-48: calc(48px / var(--scale));
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
@include width-range($largeDesktop, $extraLargeDesktop) {
|
|
41
|
+
:root {
|
|
42
|
+
--scale: 1.33;
|
|
43
|
+
--fs-6: calc(6px / var(--scale));
|
|
44
|
+
--fs-12: calc(12px / var(--scale));
|
|
45
|
+
--fs-14: calc(14px / var(--scale));
|
|
46
|
+
--fs-16: calc(16px / var(--scale));
|
|
47
|
+
--fs-18: calc(18px / var(--scale));
|
|
48
|
+
--fs-20: calc(20px / var(--scale));
|
|
49
|
+
--fs-24: calc(24px / var(--scale));
|
|
50
|
+
--fs-28: calc(28px / var(--scale));
|
|
51
|
+
--fs-30: calc(30px / var(--scale));
|
|
52
|
+
--fs-32: calc(32px / var(--scale));
|
|
53
|
+
--fs-42: calc(42px / var(--scale));
|
|
54
|
+
--fs-48: calc(48px / var(--scale));
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
@include width-range($xxlargeDesktop, $ultraWideDesktop) {
|
|
59
|
+
:root {
|
|
60
|
+
--scale: 1.25;
|
|
61
|
+
--fs-6: calc(6px / var(--scale));
|
|
62
|
+
--fs-12: calc(12px / var(--scale));
|
|
63
|
+
--fs-14: calc(14px / var(--scale));
|
|
64
|
+
--fs-16: calc(16px / var(--scale));
|
|
65
|
+
--fs-18: calc(18px / var(--scale));
|
|
66
|
+
--fs-20: calc(20px / var(--scale));
|
|
67
|
+
--fs-24: calc(24px / var(--scale));
|
|
68
|
+
--fs-28: calc(28px / var(--scale));
|
|
69
|
+
--fs-30: calc(30px / var(--scale));
|
|
70
|
+
--fs-32: calc(32px / var(--scale));
|
|
71
|
+
--fs-42: calc(42px / var(--scale));
|
|
72
|
+
--fs-48: calc(48px / var(--scale));
|
|
73
|
+
}
|
|
74
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
@use "variables" as *;
|
|
2
|
+
@use "functions" as *;
|
|
3
|
+
|
|
4
|
+
$tablet: 1024px;
|
|
5
|
+
$mediumDesktop: 1280px;
|
|
6
|
+
$largeDesktop: 1360px;
|
|
7
|
+
$extraLargeDesktop: 1440px;
|
|
8
|
+
$xxlargeDesktop: 1536px;
|
|
9
|
+
$ultraWideDesktop: 1919px;
|
|
10
|
+
|
|
11
|
+
// --------------- MEDIA QUERY ------------------------
|
|
12
|
+
@mixin width-range($min, $max) {
|
|
13
|
+
@media only screen and (min-width: $min) and (max-width: $max) {
|
|
14
|
+
@content;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
// -------------- BOX HEIGHT AND WIDTH -------
|
|
19
|
+
@mixin box($width, $height: 100%) {
|
|
20
|
+
width: $width;
|
|
21
|
+
height: $height;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
// ------------- FONT STYLE
|
|
25
|
+
@mixin fontStyle($fontSize, $lineHeight, $fontWeight: 400) {
|
|
26
|
+
font-size: $fontSize;
|
|
27
|
+
line-height: $lineHeight;
|
|
28
|
+
font-weight: $fontWeight;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
// ------------- FLEX PROPERTY ---------------------
|
|
32
|
+
@mixin flex(
|
|
33
|
+
$justify: flex-start,
|
|
34
|
+
$align: stretch,
|
|
35
|
+
$gap: 0,
|
|
36
|
+
$direction: row,
|
|
37
|
+
$wrap: nowrap
|
|
38
|
+
) {
|
|
39
|
+
display: flex;
|
|
40
|
+
flex-direction: $direction;
|
|
41
|
+
justify-content: $justify;
|
|
42
|
+
align-items: $align;
|
|
43
|
+
flex-wrap: $wrap;
|
|
44
|
+
gap: $gap;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// USE CASE: IF YOU WANT ONLY 2 PROP. THEN OTHER PROP WILL APPLY AS DEFAULT PROP.
|
|
48
|
+
// @include flex(center, stretch,row, wrap, 10px);
|
|
49
|
+
|
|
50
|
+
// ------------- Border PROPERTY with width,color and radius ---------------------
|
|
51
|
+
@mixin border(
|
|
52
|
+
$width: rem(1px),
|
|
53
|
+
$style: solid,
|
|
54
|
+
$color: var(--neutral-300),
|
|
55
|
+
$radius: rem(4px)
|
|
56
|
+
) {
|
|
57
|
+
border: $width $style $color;
|
|
58
|
+
border-radius: $radius;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// Positioning element
|
|
62
|
+
@mixin position($top, $left) {
|
|
63
|
+
top: $top;
|
|
64
|
+
left: $left;
|
|
65
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
// Box Sizing
|
|
2
|
+
*,
|
|
3
|
+
*::before,
|
|
4
|
+
*::after {
|
|
5
|
+
box-sizing: border-box;
|
|
6
|
+
margin: 0;
|
|
7
|
+
padding: 0;
|
|
8
|
+
font-family: "Open Sans", sans-serif;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
body {
|
|
12
|
+
font-size: 100%;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
// Font-inflation
|
|
16
|
+
html {
|
|
17
|
+
-moz-text-size-adjust: none;
|
|
18
|
+
-webkit-text-size-adjust: none;
|
|
19
|
+
-ms-text-size-adjust: none;
|
|
20
|
+
text-size-adjust: none;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// Remove default margin and padding
|
|
24
|
+
h1,
|
|
25
|
+
h2,
|
|
26
|
+
h3,
|
|
27
|
+
h4,
|
|
28
|
+
h5,
|
|
29
|
+
h6,
|
|
30
|
+
ul,
|
|
31
|
+
ol p {
|
|
32
|
+
margin: 0;
|
|
33
|
+
padding: 0;
|
|
34
|
+
text-wrap: pretty;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
// Remove list styles on ul, ol elements
|
|
38
|
+
ul[role="list"],
|
|
39
|
+
ol[role="list"] {
|
|
40
|
+
list-style: none;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
ul {
|
|
44
|
+
list-style: none;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// images
|
|
48
|
+
img,
|
|
49
|
+
picture {
|
|
50
|
+
max-width: 100%;
|
|
51
|
+
display: block;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
::-webkit-scrollbar {
|
|
55
|
+
width: 8px;
|
|
56
|
+
height: 8px;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
::-webkit-scrollbar-thumb {
|
|
60
|
+
background: var(--neutral-200);
|
|
61
|
+
border-radius: 8px;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
input,
|
|
65
|
+
select,
|
|
66
|
+
textarea {
|
|
67
|
+
outline: none;
|
|
68
|
+
box-shadow: none;
|
|
69
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
@use "./functions" as *;
|
|
2
|
+
@use "./mixins" as *;
|
|
3
|
+
|
|
4
|
+
.pointer {
|
|
5
|
+
cursor: pointer;
|
|
6
|
+
}
|
|
7
|
+
.d-none {
|
|
8
|
+
display: none;
|
|
9
|
+
}
|
|
10
|
+
// ---------------------------- THREE DOTS TRUNCATE TEXT ------------------------
|
|
11
|
+
.textTruncate {
|
|
12
|
+
text-overflow: ellipsis;
|
|
13
|
+
overflow: hidden;
|
|
14
|
+
white-space: nowrap;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
// ------------------Button Styles--------------------
|
|
18
|
+
button {
|
|
19
|
+
border: rem(1px) solid transparent;
|
|
20
|
+
padding: 0 rem(28px);
|
|
21
|
+
height: rem(56px);
|
|
22
|
+
min-width: rem(142px);
|
|
23
|
+
@include flex(center, center, rem(12px));
|
|
24
|
+
border-radius: rem(8px);
|
|
25
|
+
@include fontStyle(var(--fs-18), "", 600);
|
|
26
|
+
cursor: pointer;
|
|
27
|
+
|
|
28
|
+
&:focus-visible {
|
|
29
|
+
outline: none;
|
|
30
|
+
border: 0;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
i-feather.icon {
|
|
34
|
+
display: flex;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
&.primary_btn {
|
|
38
|
+
background-color: var(--blue-600);
|
|
39
|
+
color: var(--white);
|
|
40
|
+
}
|
|
41
|
+
&.secondary_btn {
|
|
42
|
+
background-color: var(--neutral-100);
|
|
43
|
+
color: var(--neutral-500);
|
|
44
|
+
}
|
|
45
|
+
&.outline_btn {
|
|
46
|
+
background-color: var(--white);
|
|
47
|
+
color: var(--neutral-500);
|
|
48
|
+
border: rem(1px) solid var(--neutral-300);
|
|
49
|
+
}
|
|
50
|
+
&.disable {
|
|
51
|
+
pointer-events: none;
|
|
52
|
+
opacity: 0.6;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
&.fill_lightBlue_btn {
|
|
56
|
+
background-color: var(--blue-50);
|
|
57
|
+
color: var(--blue-600);
|
|
58
|
+
}
|
|
59
|
+
&.disable_fill_lightBlue_btn {
|
|
60
|
+
background-color: var(--blue-50);
|
|
61
|
+
color: var(--blue-300);
|
|
62
|
+
pointer-events: none;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
&.bg_logic_btn {
|
|
66
|
+
background-color: var(--white);
|
|
67
|
+
color: var(--neutral-500);
|
|
68
|
+
border: rem(1px) solid var(--neutral-200);
|
|
69
|
+
}
|
|
70
|
+
&.no_outline_btn {
|
|
71
|
+
background-color: var(--blue-50);
|
|
72
|
+
color: var(--blue-600);
|
|
73
|
+
outline: none;
|
|
74
|
+
}
|
|
75
|
+
.close_outline_btn {
|
|
76
|
+
background-color: var(--blue-50);
|
|
77
|
+
border: rem(1px) solid var(--blue-50);
|
|
78
|
+
color: var(--blue-600);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
:root {
|
|
2
|
+
--white: #ffffff;
|
|
3
|
+
--white-50: rgba(255, 255, 255, 0.582);
|
|
4
|
+
|
|
5
|
+
--black: #1f1f1f;
|
|
6
|
+
--default: #000000;
|
|
7
|
+
--black-900: #202224;
|
|
8
|
+
--pagination-text: var(--neutral-500);
|
|
9
|
+
--black-dust: #1a1a1a;
|
|
10
|
+
|
|
11
|
+
// NEUTRAL-COLOR
|
|
12
|
+
--neutral-cross: #d9d9d9;
|
|
13
|
+
--neutral-40: #d5d7da;
|
|
14
|
+
--neutral-50: #f0f0f0;
|
|
15
|
+
--neutral-100: #e6e7e8;
|
|
16
|
+
--neutral-200: #dadbdc;
|
|
17
|
+
--neutral-300: #c0c2c5;
|
|
18
|
+
--neutral-400: #81858a;
|
|
19
|
+
--neutral-500: #434a51;
|
|
20
|
+
--neutral-600: #040d17;
|
|
21
|
+
--neutral-900: #010306;
|
|
22
|
+
|
|
23
|
+
// BLUE COLOR
|
|
24
|
+
--blue-700: #1c60af;
|
|
25
|
+
--blue-600: #2680ea;
|
|
26
|
+
--blue-400: #92bff4;
|
|
27
|
+
--blue-100: #eaf3fd;
|
|
28
|
+
--blue-300: #c8dff9;
|
|
29
|
+
--blue-200: #dfecfc;
|
|
30
|
+
--blue-50: #f7fafe;
|
|
31
|
+
--blue-800: #1849d6;
|
|
32
|
+
|
|
33
|
+
// GREY COLOR
|
|
34
|
+
--grey-50: #e9eaeb;
|
|
35
|
+
--grey-100: #e2e8f0;
|
|
36
|
+
--grey-150: #d6d6d6;
|
|
37
|
+
--grey-200: #64748b;
|
|
38
|
+
--grey-300: #414651;
|
|
39
|
+
--grey-400: #8080808c;
|
|
40
|
+
--grey-600: #535862;
|
|
41
|
+
--light-grey: #81858a;
|
|
42
|
+
--dark-grey: #4a4a4a;
|
|
43
|
+
|
|
44
|
+
--green-50: #f7fbf7;
|
|
45
|
+
--green-100: #ecf4ec;
|
|
46
|
+
--green-200: #2a6a2d;
|
|
47
|
+
--green-400: #9bc69d;
|
|
48
|
+
--green-600: #388e3c;
|
|
49
|
+
--green-700: rgba(42, 106, 45, 1);
|
|
50
|
+
|
|
51
|
+
--red: #ff0000;
|
|
52
|
+
--red-50: #fdf7f7;
|
|
53
|
+
--red-100: #f0c9c9;
|
|
54
|
+
--red-200: #f7dfdf;
|
|
55
|
+
--red-300: #f2f2f2;
|
|
56
|
+
--red-700: #941e1e;
|
|
57
|
+
|
|
58
|
+
--yellow-50: #fffdf5;
|
|
59
|
+
--yellow-100: #fff5e6;
|
|
60
|
+
--yellow-200: #fff6da;
|
|
61
|
+
--yellow-300: #ffefc1;
|
|
62
|
+
--yellow-400: #fff9e7;
|
|
63
|
+
--yellow-500: #bf7200;
|
|
64
|
+
--yellow-600: #ffc107;
|
|
65
|
+
--yellow-700: #bf9105;
|
|
66
|
+
--yellow-800: #806003;
|
|
67
|
+
--yellow-900: #bf9105;
|
|
68
|
+
|
|
69
|
+
// Orange
|
|
70
|
+
--orange-50: rgba(255, 251, 245, 1);
|
|
71
|
+
--orange-100: #fff5e6;
|
|
72
|
+
--orange-200: #fff0d9;
|
|
73
|
+
--orange-600: #ff9800;
|
|
74
|
+
--orange-700: rgba(191, 114, 0, 1);
|
|
75
|
+
|
|
76
|
+
--box-shadow: #0a0d1208;
|
|
77
|
+
--box-shadow-100: #0000001f;
|
|
78
|
+
--box-shadow-200: #0a0d1214;
|
|
79
|
+
--grid-box-shadow: #0000000a;
|
|
80
|
+
--model-shadow: rgba(0, 0, 0, 0.08);
|
|
81
|
+
--canvas-shadow: #00000014;
|
|
82
|
+
// chunk shadow
|
|
83
|
+
--chunk-shadow: #0a0d120d;
|
|
84
|
+
|
|
85
|
+
--loader-border: #6f7b93;
|
|
86
|
+
--modal-bg: rgba(4, 13, 23, 0.3);
|
|
87
|
+
--checkbox-border: #0d6efd;
|
|
88
|
+
|
|
89
|
+
// FILTER COLOR
|
|
90
|
+
--filter-600: rgba(0, 0, 0, 0.644);
|
|
91
|
+
--feather-bg: #fafafa;
|
|
92
|
+
}
|