@ng-formworks/material 15.2.7
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 +133 -0
- package/assets/material-design-themes.scss +71 -0
- package/karma.conf.js +46 -0
- package/ng-package.json +13 -0
- package/package.json +49 -0
- package/src/lib/flexlayout-replacement-styles.scss +95 -0
- package/src/lib/material-design-cssframework.ts +20 -0
- package/src/lib/material-design-framework.component.html +13 -0
- package/src/lib/material-design-framework.component.scss +58 -0
- package/src/lib/material-design-framework.component.spec.ts +39 -0
- package/src/lib/material-design-framework.component.ts +143 -0
- package/src/lib/material-design-framework.module.ts +81 -0
- package/src/lib/material-design-themes.scss +71 -0
- package/src/lib/material-design.framework.ts +83 -0
- package/src/lib/tailwind-output.scss +622 -0
- package/src/lib/widgets/flex-layout-root.component.html +4 -0
- package/src/lib/widgets/flex-layout-root.component.ts +52 -0
- package/src/lib/widgets/flex-layout-section.component.ts +216 -0
- package/src/lib/widgets/material-add-reference.component.ts +56 -0
- package/src/lib/widgets/material-button-group.component.ts +68 -0
- package/src/lib/widgets/material-button.component.ts +66 -0
- package/src/lib/widgets/material-checkbox.component.ts +112 -0
- package/src/lib/widgets/material-checkboxes.component.ts +108 -0
- package/src/lib/widgets/material-chip-list.component.ts +35 -0
- package/src/lib/widgets/material-datepicker.component.ts +89 -0
- package/src/lib/widgets/material-file.component.ts +35 -0
- package/src/lib/widgets/material-input.component.ts +97 -0
- package/src/lib/widgets/material-number.component.ts +95 -0
- package/src/lib/widgets/material-one-of.component.ts +35 -0
- package/src/lib/widgets/material-radios.component.ts +91 -0
- package/src/lib/widgets/material-select.component.ts +118 -0
- package/src/lib/widgets/material-slider.component.ts +65 -0
- package/src/lib/widgets/material-stepper.component.ts +35 -0
- package/src/lib/widgets/material-tabs.component.ts +72 -0
- package/src/lib/widgets/material-textarea.component.ts +88 -0
- package/src/lib/widgets/public_api.ts +54 -0
- package/src/public_api.ts +9 -0
- package/src/test.ts +17 -0
- package/tailwind-input.css +3 -0
- package/tailwind.config.js +12 -0
- package/tsconfig.lib.json +25 -0
- package/tsconfig.lib.prod.json +9 -0
- package/tsconfig.spec.json +17 -0
- package/tslint.json +11 -0
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
5
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
6
|
+
import { MatButtonToggleModule } from '@angular/material/button-toggle';
|
|
7
|
+
import { MatCardModule } from '@angular/material/card';
|
|
8
|
+
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
9
|
+
import { MatChipsModule } from '@angular/material/chips';
|
|
10
|
+
import { MatNativeDateModule } from '@angular/material/core';
|
|
11
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
12
|
+
import { MatExpansionModule } from '@angular/material/expansion';
|
|
13
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
14
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
15
|
+
import { MatInputModule } from '@angular/material/input';
|
|
16
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
17
|
+
import { MatRadioModule } from '@angular/material/radio';
|
|
18
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
19
|
+
import { MatSlideToggleModule } from '@angular/material/slide-toggle';
|
|
20
|
+
import { MatSliderModule } from '@angular/material/slider';
|
|
21
|
+
import { MatStepperModule } from '@angular/material/stepper';
|
|
22
|
+
import { MatTabsModule } from '@angular/material/tabs';
|
|
23
|
+
import { MatToolbarModule } from '@angular/material/toolbar';
|
|
24
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
25
|
+
import {
|
|
26
|
+
Framework,
|
|
27
|
+
FrameworkLibraryService,
|
|
28
|
+
JsonSchemaFormModule,
|
|
29
|
+
JsonSchemaFormService,
|
|
30
|
+
WidgetLibraryModule, WidgetLibraryService
|
|
31
|
+
} from '@ng-formworks/core';
|
|
32
|
+
import { CssFrameworkModule } from '@ng-formworks/cssframework';
|
|
33
|
+
import { MaterialDesignFramework } from './material-design.framework';
|
|
34
|
+
import { MATERIAL_FRAMEWORK_COMPONENTS } from './widgets/public_api';
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* unused @angular/material modules:
|
|
39
|
+
* MatDialogModule, MatGridListModule, MatListModule, MatMenuModule,
|
|
40
|
+
* MatPaginatorModule, MatProgressBarModule, MatProgressSpinnerModule,
|
|
41
|
+
* MatSidenavModule, MatSnackBarModule, MatSortModule, MatTableModule,
|
|
42
|
+
* ,
|
|
43
|
+
*/
|
|
44
|
+
export const ANGULAR_MATERIAL_MODULES = [
|
|
45
|
+
MatAutocompleteModule, MatButtonModule, MatButtonToggleModule, MatCardModule,
|
|
46
|
+
MatCheckboxModule, MatChipsModule, MatDatepickerModule, MatExpansionModule,
|
|
47
|
+
MatFormFieldModule, MatIconModule, MatInputModule, MatNativeDateModule,
|
|
48
|
+
MatRadioModule, MatSelectModule, MatSliderModule, MatSlideToggleModule,
|
|
49
|
+
MatStepperModule, MatTabsModule, MatTooltipModule,
|
|
50
|
+
MatToolbarModule, MatMenuModule, MatToolbarModule,
|
|
51
|
+
];
|
|
52
|
+
|
|
53
|
+
@NgModule({
|
|
54
|
+
imports: [
|
|
55
|
+
CommonModule,
|
|
56
|
+
FormsModule,
|
|
57
|
+
ReactiveFormsModule,
|
|
58
|
+
...ANGULAR_MATERIAL_MODULES,
|
|
59
|
+
WidgetLibraryModule,
|
|
60
|
+
JsonSchemaFormModule,
|
|
61
|
+
CssFrameworkModule
|
|
62
|
+
],
|
|
63
|
+
declarations: [
|
|
64
|
+
...MATERIAL_FRAMEWORK_COMPONENTS,
|
|
65
|
+
],
|
|
66
|
+
exports: [
|
|
67
|
+
JsonSchemaFormModule,
|
|
68
|
+
...MATERIAL_FRAMEWORK_COMPONENTS,
|
|
69
|
+
],
|
|
70
|
+
providers: [
|
|
71
|
+
JsonSchemaFormService,
|
|
72
|
+
FrameworkLibraryService,
|
|
73
|
+
WidgetLibraryService,
|
|
74
|
+
{ provide: Framework, useClass: MaterialDesignFramework, multi: true },
|
|
75
|
+
]
|
|
76
|
+
})
|
|
77
|
+
export class MaterialDesignFrameworkModule {
|
|
78
|
+
constructor() {
|
|
79
|
+
|
|
80
|
+
}
|
|
81
|
+
}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/* see https://material.angular.io/guide/theming */
|
|
2
|
+
|
|
3
|
+
@use '@angular/material' as mat;
|
|
4
|
+
@include mat.core();
|
|
5
|
+
$indigo-primary: mat.define-palette(mat.$indigo-palette, 500);
|
|
6
|
+
$green-accent: mat.define-palette(mat.$green-palette, A200, A100, A400);
|
|
7
|
+
$red-warn: mat.define-palette(mat.$red-palette);
|
|
8
|
+
$pink-accent: mat.define-palette(mat.$pink-palette, A200, A100, A400);
|
|
9
|
+
$deep-purple-primary: mat.define-palette(mat.$deep-purple-palette, 500);
|
|
10
|
+
$amber-accent: mat.define-palette(mat.$amber-palette, A200, A100, A400);
|
|
11
|
+
$pink-primary: mat.define-palette(mat.$pink-palette, 500);
|
|
12
|
+
$bluegrey-accent: mat.define-palette(mat.$blue-grey-palette, A200, A100, A400);
|
|
13
|
+
$typography:mat.define-typography-config();
|
|
14
|
+
$density:0;
|
|
15
|
+
|
|
16
|
+
/*Palettes (primary, accent, warn)-indigo, pink, red */
|
|
17
|
+
|
|
18
|
+
$indigo-pink-primary: $indigo-primary;
|
|
19
|
+
$indigo-pink-accent: $pink-accent;
|
|
20
|
+
$indigo-pink-warn: $red-warn;
|
|
21
|
+
$indigo-pink-theme: mat.define-light-theme(( color: ( primary: $indigo-pink-primary, accent: $indigo-pink-accent, warn:$indigo-pink-warn), typography: $typography, density: $density));
|
|
22
|
+
.indigo-pink {
|
|
23
|
+
@include mat.core-theme($indigo-pink-theme);
|
|
24
|
+
@include mat.all-component-themes($indigo-pink-theme);
|
|
25
|
+
@include mat.button-color($indigo-pink-theme);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
/*Palettes (primary, accent, warn)-purple, green, red */
|
|
30
|
+
|
|
31
|
+
$purple-green-primary: $indigo-primary;
|
|
32
|
+
$purple-green-accent: $green-accent;
|
|
33
|
+
$purple-green-warn: $red-warn;
|
|
34
|
+
$purple-green-theme: mat.define-dark-theme(( color: ( primary: $purple-green-primary, accent: $purple-green-accent, warn:$purple-green-warn)));
|
|
35
|
+
.purple-green {
|
|
36
|
+
@include mat.core-color($purple-green-theme);
|
|
37
|
+
@include mat.all-component-colors($purple-green-theme);
|
|
38
|
+
@include mat.button-color($purple-green-theme);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
/*Palettes (primary, accent, warn)-deep-purple, amber, red */
|
|
43
|
+
|
|
44
|
+
$deeppurple-amber-primary: $deep-purple-primary;
|
|
45
|
+
$deeppurple-amber-accent: $amber-accent;
|
|
46
|
+
$deeppurple-amber-warn: $red-warn;
|
|
47
|
+
$deeppurple-amber-theme: mat.define-light-theme(( color: ( primary: $deeppurple-amber-primary, accent: $deeppurple-amber-accent, warn:$deeppurple-amber-warn)));
|
|
48
|
+
.deeppurple-amber {
|
|
49
|
+
@include mat.core-color($deeppurple-amber-theme);
|
|
50
|
+
@include mat.all-component-colors($deeppurple-amber-theme);
|
|
51
|
+
@include mat.button-color($deeppurple-amber-theme);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
/*Palettes (primary, accent, warn)-pink, blue-grey, red */
|
|
56
|
+
|
|
57
|
+
$pink-bluegrey-primary: $pink-primary;
|
|
58
|
+
$pink-bluegrey-accent: $bluegrey-accent;
|
|
59
|
+
$pink-bluegrey-warn: $red-warn;
|
|
60
|
+
$pink-bluegrey-theme: mat.define-dark-theme(( color: ( primary: $pink-bluegrey-primary, accent: $pink-bluegrey-accent, warn:$pink-bluegrey-warn)));
|
|
61
|
+
.pink-bluegrey {
|
|
62
|
+
@include mat.core-color($pink-bluegrey-theme);
|
|
63
|
+
@include mat.all-component-colors($pink-bluegrey-theme);
|
|
64
|
+
@include mat.button-color($pink-bluegrey-theme);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
.material_default {
|
|
68
|
+
@include mat.core-color($indigo-pink-theme);
|
|
69
|
+
@include mat.all-component-colors($indigo-pink-theme);
|
|
70
|
+
@include mat.button-color($indigo-pink-theme);
|
|
71
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { CssFramework, CssframeworkService } from '@ng-formworks/cssframework';
|
|
3
|
+
import { cssFrameworkCfgMaterialDesign } from './material-design-cssframework';
|
|
4
|
+
import {
|
|
5
|
+
FlexLayoutRootComponent,
|
|
6
|
+
FlexLayoutSectionComponent,
|
|
7
|
+
MaterialAddReferenceComponent,
|
|
8
|
+
MaterialButtonComponent,
|
|
9
|
+
MaterialButtonGroupComponent,
|
|
10
|
+
MaterialCheckboxComponent,
|
|
11
|
+
MaterialCheckboxesComponent,
|
|
12
|
+
MaterialChipListComponent,
|
|
13
|
+
MaterialDatepickerComponent,
|
|
14
|
+
MaterialDesignFrameworkComponent,
|
|
15
|
+
MaterialFileComponent,
|
|
16
|
+
MaterialInputComponent,
|
|
17
|
+
MaterialNumberComponent,
|
|
18
|
+
MaterialOneOfComponent,
|
|
19
|
+
MaterialRadiosComponent,
|
|
20
|
+
MaterialSelectComponent,
|
|
21
|
+
MaterialSliderComponent,
|
|
22
|
+
MaterialStepperComponent,
|
|
23
|
+
MaterialTabsComponent,
|
|
24
|
+
MaterialTextareaComponent
|
|
25
|
+
} from './widgets/public_api';
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
// Material Design Framework
|
|
29
|
+
// https://github.com/angular/material2
|
|
30
|
+
|
|
31
|
+
@Injectable()
|
|
32
|
+
export class MaterialDesignFramework extends CssFramework {
|
|
33
|
+
name = 'material-design';
|
|
34
|
+
|
|
35
|
+
framework = MaterialDesignFrameworkComponent;
|
|
36
|
+
|
|
37
|
+
stylesheets = [
|
|
38
|
+
'//fonts.googleapis.com/icon?family=Material+Icons',
|
|
39
|
+
'//fonts.googleapis.com/css?family=Roboto:300,400,500,700',
|
|
40
|
+
];
|
|
41
|
+
|
|
42
|
+
_widgets = {
|
|
43
|
+
'root': FlexLayoutRootComponent,
|
|
44
|
+
'section': FlexLayoutSectionComponent,
|
|
45
|
+
'$ref': MaterialAddReferenceComponent,
|
|
46
|
+
'button': MaterialButtonComponent,
|
|
47
|
+
'button-group': MaterialButtonGroupComponent,
|
|
48
|
+
'checkbox': MaterialCheckboxComponent,
|
|
49
|
+
'checkboxes': MaterialCheckboxesComponent,
|
|
50
|
+
'chip-list': MaterialChipListComponent,
|
|
51
|
+
'date': MaterialDatepickerComponent,
|
|
52
|
+
'file': MaterialFileComponent,
|
|
53
|
+
'number': MaterialNumberComponent,
|
|
54
|
+
'one-of': MaterialOneOfComponent,
|
|
55
|
+
'radios': MaterialRadiosComponent,
|
|
56
|
+
'select': MaterialSelectComponent,
|
|
57
|
+
'slider': MaterialSliderComponent,
|
|
58
|
+
'stepper': MaterialStepperComponent,
|
|
59
|
+
'tabs': MaterialTabsComponent,
|
|
60
|
+
'text': MaterialInputComponent,
|
|
61
|
+
'textarea': MaterialTextareaComponent,
|
|
62
|
+
'alt-date': 'date',
|
|
63
|
+
'any-of': 'one-of',
|
|
64
|
+
'card': 'section',
|
|
65
|
+
'color': 'text',
|
|
66
|
+
'expansion-panel': 'section',
|
|
67
|
+
'hidden': 'none',
|
|
68
|
+
'image': 'none',
|
|
69
|
+
'integer': 'number',
|
|
70
|
+
'radiobuttons': 'button-group',
|
|
71
|
+
'range': 'slider',
|
|
72
|
+
'submit': 'button',
|
|
73
|
+
'tagsinput': 'chip-list',
|
|
74
|
+
'wizard': 'stepper',
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
constructor(public cssFWService:CssframeworkService){
|
|
78
|
+
super(cssFrameworkCfgMaterialDesign,cssFWService);
|
|
79
|
+
this.widgets=this._widgets
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
}
|