├── .editorconfig
├── .gitignore
├── LICENSE
├── README.md
├── angular.json
├── e2e
├── protractor.conf.js
├── src
│ ├── app.e2e-spec.ts
│ └── app.po.ts
└── tsconfig.e2e.json
├── package.json
├── src
├── .browserslistrc
├── app
│ ├── Prism.service.ts
│ ├── app.component.html
│ ├── app.component.scss
│ ├── app.component.spec.ts
│ ├── app.component.ts
│ ├── app.module.ts
│ ├── auth
│ │ ├── auth.module.spec.ts
│ │ ├── auth.module.ts
│ │ ├── auth
│ │ │ ├── auth.component.html
│ │ │ ├── auth.component.scss
│ │ │ ├── auth.component.spec.ts
│ │ │ └── auth.component.ts
│ │ └── login
│ │ │ ├── login.component.html
│ │ │ ├── login.component.scss
│ │ │ ├── login.component.spec.ts
│ │ │ └── login.component.ts
│ ├── components
│ │ └── CheckMatrix.js
│ ├── config.ts
│ ├── data
│ │ ├── data.component.html
│ │ ├── data.component.scss
│ │ ├── data.component.spec.ts
│ │ ├── data.component.ts
│ │ └── submission
│ │ │ ├── SubmissionGridHeader.component.html
│ │ │ ├── SubmissionGridHeader.component.ts
│ │ │ └── index.ts
│ ├── event
│ │ ├── event.module.spec.ts
│ │ ├── event.module.ts
│ │ ├── participant
│ │ │ ├── participant.module.spec.ts
│ │ │ └── participant.module.ts
│ │ ├── resource
│ │ │ ├── resource.component.html
│ │ │ ├── resource.component.scss
│ │ │ ├── resource.component.spec.ts
│ │ │ └── resource.component.ts
│ │ └── view
│ │ │ ├── view.component.html
│ │ │ ├── view.component.scss
│ │ │ ├── view.component.spec.ts
│ │ │ └── view.component.ts
│ ├── form
│ │ ├── form.module.spec.ts
│ │ ├── form.module.ts
│ │ └── index
│ │ │ ├── index.component.html
│ │ │ ├── index.component.scss
│ │ │ ├── index.component.spec.ts
│ │ │ └── index.component.ts
│ ├── forms
│ │ ├── builder
│ │ │ ├── builder.component.html
│ │ │ ├── builder.component.scss
│ │ │ ├── builder.component.spec.ts
│ │ │ └── builder.component.ts
│ │ ├── custom-builder
│ │ │ ├── builder.component.html
│ │ │ ├── builder.component.ts
│ │ │ └── options.ts
│ │ ├── forms.index.ts
│ │ ├── forms.module.spec.ts
│ │ ├── forms.module.ts
│ │ ├── forms
│ │ │ ├── forms.component.html
│ │ │ ├── forms.component.scss
│ │ │ ├── forms.component.spec.ts
│ │ │ └── forms.component.ts
│ │ ├── kitchen
│ │ │ ├── form.ts
│ │ │ ├── kitchen.component.html
│ │ │ ├── kitchen.component.scss
│ │ │ ├── kitchen.component.spec.ts
│ │ │ └── kitchen.component.ts
│ │ ├── language
│ │ │ ├── language.component.html
│ │ │ ├── language.component.scss
│ │ │ ├── language.component.spec.ts
│ │ │ └── language.component.ts
│ │ ├── pdf
│ │ │ ├── pdf.component.html
│ │ │ ├── pdf.component.scss
│ │ │ ├── pdf.component.spec.ts
│ │ │ └── pdf.component.ts
│ │ ├── renderer
│ │ │ ├── renderer.component.html
│ │ │ ├── renderer.component.scss
│ │ │ ├── renderer.component.spec.ts
│ │ │ └── renderer.component.ts
│ │ ├── simple
│ │ │ ├── simple.component.html
│ │ │ ├── simple.component.scss
│ │ │ ├── simple.component.spec.ts
│ │ │ └── simple.component.ts
│ │ └── wizard
│ │ │ ├── wizard.component.html
│ │ │ ├── wizard.component.scss
│ │ │ ├── wizard.component.spec.ts
│ │ │ └── wizard.component.ts
│ └── home
│ │ ├── home.component.html
│ │ ├── home.component.scss
│ │ ├── home.component.spec.ts
│ │ └── home.component.ts
├── assets
│ └── .gitkeep
├── environments
│ ├── environment.prod.ts
│ └── environment.ts
├── favicon.ico
├── index.html
├── karma.conf.js
├── main.ts
├── polyfills.ts
├── styles.scss
├── test.ts
├── tsconfig.app.json
├── tsconfig.spec.json
└── tslint.json
├── tsconfig.json
├── tslint.json
└── yarn.lock
/.editorconfig:
--------------------------------------------------------------------------------
1 | # Editor configuration, see http://editorconfig.org
2 | root = true
3 |
4 | [*]
5 | charset = utf-8
6 | indent_style = space
7 | indent_size = 2
8 | insert_final_newline = true
9 | trim_trailing_whitespace = true
10 |
11 | [*.md]
12 | max_line_length = off
13 | trim_trailing_whitespace = false
14 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | .angular
2 | .dccache
3 | # See http://help.github.com/ignore-files/ for more about ignoring files.
4 |
5 | # compiled output
6 | /dist
7 | /tmp
8 | /out-tsc
9 |
10 | # dependencies
11 | /node_modules
12 |
13 | # IDEs and editors
14 | /.idea
15 | .project
16 | .classpath
17 | .c9/
18 | *.launch
19 | .settings/
20 | *.sublime-workspace
21 |
22 | # IDE - VSCode
23 | .vscode/*
24 | !.vscode/settings.json
25 | !.vscode/tasks.json
26 | !.vscode/launch.json
27 | !.vscode/extensions.json
28 |
29 | # misc
30 | /.sass-cache
31 | /connect.lock
32 | /coverage
33 | /libpeerconnection.log
34 | npm-debug.log
35 | yarn-error.log
36 | testem.log
37 | /typings
38 |
39 | # System Files
40 | .DS_Store
41 | Thumbs.db
42 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2019 Form.io
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Angular + Form.io Demo
2 |
3 | This project provides an Angular demonstration with Form.io platform.
4 |
5 | ## Angular Versions
6 | This application has support for multiple versions of Angular.
7 |
8 | ### Angular 17
9 | This is the "master" branch of this application, but is also tagged with v7.0.0+ version
10 |
11 | ### Angular 16
12 | This is pushed to the "6.0.x" branch of this application, but is also tagged with v6.0.0+ version.
13 |
14 | ### Running the demo
15 | Type the following to run the demo.
16 |
17 | ```
18 | ng serve
19 | ```
20 |
21 | ### Live Demonstration
22 |
23 | To see a live demonstration, go to [https://formio.github.io/angular-demo/](https://formio.github.io/angular-demo/)
24 |
--------------------------------------------------------------------------------
/angular.json:
--------------------------------------------------------------------------------
1 | {
2 | "$schema": "./node_modules/@angular/cli/lib/config/schema.json",
3 | "version": 1,
4 | "newProjectRoot": "projects",
5 | "projects": {
6 | "demo": {
7 | "root": "",
8 | "sourceRoot": "src",
9 | "projectType": "application",
10 | "prefix": "app",
11 | "schematics": {
12 | "@schematics/angular:component": {
13 | "style": "scss"
14 | }
15 | },
16 | "architect": {
17 | "build": {
18 | "builder": "@angular-devkit/build-angular:browser",
19 | "options": {
20 | "outputPath": "dist",
21 | "index": "src/index.html",
22 | "main": "src/main.ts",
23 | "preserveSymlinks": true,
24 | "polyfills": "src/polyfills.ts",
25 | "tsConfig": "src/tsconfig.app.json",
26 | "assets": [
27 | "src/favicon.ico",
28 | "src/assets"
29 | ],
30 | "styles": [
31 | "src/styles.scss",
32 | "./node_modules/prism-themes/themes/prism-vs.css"
33 | ],
34 | "scripts": [
35 | "./node_modules/jquery/dist/jquery.min.js",
36 | "./node_modules/popper.js/dist/umd/popper.js",
37 | "./node_modules/bootstrap/dist/js/bootstrap.js",
38 | "./node_modules/prismjs/prism.js",
39 | "./node_modules/prismjs/components/prism-markup.min.js",
40 | "./node_modules/prismjs/components/prism-json.min.js",
41 | "./node_modules/prismjs/components/prism-javascript.min.js",
42 | "./node_modules/prismjs/components/prism-typescript.min.js"
43 | ]
44 | },
45 | "configurations": {
46 | "production": {
47 | "fileReplacements": [
48 | {
49 | "replace": "src/environments/environment.ts",
50 | "with": "src/environments/environment.prod.ts"
51 | }
52 | ],
53 | "optimization": true,
54 | "outputHashing": "all",
55 | "sourceMap": false,
56 | "namedChunks": false,
57 | "aot": true,
58 | "extractLicenses": true,
59 | "vendorChunk": false,
60 | "buildOptimizer": true
61 | },
62 | "development": {
63 | "buildOptimizer": false,
64 | "optimization": false,
65 | "vendorChunk": true,
66 | "extractLicenses": false,
67 | "sourceMap": true,
68 | "namedChunks": true
69 | }
70 | }
71 | },
72 | "serve": {
73 | "builder": "@angular-devkit/build-angular:dev-server",
74 | "options": {
75 | "browserTarget": "demo:build"
76 | },
77 | "configurations": {
78 | "production": {
79 | "browserTarget": "demo:build:production"
80 | },
81 | "development": {
82 | "browserTarget": "demo:build:development"
83 | }
84 | }
85 | },
86 | "extract-i18n": {
87 | "builder": "@angular-devkit/build-angular:extract-i18n",
88 | "options": {
89 | "browserTarget": "demo:build"
90 | }
91 | },
92 | "test": {
93 | "builder": "@angular-devkit/build-angular:karma",
94 | "options": {
95 | "main": "src/test.ts",
96 | "polyfills": "src/polyfills.ts",
97 | "tsConfig": "src/tsconfig.spec.json",
98 | "karmaConfig": "src/karma.conf.js",
99 | "styles": [
100 | "src/styles.scss",
101 | "./node_modules/prism-themes/themes/prism-vs.css"
102 | ],
103 | "scripts": [
104 | "./node_modules/jquery/dist/jquery.slim.js",
105 | "./node_modules/popper.js/dist/umd/popper.js",
106 | "./node_modules/bootstrap/dist/js/bootstrap.js",
107 | "./node_modules/prismjs/prism.js",
108 | "./node_modules/prismjs/components/prism-markup.min.js",
109 | "./node_modules/prismjs/components/prism-json.min.js",
110 | "./node_modules/prismjs/components/prism-javascript.min.js",
111 | "./node_modules/prismjs/components/prism-typescript.min.js"
112 | ],
113 | "assets": [
114 | "src/favicon.ico",
115 | "src/assets"
116 | ]
117 | }
118 | },
119 | "lint": {
120 | "builder": "@angular-devkit/build-angular:tslint",
121 | "options": {
122 | "tsConfig": [
123 | "src/tsconfig.app.json",
124 | "src/tsconfig.spec.json"
125 | ],
126 | "exclude": [
127 | "**/node_modules/**"
128 | ]
129 | }
130 | }
131 | }
132 | },
133 | "demo-e2e": {
134 | "root": "e2e/",
135 | "projectType": "application",
136 | "architect": {
137 | "e2e": {
138 | "builder": "@angular-devkit/build-angular:protractor",
139 | "options": {
140 | "protractorConfig": "e2e/protractor.conf.js",
141 | "devServerTarget": "demo:serve"
142 | },
143 | "configurations": {
144 | "production": {
145 | "devServerTarget": "demo:serve:production"
146 | }
147 | }
148 | },
149 | "lint": {
150 | "builder": "@angular-devkit/build-angular:tslint",
151 | "options": {
152 | "tsConfig": "e2e/tsconfig.e2e.json",
153 | "exclude": [
154 | "**/node_modules/**"
155 | ]
156 | }
157 | }
158 | }
159 | }
160 | },
161 | "defaultProject": "demo",
162 | "cli": {
163 | "analytics": false
164 | }
165 | }
--------------------------------------------------------------------------------
/e2e/protractor.conf.js:
--------------------------------------------------------------------------------
1 | // Protractor configuration file, see link for more information
2 | // https://github.com/angular/protractor/blob/master/lib/config.ts
3 |
4 | const { SpecReporter } = require('jasmine-spec-reporter');
5 |
6 | exports.config = {
7 | allScriptsTimeout: 11000,
8 | specs: [
9 | './src/**/*.e2e-spec.ts'
10 | ],
11 | capabilities: {
12 | 'browserName': 'chrome'
13 | },
14 | directConnect: true,
15 | baseUrl: 'http://localhost:4200/',
16 | framework: 'jasmine',
17 | jasmineNodeOpts: {
18 | showColors: true,
19 | defaultTimeoutInterval: 30000,
20 | print: function() {}
21 | },
22 | onPrepare() {
23 | require('ts-node').register({
24 | project: require('path').join(__dirname, './tsconfig.e2e.json')
25 | });
26 | jasmine.getEnv().addReporter(new SpecReporter({ spec: { displayStacktrace: true } }));
27 | }
28 | };
--------------------------------------------------------------------------------
/e2e/src/app.e2e-spec.ts:
--------------------------------------------------------------------------------
1 | import { AppPage } from './app.po';
2 |
3 | describe('workspace-project App', () => {
4 | let page: AppPage;
5 |
6 | beforeEach(() => {
7 | page = new AppPage();
8 | });
9 |
10 | it('should display welcome message', () => {
11 | page.navigateTo();
12 | expect(page.getParagraphText()).toEqual('Welcome to demo!');
13 | });
14 | });
15 |
--------------------------------------------------------------------------------
/e2e/src/app.po.ts:
--------------------------------------------------------------------------------
1 | import { browser, by, element } from 'protractor';
2 |
3 | export class AppPage {
4 | navigateTo() {
5 | return browser.get('/');
6 | }
7 |
8 | getParagraphText() {
9 | return element(by.css('app-root h1')).getText();
10 | }
11 | }
12 |
--------------------------------------------------------------------------------
/e2e/tsconfig.e2e.json:
--------------------------------------------------------------------------------
1 | {
2 | "extends": "../tsconfig.json",
3 | "compilerOptions": {
4 | "outDir": "../out-tsc/app",
5 | "module": "commonjs",
6 | "target": "es5",
7 | "types": [
8 | "jasmine",
9 | "jasminewd2",
10 | "node"
11 | ]
12 | }
13 | }
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@formio/formio-angular-demo",
3 | "version": "7.0.0",
4 | "scripts": {
5 | "ng": "ng",
6 | "start": "ng serve --configuration development",
7 | "build": "ng build",
8 | "test": "ng test",
9 | "lint": "ng lint",
10 | "e2e": "ng e2e",
11 | "buildprod": "ng build --configuration production",
12 | "builddemo": "ng build --configuration production --base-href /angular-demo/;",
13 | "deploy": "npm run builddemo; cd dist; git init; git remote add origin git@github.com:formio/angular-demo.git; git checkout -b gh-pages; git add -A; git commit -m 'Update demo application'; git push -f origin gh-pages;"
14 | },
15 | "dependencies": {
16 | "@angular/animations": "^17.0.8",
17 | "@angular/common": "^17.0.8",
18 | "@angular/compiler": "^17.0.8",
19 | "@angular/core": "^17.0.8",
20 | "@angular/elements": "^17.0.8",
21 | "@angular/forms": "^17.0.8",
22 | "@angular/platform-browser": "^17.0.8",
23 | "@angular/platform-browser-dynamic": "^17.0.8",
24 | "@angular/router": "^17.0.8",
25 | "@formio/angular": "^7.0.0",
26 | "bootstrap": "4",
27 | "bootswatch": "^4.5.3",
28 | "core-js": "^3.8.1",
29 | "font-awesome": "^4.7.0",
30 | "formiojs": "^4.18.0",
31 | "jquery": "^3.7.1",
32 | "ngx-bootstrap": "^12.0.0",
33 | "popper.js": "^1.16.1",
34 | "prism-themes": "^1.5.0",
35 | "prismjs": "^1.22.0",
36 | "rxjs": "^7.8.0",
37 | "zone.js": "^0.14.2"
38 | },
39 | "devDependencies": {
40 | "@angular-devkit/build-angular": "^17.0.9",
41 | "@angular/cli": "^17.0.9",
42 | "@angular/compiler-cli": "^17.0.8",
43 | "@angular/language-service": "^17.0.8",
44 | "@types/jasmine": "^5.1.4",
45 | "@types/jasminewd2": "^2.0.8",
46 | "@types/node": "^20.2.5",
47 | "codelyzer": "^6.0.1",
48 | "jasmine-core": "^5.0.0",
49 | "jasmine-spec-reporter": "^7.0.0",
50 | "karma": "^6.4.1",
51 | "karma-chrome-launcher": "~3.2.0",
52 | "karma-coverage-istanbul-reporter": "~3.0.2",
53 | "karma-jasmine": "~5.1.0",
54 | "karma-jasmine-html-reporter": "^2.1.0",
55 | "protractor": "~7.0.0",
56 | "ts-node": "^10.9.1",
57 | "tslint": "^6.1.3",
58 | "typescript": "~5.2.0"
59 | }
60 | }
61 |
--------------------------------------------------------------------------------
/src/.browserslistrc:
--------------------------------------------------------------------------------
1 | # This file is currently used by autoprefixer to adjust CSS to support the below specified browsers
2 | # For additional information regarding the format and rule options, please see:
3 | # https://github.com/browserslist/browserslist#queries
4 | #
5 | # For IE 9-11 support, please remove 'not' from the last line of the file and adjust as needed
6 |
7 | > 0.5%
8 | last 2 versions
9 | Firefox ESR
10 | not dead
11 | not IE 9-11
--------------------------------------------------------------------------------
/src/app/Prism.service.ts:
--------------------------------------------------------------------------------
1 | import { Injectable } from '@angular/core';
2 | declare var Prism: any;
3 |
4 | @Injectable()
5 | export class PrismService {
6 | init() {
7 | Prism.highlightAll();
8 | }
9 | }
10 |
--------------------------------------------------------------------------------
/src/app/app.component.html:
--------------------------------------------------------------------------------
1 |
2 |
39 |
40 |
41 |
42 |
43 |
--------------------------------------------------------------------------------
/src/app/app.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/app.component.scss
--------------------------------------------------------------------------------
/src/app/app.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { TestBed, async } from '@angular/core/testing';
2 | import { AppComponent } from './app.component';
3 | describe('AppComponent', () => {
4 | beforeEach(async(() => {
5 | TestBed.configureTestingModule({
6 | declarations: [
7 | AppComponent
8 | ],
9 | }).compileComponents();
10 | }));
11 | it('should create the app', async(() => {
12 | const fixture = TestBed.createComponent(AppComponent);
13 | const app = fixture.debugElement.componentInstance;
14 | expect(app).toBeTruthy();
15 | }));
16 | it(`should have as title 'demo'`, async(() => {
17 | const fixture = TestBed.createComponent(AppComponent);
18 | const app = fixture.debugElement.componentInstance;
19 | expect(app.title).toEqual('demo');
20 | }));
21 | it('should render title in a h1 tag', async(() => {
22 | const fixture = TestBed.createComponent(AppComponent);
23 | fixture.detectChanges();
24 | const compiled = fixture.debugElement.nativeElement;
25 | expect(compiled.querySelector('h1').textContent).toContain('Welcome to demo!');
26 | }));
27 | });
28 |
--------------------------------------------------------------------------------
/src/app/app.component.ts:
--------------------------------------------------------------------------------
1 | import { Component } from '@angular/core';
2 | import { FormioAuthService } from '@formio/angular/auth';
3 |
4 | @Component({
5 | selector: 'app-root',
6 | templateUrl: './app.component.html',
7 | styleUrls: ['./app.component.scss']
8 | })
9 | export class AppComponent {
10 | constructor(public auth: FormioAuthService) {}
11 | }
12 |
--------------------------------------------------------------------------------
/src/app/app.module.ts:
--------------------------------------------------------------------------------
1 | import { BrowserModule } from '@angular/platform-browser';
2 | import { NgModule } from '@angular/core';
3 | import { CommonModule } from '@angular/common';
4 | import { RouterModule } from '@angular/router';
5 | import { Formio, FormioModule, FormioAppConfig } from '@formio/angular';
6 | // import premium from '@formio/premium';
7 | // Formio.use(premium);
8 | import { FormioGrid } from '@formio/angular/grid';
9 | import { FormioAuthService, FormioAuthConfig } from '@formio/angular/auth';
10 | import { FormioResources } from '@formio/angular/resource';
11 | import { PrismService } from './Prism.service';
12 |
13 | import { AppConfig } from './config';
14 | import { AppComponent } from './app.component';
15 | import { HomeComponent } from './home/home.component';
16 | import { DataComponent } from './data/data.component';
17 | import { CustomSubmissionGridHeaderComponent } from './data/submission/SubmissionGridHeader.component';
18 |
19 | // Make sure we use fontawesome everywhere in Form.io renderers.
20 | (Formio as any).icons = 'fontawesome';
21 |
22 | /**
23 | * Import the Custom component CheckMatrix.
24 | */
25 | // import './components/CheckMatrix';
26 |
27 | @NgModule({
28 | declarations: [
29 | AppComponent,
30 | HomeComponent,
31 | DataComponent,
32 | CustomSubmissionGridHeaderComponent
33 | ],
34 | imports: [
35 | BrowserModule,
36 | CommonModule,
37 | FormioModule,
38 | FormioGrid,
39 | RouterModule.forRoot([
40 | {
41 | path: '',
42 | component: HomeComponent
43 | },
44 | {
45 | path: 'data',
46 | component: DataComponent
47 | },
48 | {
49 | path: 'forms',
50 | loadChildren: () => import('./forms/forms.module').then(m => m.FormsModule)
51 | },
52 | {
53 | path: 'auth',
54 | loadChildren: () => import('./auth/auth.module').then(m => m.AuthModule)
55 | },
56 | {
57 | path: 'event',
58 | loadChildren: () => import('./event/event.module').then(m => m.EventModule)
59 | },
60 | {
61 | path: 'manager',
62 | loadChildren: () => import('./form/form.module').then(m => m.FormModule)
63 | }
64 | ], {useHash: true})
65 | ],
66 | providers: [
67 | PrismService,
68 | FormioAuthService,
69 | FormioResources,
70 | {provide: FormioAppConfig, useValue: AppConfig},
71 | {provide: FormioAuthConfig, useValue: {
72 | login: {
73 | form: 'user/login'
74 | },
75 | register: {
76 | form: 'user/register'
77 | }
78 | }}
79 | ],
80 | bootstrap: [AppComponent]
81 | })
82 | export class AppModule { }
83 |
--------------------------------------------------------------------------------
/src/app/auth/auth.module.spec.ts:
--------------------------------------------------------------------------------
1 | import { AuthModule } from './auth.module';
2 |
3 | describe('AuthModule', () => {
4 | let authModule: AuthModule;
5 |
6 | beforeEach(() => {
7 | authModule = new AuthModule();
8 | });
9 |
10 | it('should create an instance', () => {
11 | expect(authModule).toBeTruthy();
12 | });
13 | });
14 |
--------------------------------------------------------------------------------
/src/app/auth/auth.module.ts:
--------------------------------------------------------------------------------
1 | import { NgModule } from '@angular/core';
2 | import { RouterModule } from '@angular/router';
3 | import { CommonModule } from '@angular/common';
4 | import { AuthComponent } from './auth/auth.component';
5 | import { LoginComponent } from './login/login.component';
6 | import { FormioModule } from '@formio/angular';
7 | import { FormioAuth, FormioAuthRoutes } from '@formio/angular/auth';
8 |
9 | export const authRoutes = FormioAuthRoutes({
10 | auth: AuthComponent,
11 | login: LoginComponent
12 | });
13 |
14 | @NgModule({
15 | imports: [
16 | CommonModule,
17 | FormioModule,
18 | FormioAuth,
19 | RouterModule.forChild(authRoutes)
20 | ],
21 | declarations: [AuthComponent, LoginComponent]
22 | })
23 | export class AuthModule { }
24 |
--------------------------------------------------------------------------------
/src/app/auth/auth/auth.component.html:
--------------------------------------------------------------------------------
1 | Authentication
2 | Authentication to your application is provided with the FormioAuthModule
3 | Authentication Documentation
4 |
5 |
6 |
7 |
You are logged in as {{ service.user.data.email }}
8 | Logout
9 |
10 |
21 |
22 |
23 |
--------------------------------------------------------------------------------
/src/app/auth/auth/auth.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/auth/auth/auth.component.scss
--------------------------------------------------------------------------------
/src/app/auth/auth/auth.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { AuthComponent } from './auth.component';
4 |
5 | describe('AuthComponent', () => {
6 | let component: AuthComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ AuthComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(AuthComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/auth/auth/auth.component.ts:
--------------------------------------------------------------------------------
1 | import { Component } from '@angular/core';
2 | import { FormioAuthComponent, FormioAuthService } from '@formio/angular/auth';
3 | @Component({
4 | selector: 'app-auth',
5 | templateUrl: './auth.component.html',
6 | styleUrls: ['./auth.component.scss']
7 | })
8 | export class AuthComponent extends FormioAuthComponent {
9 | constructor(public service: FormioAuthService) {
10 | super();
11 | }
12 | }
13 |
--------------------------------------------------------------------------------
/src/app/auth/login/login.component.html:
--------------------------------------------------------------------------------
1 |
2 |
You can use the following to login.
3 |
4 | Email: demo@form.io
5 | Password: testing
6 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/src/app/auth/login/login.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/auth/login/login.component.scss
--------------------------------------------------------------------------------
/src/app/auth/login/login.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { LoginComponent } from './login.component';
4 |
5 | describe('LoginComponent', () => {
6 | let component: LoginComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ LoginComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(LoginComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/auth/login/login.component.ts:
--------------------------------------------------------------------------------
1 | import { Component } from '@angular/core';
2 | import { FormioAuthLoginComponent, FormioAuthService } from '@formio/angular/auth';
3 | @Component({
4 | selector: 'app-login',
5 | templateUrl: './login.component.html',
6 | styleUrls: ['./login.component.scss']
7 | })
8 | export class LoginComponent extends FormioAuthLoginComponent {
9 | constructor(public service: FormioAuthService) {
10 | super(service);
11 | }
12 | }
13 |
--------------------------------------------------------------------------------
/src/app/components/CheckMatrix.js:
--------------------------------------------------------------------------------
1 | /**
2 | * This file shows how to create a custom component and register that within an Angular application.
3 | *
4 | * Get the base component class by referencing Formio.Components.components map.
5 | */
6 | import { Formio } from '@formio/angular';
7 | const Base = (Formio as any).Components.components.component;
8 | const editForm = (Formio as any).Components.components.table.editForm;
9 | const Components = (Formio as any).Components;
10 |
11 | /**
12 | * Create a new CheckMatrixComponent "class" using ES5 class inheritance notation.
13 | * https://developer.mozilla.org/en-US/docs/Learn/JavaScript/Objects/Inheritance
14 | *
15 | * Here we will derive from the base component which all Form.io form components derive from.
16 | *
17 | * @param component
18 | * @param options
19 | * @param data
20 | * @constructor
21 | */
22 | export default class CheckMatrix extends Base {
23 | constructor(component, options, data) {
24 | super(component, options, data);
25 | }
26 |
27 | static schema() {
28 | return Base.schema({
29 | type: 'checkmatrix',
30 | numRows: 3,
31 | numCols: 3
32 | });
33 | }
34 |
35 | static builderInfo = {
36 | title: 'Check Matrix',
37 | group: 'basic',
38 | icon: 'fa fa-table',
39 | weight: 70,
40 | documentation: 'http://help.form.io/userguide/#table',
41 | schema: CheckMatrix.schema()
42 | }
43 |
44 | static editForm = editForm
45 |
46 | /**
47 | * Render returns an html string of the fully rendered component.
48 | *
49 | * @param children - If this class is extendended, the sub string is passed as children.
50 | * @returns {string}
51 | */
52 | render(children) {
53 | // To make this dynamic, we could call this.renderTemplate('templatename', {}).
54 |
55 | let tableClass = 'table ';
56 | ['striped', 'bordered', 'hover', 'condensed'].forEach((prop) => {
57 | if (this.component[prop]) {
58 | tableClass += `table-${prop} `;
59 | }
60 | });
61 |
62 | let content = '';
63 |
64 | for (let i = 0; i < this.component.numRows; i++) {
65 | let row = '';
66 | for (let j = 0; j < this.component.numCols; j++) {
67 | let cell = '';
68 |
69 | cell += this.renderTemplate('input', {
70 | input: {
71 | type: 'input',
72 | ref: `${this.component.key}-${i}`,
73 | attr: {
74 | id: `${this.component.key}-${i}-${j}`,
75 | class: 'form-control',
76 | type: 'checkbox',
77 | }
78 | }
79 | });
80 |
81 | cell += ' ';
82 | row += cell;
83 | }
84 | row += ' ';
85 | content += row;
86 | }
87 |
88 | // Calling super.render will wrap it html as a component.
89 | return super.render(`
90 |
91 |
92 | ${content}
93 |
94 |
95 | `);
96 | }
97 |
98 | /**
99 | * After the html string has been mounted into the dom, the dom element is returned here. Use refs to find specific
100 | * elements to attach functionality to.
101 | *
102 | * @param element
103 | * @returns {Promise}
104 | */
105 | attach(element) {
106 | const refs = {};
107 |
108 | for (let i = 0; i < this.component.numRows; i++) {
109 | refs[`${this.component.key}-${i}`] = 'multiple';
110 | }
111 |
112 | this.loadRefs(element, refs);
113 |
114 | this.checks = [];
115 | for (let i = 0; i < this.component.numRows; i++) {
116 | this.checks[i] = Array.prototype.slice.call(this.refs[`${this.component.key}-${i}`], 0);
117 |
118 | // Attach click events to each input in the row
119 | this.checks[i].forEach(input => {
120 | this.addEventListener(input, 'click', () => this.updateValue())
121 | });
122 | }
123 |
124 | // Allow basic component functionality to attach like field logic and tooltips.
125 | return super.attach(element);
126 | }
127 |
128 | /**
129 | * Get the value of the component from the dom elements.
130 | *
131 | * @returns {Array}
132 | */
133 | getValue() {
134 | var value = [];
135 | for (var rowIndex in this.checks) {
136 | var row = this.checks[rowIndex];
137 | value[rowIndex] = [];
138 | for (var colIndex in row) {
139 | var col = row[colIndex];
140 | value[rowIndex][colIndex] = !!col.checked;
141 | }
142 | }
143 | return value;
144 | }
145 |
146 | /**
147 | * Set the value of the component into the dom elements.
148 | *
149 | * @param value
150 | * @returns {boolean}
151 | */
152 | setValue(value) {
153 | if (!value) {
154 | return;
155 | }
156 | for (var rowIndex in this.checks) {
157 | var row = this.checks[rowIndex];
158 | if (!value[rowIndex]) {
159 | break;
160 | }
161 | for (var colIndex in row) {
162 | var col = row[colIndex];
163 | if (!value[rowIndex][colIndex]) {
164 | return false;
165 | }
166 | let checked = value[rowIndex][colIndex] ? 1 : 0;
167 | col.value = checked;
168 | col.checked = checked;
169 | }
170 | }
171 | }
172 | }
173 |
174 | // Use the table component edit form.
175 | CheckMatrix.editForm = editForm;
176 |
177 | // Register the component to the Formio.Components registry.
178 | Components.addComponent('checkmatrix', CheckMatrix);
179 |
--------------------------------------------------------------------------------
/src/app/config.ts:
--------------------------------------------------------------------------------
1 | export const AppConfig = {
2 | appUrl: 'https://example.form.io',
3 | apiUrl: 'https://api.form.io'
4 | };
5 |
--------------------------------------------------------------------------------
/src/app/data/data.component.html:
--------------------------------------------------------------------------------
1 | Data Tables
2 | The data table is provided through the FormioGridModule
, and provides you a way to easily embed a data table within your application with the following code.
3 | <formio-grid src="https://examples.form.io/company"></formio-grid>
4 | Data Table Documentation
5 |
6 |
--------------------------------------------------------------------------------
/src/app/data/data.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/data/data.component.scss
--------------------------------------------------------------------------------
/src/app/data/data.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { DataComponent } from './data.component';
4 |
5 | describe('DataComponent', () => {
6 | let component: DataComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ DataComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(DataComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/data/data.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, AfterViewInit, ViewEncapsulation } from '@angular/core';
2 | import { FormioAppConfig } from '@formio/angular';
3 | import { FormioAuthService } from '@formio/angular/auth';
4 | import SubmissionComponents from './submission/index';
5 | import { PrismService } from '../Prism.service';
6 | @Component({
7 | selector: 'app-data',
8 | templateUrl: './data.component.html',
9 | styleUrls: ['./data.component.scss'],
10 | encapsulation: ViewEncapsulation.None
11 | })
12 | export class DataComponent implements AfterViewInit {
13 |
14 | public components = SubmissionComponents;
15 |
16 | constructor(
17 | public auth: FormioAuthService,
18 | public config: FormioAppConfig,
19 | public prism: PrismService
20 | ) {}
21 |
22 | ngAfterViewInit() {
23 | this.prism.init();
24 | }
25 | }
26 |
--------------------------------------------------------------------------------
/src/app/data/submission/SubmissionGridHeader.component.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | Custom
6 |
7 | {{ header.label }}
8 |
9 |
10 |
11 |
12 |
13 |
--------------------------------------------------------------------------------
/src/app/data/submission/SubmissionGridHeader.component.ts:
--------------------------------------------------------------------------------
1 | import { Component } from "@angular/core";
2 | import { SubmissionGridHeaderComponent } from "@formio/angular/grid";
3 |
4 | @Component({
5 | templateUrl: './SubmissionGridHeader.component.html'
6 | })
7 | export class CustomSubmissionGridHeaderComponent extends SubmissionGridHeaderComponent {}
8 |
--------------------------------------------------------------------------------
/src/app/data/submission/index.ts:
--------------------------------------------------------------------------------
1 | import { SubmissionGridBodyComponent, SubmissionGridFooterComponent } from "@formio/angular/grid";
2 | import { CustomSubmissionGridHeaderComponent } from "./SubmissionGridHeader.component";
3 |
4 | export default {
5 | header: CustomSubmissionGridHeaderComponent,
6 | body: SubmissionGridBodyComponent,
7 | footer: SubmissionGridFooterComponent
8 | };
9 |
--------------------------------------------------------------------------------
/src/app/event/event.module.spec.ts:
--------------------------------------------------------------------------------
1 | import { EventModule } from './event.module';
2 |
3 | describe('EventModule', () => {
4 | let eventModule: EventModule;
5 |
6 | beforeEach(() => {
7 | eventModule = new EventModule();
8 | });
9 |
10 | it('should create an instance', () => {
11 | expect(eventModule).toBeTruthy();
12 | });
13 | });
14 |
--------------------------------------------------------------------------------
/src/app/event/event.module.ts:
--------------------------------------------------------------------------------
1 | import { NgModule } from '@angular/core';
2 | import { CommonModule } from '@angular/common';
3 | import { ResourceComponent } from './resource/resource.component';
4 | import { ViewComponent } from './view/view.component';
5 | import { RouterModule } from '@angular/router';
6 | import { FormioModule } from '@formio/angular';
7 | import {
8 | FormioResource,
9 | FormioResourceConfig,
10 | FormioResourceService,
11 | FormioResourceIndexComponent,
12 | FormioResourceCreateComponent,
13 | FormioResourceEditComponent,
14 | FormioResourceDeleteComponent
15 | } from '@formio/angular/resource';
16 |
17 | @NgModule({
18 | imports: [
19 | CommonModule,
20 | FormioModule,
21 | FormioResource,
22 | RouterModule.forChild([
23 | {
24 | path: '',
25 | component: FormioResourceIndexComponent
26 | },
27 | {
28 | path: 'new',
29 | component: FormioResourceCreateComponent
30 | },
31 | {
32 | path: ':id',
33 | component: ResourceComponent,
34 | children: [
35 | {
36 | path: '',
37 | redirectTo: 'view',
38 | pathMatch: 'full'
39 | },
40 | {
41 | path: 'view',
42 | component: ViewComponent
43 | },
44 | {
45 | path: 'edit',
46 | component: FormioResourceEditComponent
47 | },
48 | {
49 | path: 'delete',
50 | component: FormioResourceDeleteComponent
51 | },
52 | {
53 | path: 'participant',
54 | loadChildren: () => import('./participant/participant.module').then(x => x.ParticipantModule)
55 | }
56 | ]
57 | }
58 | ])
59 | ],
60 | declarations: [ResourceComponent, ViewComponent],
61 | providers: [
62 | FormioResourceService,
63 | {
64 | provide: FormioResourceConfig,
65 | useValue: {
66 | name: 'event',
67 | form: 'event'
68 | }
69 | }
70 | ]
71 | })
72 | export class EventModule { }
73 |
--------------------------------------------------------------------------------
/src/app/event/participant/participant.module.spec.ts:
--------------------------------------------------------------------------------
1 | import { ParticipantModule } from './participant.module';
2 |
3 | describe('ParticipantModule', () => {
4 | let participantModule: ParticipantModule;
5 |
6 | beforeEach(() => {
7 | participantModule = new ParticipantModule();
8 | });
9 |
10 | it('should create an instance', () => {
11 | expect(participantModule).toBeTruthy();
12 | });
13 | });
14 |
--------------------------------------------------------------------------------
/src/app/event/participant/participant.module.ts:
--------------------------------------------------------------------------------
1 | import { NgModule } from '@angular/core';
2 | import { CommonModule } from '@angular/common';
3 | import { RouterModule } from '@angular/router';
4 | import { FormioModule } from '@formio/angular';
5 | import {
6 | FormioResource,
7 | FormioResourceRoutes,
8 | FormioResourceConfig,
9 | FormioResourceService
10 | } from '@formio/angular/resource';
11 |
12 | @NgModule({
13 | imports: [
14 | CommonModule,
15 | FormioModule,
16 | FormioResource,
17 | RouterModule.forChild(FormioResourceRoutes())
18 | ],
19 | declarations: [],
20 | providers: [
21 | FormioResourceService,
22 | {
23 | provide: FormioResourceConfig,
24 | useValue: {
25 | name: 'participant',
26 | form: 'participant',
27 | parents: [
28 | 'event',
29 | {
30 | field: 'user',
31 | resource: 'currentUser',
32 | filter: false
33 | }
34 | ]
35 | }
36 | }
37 | ]
38 | })
39 | export class ParticipantModule { }
40 |
--------------------------------------------------------------------------------
/src/app/event/resource/resource.component.html:
--------------------------------------------------------------------------------
1 |
8 |
9 |
--------------------------------------------------------------------------------
/src/app/event/resource/resource.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/event/resource/resource.component.scss
--------------------------------------------------------------------------------
/src/app/event/resource/resource.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { ResourceComponent } from './resource.component';
4 |
5 | describe('ResourceComponent', () => {
6 | let component: ResourceComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ ResourceComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(ResourceComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/event/resource/resource.component.ts:
--------------------------------------------------------------------------------
1 | import { Component } from '@angular/core';
2 | import { FormioResourceComponent } from '@formio/angular/resource';
3 |
4 | @Component({
5 | selector: 'app-resource',
6 | templateUrl: './resource.component.html',
7 | styleUrls: ['./resource.component.scss']
8 | })
9 | export class ResourceComponent extends FormioResourceComponent {}
10 |
--------------------------------------------------------------------------------
/src/app/event/view/view.component.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
7 |
8 |
{{ service.resource?.data.title }}
9 |
10 |
11 |
12 |
13 |
23 |
24 |
--------------------------------------------------------------------------------
/src/app/event/view/view.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/event/view/view.component.scss
--------------------------------------------------------------------------------
/src/app/event/view/view.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { ViewComponent } from './view.component';
4 |
5 | describe('ViewComponent', () => {
6 | let component: ViewComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ ViewComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(ViewComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/event/view/view.component.ts:
--------------------------------------------------------------------------------
1 | import { Component } from '@angular/core';
2 | import { FormioResourceViewComponent } from '@formio/angular/resource';
3 |
4 | @Component({
5 | selector: 'app-view',
6 | templateUrl: './view.component.html',
7 | styleUrls: ['./view.component.scss']
8 | })
9 | export class ViewComponent extends FormioResourceViewComponent {}
10 |
--------------------------------------------------------------------------------
/src/app/form/form.module.spec.ts:
--------------------------------------------------------------------------------
1 | import { FormModule } from './form.module';
2 |
3 | describe('FormModule', () => {
4 | let formModule: FormModule;
5 |
6 | beforeEach(() => {
7 | formModule = new FormModule();
8 | });
9 |
10 | it('should create an instance', () => {
11 | expect(formModule).toBeTruthy();
12 | });
13 | });
14 |
--------------------------------------------------------------------------------
/src/app/form/form.module.ts:
--------------------------------------------------------------------------------
1 | import { NgModule } from '@angular/core';
2 | import { CommonModule } from '@angular/common';
3 | import { RouterModule } from '@angular/router';
4 | import { FormioGrid } from '@formio/angular/grid';
5 | import { FormManagerModule, FormManagerRoutes, FormManagerService, FormManagerConfig } from '@formio/angular/manager';
6 | import { IndexComponent } from './index/index.component';
7 |
8 | @NgModule({
9 | imports: [
10 | CommonModule,
11 | FormioGrid,
12 | FormManagerModule,
13 | RouterModule.forChild(FormManagerRoutes({
14 | formIndex: IndexComponent
15 | }))
16 | ],
17 | declarations: [
18 | IndexComponent
19 | ],
20 | providers: [
21 | FormManagerService,
22 | {provide: FormManagerConfig, useValue: {
23 | tag: 'common'
24 | }}
25 | ]
26 | })
27 | export class FormModule { }
28 |
--------------------------------------------------------------------------------
/src/app/form/index/index.component.html:
--------------------------------------------------------------------------------
1 | You must Login to use the Form Manager.
2 |
12 |
--------------------------------------------------------------------------------
/src/app/form/index/index.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/form/index/index.component.scss
--------------------------------------------------------------------------------
/src/app/form/index/index.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { IndexComponent } from './index.component';
4 |
5 | describe('IndexComponent', () => {
6 | let component: IndexComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ IndexComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(IndexComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/form/index/index.component.ts:
--------------------------------------------------------------------------------
1 | import { Component } from '@angular/core';
2 | import { Router, ActivatedRoute } from '@angular/router';
3 | import { FormManagerIndexComponent, FormManagerService, FormManagerConfig } from '@formio/angular/manager';
4 | import { FormioAuthService } from '@formio/angular/auth';
5 |
6 | @Component({
7 | selector: 'app-index',
8 | templateUrl: './index.component.html',
9 | styleUrls: ['./index.component.scss']
10 | })
11 | export class IndexComponent extends FormManagerIndexComponent {
12 | constructor(
13 | public auth: FormioAuthService,
14 | public service: FormManagerService,
15 | public route: ActivatedRoute,
16 | public router: Router,
17 | public config: FormManagerConfig
18 | ) {
19 | super(service, route, router, config);
20 | }
21 | }
22 |
--------------------------------------------------------------------------------
/src/app/forms/builder/builder.component.html:
--------------------------------------------------------------------------------
1 | Dynamic JSON Form Builder
2 | The Form.io form builder interface allows you to embed a form builder within your application, which generates a JSON schema of the form created.
3 | Builder Documentation
4 | builder.html
5 | <form-builder [form]="form" (change)="onChange($event)"></form-builder>
6 | builder.ts
7 | import { Component, ElementRef, ViewChild } from '@angular/core';
8 | @Component({
9 | template: require('./builder.html')
10 | })
11 | export class BuilderComponent {
12 | @ViewChild('json') jsonElement?: ElementRef;
13 | public form: Object = {components: []};
14 | onChange(event) {
15 | console.log(event.form);
16 | }
17 | }
18 |
19 |
20 | As JSON Schema
21 |
24 | As Rendered Form
25 |
26 |
27 |
28 |
--------------------------------------------------------------------------------
/src/app/forms/builder/builder.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/forms/builder/builder.component.scss
--------------------------------------------------------------------------------
/src/app/forms/builder/builder.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { BuilderComponent } from './builder.component';
4 |
5 | describe('BuilderComponent', () => {
6 | let component: BuilderComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ BuilderComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(BuilderComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/forms/builder/builder.component.ts:
--------------------------------------------------------------------------------
1 | import { FormioRefreshValue } from '@formio/angular';
2 | import { Component, AfterViewInit, ViewChild, ElementRef, EventEmitter } from '@angular/core';
3 | import { PrismService } from '../../Prism.service';
4 |
5 | @Component({
6 | selector: 'app-builder',
7 | templateUrl: './builder.component.html',
8 | styleUrls: ['./builder.component.scss']
9 | })
10 | export class BuilderComponent implements AfterViewInit {
11 | @ViewChild('json', {static: true}) jsonElement?: ElementRef;
12 | @ViewChild('code', {static: true}) codeElement?: ElementRef;
13 | public form: Object;
14 | public refreshForm: EventEmitter = new EventEmitter();
15 | constructor(public prism: PrismService) {
16 | this.form = {components: []};
17 | }
18 |
19 | onChange(event) {
20 | this.jsonElement.nativeElement.innerHTML = '';
21 | this.jsonElement.nativeElement.appendChild(document.createTextNode(JSON.stringify(event.form, null, 4)));
22 | this.refreshForm.emit({
23 | property: 'form',
24 | value: event.form
25 | });
26 | }
27 |
28 | ngAfterViewInit() {
29 | this.prism.init();
30 | }
31 | }
32 |
--------------------------------------------------------------------------------
/src/app/forms/custom-builder/builder.component.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
The Form.io form builder interface allows you to embed a form builder within your application, which generates a JSON schema of the form created.
4 |
Builder Documentation
5 |
6 | One of the features of builder that user can change different options.
7 | For example language. Options can be provided via [options]
property.
8 |
9 |
10 |
<form-builder [form]="form" [options]="options"></form-builder>
11 |
12 |
Options can be look like:
13 |
14 |
exprort const options = {
15 | language: 'en',
16 | i18n: {
17 | jp: {
18 | 'Label': 'ラベル',
19 | 'Label Position': 'ラベルの位置',
20 | 'Placeholder': 'プレースホルダー',
21 | 'Description': '説明文'
22 | }
23 | }
24 | }
25 |
26 |
27 |
Also builder can be updated with the new options via
28 |
29 | [rebuild]
30 |
31 |
32 |
33 |
<form-builder [form]="form" [options]="options" [rebuild]="rebuildEmitter.asObservable()"
34 |
35 |
36 | Rebuid emitter can be Observable and used to set the new options like this:
37 |
38 |
39 |
this.rebuildEmitter.next(this.options)
40 |
41 |
42 |
43 |
44 | English
45 | 日本語
46 |
47 |
48 |
49 | As JSON Schema
50 |
53 |
--------------------------------------------------------------------------------
/src/app/forms/custom-builder/builder.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, AfterViewInit, ViewChild, ElementRef } from '@angular/core';
2 | import { PrismService } from '../../Prism.service';
3 | import { options } from './options';
4 | import {Observable, Subject} from "rxjs";
5 |
6 | @Component({
7 | selector: 'app-builder',
8 | templateUrl: './builder.component.html',
9 | })
10 | export class CustomBuilderComponent implements AfterViewInit {
11 | @ViewChild('json', {static: true}) jsonElement?: ElementRef;
12 | @ViewChild('code', {static: true}) codeElement?: ElementRef;
13 | public form: Object;
14 | public options: any;
15 | public language: string;
16 | public rebuildEmitter: Subject = new Subject();
17 |
18 | constructor(public prism: PrismService) {
19 | this.options = options;
20 | this.form = {components: []};
21 | }
22 |
23 | onChange(event) {
24 | this.jsonElement.nativeElement.innerHTML = '';
25 | this.jsonElement.nativeElement.appendChild(document.createTextNode(JSON.stringify(event.form, null, 4)));
26 | }
27 |
28 | ngAfterViewInit() {
29 | this.prism.init();
30 | }
31 |
32 | changeLanguage(language: string) {
33 | this.language = language;
34 | this.options.language = this.language;
35 | this.rebuildEmitter.next(this.options);
36 | }
37 | }
38 |
--------------------------------------------------------------------------------
/src/app/forms/custom-builder/options.ts:
--------------------------------------------------------------------------------
1 | export const options = {
2 | builder: {
3 | basic: false,
4 | data: false,
5 | premium: false,
6 | customBasic: {
7 | title: 'Basic Components',
8 | default: true,
9 | weight: 0,
10 | components: {
11 | textfield: true,
12 | textarea: true,
13 | email: true
14 | }
15 | },
16 | advanced: {
17 | components: {
18 | email: false,
19 | url: false,
20 | tags: false,
21 | address: false,
22 | survey: false,
23 | currency: false,
24 | signature: false,
25 | day: false,
26 | phoneNumber: false,
27 | datetime: false
28 | }
29 | },
30 | layout: {
31 | title: 'Layout Components',
32 | weight: 0,
33 | components: {
34 | panel: true,
35 | table: false,
36 | tabs: false,
37 | well: false,
38 | columns: false,
39 | fieldset: false,
40 | content: false,
41 | htmlelement: false
42 | }
43 | }
44 | },
45 | language: 'en',
46 | i18n: {
47 | jp: {
48 | 'Label': 'ラベル',
49 | 'Label Position': 'ラベルの位置',
50 | 'Placeholder': 'プレースホルダー',
51 | 'Description': '説明文',
52 | 'Tooltip': 'ツールチップ',
53 | 'Prefix': '接頭辞',
54 | 'Suffix': 'サフィックス',
55 | 'Widget': 'ウィジェット',
56 | 'Input Mask': '定型入力',
57 | 'Custom CSS Class': 'カスタムCSSクラス',
58 | 'Tab Index': 'タブインデックス',
59 | 'Hidden ': '隠された',
60 | 'Hide Label': 'ラベルを非表示',
61 | 'Show Word Counter': 'ワードカウンターを表示',
62 | 'Show Character Counter': 'キャラクターカウンターを表示',
63 | 'Hide Input': '入力を非表示',
64 | 'Excellent': 'Excelente',
65 | 'Initial Focus': '最初の焦点',
66 | 'Allow Spellcheck': 'スペルチェックを許可',
67 | 'Disabled': '無効',
68 | 'Table View': 'テーブルビュー',
69 | 'Modal Edit': 'モーダル編集',
70 | 'Multiple Values': '複数の値',
71 | 'Persistent': '持続的',
72 | 'Input Format': '入力フォーマット',
73 | 'Protected': '保護された',
74 | 'Database Index': 'データベースインデックス',
75 | 'Mixed (Allow upper and lower case)': '混合(大文字と小文字を許可)',
76 | 'Uppercase': '大文字',
77 | 'Lowercase': '小文字',
78 | 'Encrypted (Enterprise Only)': '暗号化(エンタープライズのみ)',
79 | 'Default Value': 'デフォルト値',
80 | 'Drag and Drop a form component': 'フォームコンポーネントをドラッグアンドドロップする',
81 | 'Text Field': 'テキストフィールド',
82 | 'Email': '電子メイル',
83 | 'Text Area': 'テキスト領域',
84 | 'Panel': 'パネル',
85 | 'Time': '時間',
86 | 'Submit': '参加する',
87 | 'Basic Components': '基本的なコンポーネント',
88 | 'Layout Components': 'レイアウトコンポーネント',
89 | 'Advanced': '高度な',
90 | 'Hidden': '隠された',
91 | 'Component': '成分',
92 | 'Display': '表示',
93 | 'Data': 'データ',
94 | 'Validation': '検証',
95 | 'API': 'アプリケーションプログラミングインターフェース',
96 | 'Conditional': '条件付き',
97 | 'Logic': '論理',
98 | 'Layout': 'レイアウト',
99 | 'Allow Multiple Masks': '複数のマスクを許可',
100 | 'Input Field': '入力フィールド',
101 | 'Top': '上',
102 | 'Input Type': '入力方式',
103 | 'Collapsible': '折りたたみ',
104 | 'Preview': 'プレビュー',
105 | 'Text Case': 'テキストケース',
106 | 'Redraw On': '再描画',
107 | 'Clear Value When Hidden': '非表示のときに値をクリア',
108 | 'Custom Default Value': 'カスタムデフォルト値',
109 | 'Calculated Value': '計算値',
110 | 'Calculate Value on server': 'サーバーで値を計算する',
111 | 'Allow Manual Override of Calculated Value': '計算値の手動オーバーライドを許可',
112 | 'Server': 'サーバ',
113 | 'Client': 'クライアント',
114 | 'None': '無し',
115 | 'Validate On': '検証',
116 | 'Required': '必須',
117 | 'Unique': 'ユニークな',
118 | 'Minimum Length': '最小の長さ',
119 | 'Maximum Length': '最大長',
120 | 'Minimum Word Length': '最小語長',
121 | 'Maximum Word Length': '最大語長',
122 | 'Regular Expression Pattern': '正規表現パターン',
123 | 'Error Label': 'エラーラベル',
124 | 'Custom Error Message': 'カスタムエラーメッセージ',
125 | 'Custom Validation': 'カスタム検証',
126 | 'JSONLogic Validation': 'JSONLogic検証',
127 | 'Property Name': 'プロパティ名',
128 | 'Field Tags': 'フィールドタグ',
129 | 'Custom Properties': 'カスタムプロパティ',
130 | 'Add Another': 'さらに追加',
131 | 'Save': 'セーブ',
132 | 'Cancel': 'キャンセル',
133 | 'Remove': '削除する',
134 | 'Rows': '行',
135 | 'Title': '題名',
136 | 'Theme': 'テーマ',
137 | 'Data Format': 'データフォーマット',
138 | 'Advanced Logic': '高度なロジック',
139 | 'Advanced Conditions': '高度な条件',
140 | 'Simple': 'シンプルな',
141 | 'HTML Attributes': 'HTML属性',
142 | 'PDF Overlay': 'PDFオーバーレイ'
143 | }
144 | }
145 | };
146 |
--------------------------------------------------------------------------------
/src/app/forms/forms.index.ts:
--------------------------------------------------------------------------------
1 | import { LanguageComponent } from './language/language.component';
2 | import { BuilderComponent } from './builder/builder.component';
3 | import { SimpleComponent } from './simple/simple.component';
4 | import { RendererComponent } from './renderer/renderer.component';
5 | import { WizardComponent } from './wizard/wizard.component';
6 | import { PdfComponent } from './pdf/pdf.component';
7 | import {CustomBuilderComponent} from "./custom-builder/builder.component";
8 | export const FORMS: any = [
9 | {
10 | path: '',
11 | redirectTo: 'renderer',
12 | pathMatch: 'full'
13 | },
14 | {
15 | path: 'renderer',
16 | title: 'Form Renderer',
17 | component: RendererComponent
18 | },
19 | {
20 | path: 'builder',
21 | title: 'Form Builder',
22 | component: BuilderComponent
23 | },
24 | {
25 | path: 'custom-builder',
26 | title: 'Custom Builder',
27 | component: CustomBuilderComponent
28 | },
29 | {
30 | path: 'simple',
31 | title: 'Simple Form',
32 | component: SimpleComponent
33 | },
34 | {
35 | path: 'wizard',
36 | title: 'Wizard Form',
37 | component: WizardComponent
38 | },
39 | {
40 | path: 'pdf',
41 | title: 'PDF Form',
42 | component: PdfComponent
43 | },
44 | {
45 | path: 'language',
46 | title: 'Multi-Language',
47 | component: LanguageComponent
48 | }
49 | ];
50 |
--------------------------------------------------------------------------------
/src/app/forms/forms.module.spec.ts:
--------------------------------------------------------------------------------
1 | import { FormsModule } from './forms.module';
2 |
3 | describe('FormsModule', () => {
4 | let formsModule: FormsModule;
5 |
6 | beforeEach(() => {
7 | formsModule = new FormsModule();
8 | });
9 |
10 | it('should create an instance', () => {
11 | expect(formsModule).toBeTruthy();
12 | });
13 | });
14 |
--------------------------------------------------------------------------------
/src/app/forms/forms.module.ts:
--------------------------------------------------------------------------------
1 | import { NgModule } from '@angular/core';
2 | import { RouterModule } from '@angular/router';
3 | import { CommonModule } from '@angular/common';
4 | import { FormioModule } from '@formio/angular';
5 | import { BuilderComponent } from './builder/builder.component';
6 | import {CustomBuilderComponent} from './custom-builder/builder.component';
7 | import { KitchenComponent } from './kitchen/kitchen.component';
8 | import { LanguageComponent } from './language/language.component';
9 | import { PdfComponent } from './pdf/pdf.component';
10 | import { RendererComponent } from './renderer/renderer.component';
11 | import { SimpleComponent } from './simple/simple.component';
12 | import { WizardComponent } from './wizard/wizard.component';
13 | import { FormsComponent } from './forms/forms.component';
14 | import { FORMS } from './forms.index';
15 |
16 | @NgModule({
17 | imports: [
18 | CommonModule,
19 | FormioModule,
20 | RouterModule.forChild([{
21 | path: '',
22 | component: FormsComponent,
23 | children: FORMS
24 | }])
25 | ],
26 | declarations: [
27 | CustomBuilderComponent,
28 | BuilderComponent,
29 | KitchenComponent,
30 | LanguageComponent,
31 | PdfComponent,
32 | RendererComponent,
33 | SimpleComponent,
34 | WizardComponent,
35 | FormsComponent
36 | ],
37 | bootstrap: [
38 | FormsComponent
39 | ]
40 | })
41 | export class FormsModule { }
42 |
--------------------------------------------------------------------------------
/src/app/forms/forms/forms.component.html:
--------------------------------------------------------------------------------
1 |
13 |
--------------------------------------------------------------------------------
/src/app/forms/forms/forms.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/forms/forms/forms.component.scss
--------------------------------------------------------------------------------
/src/app/forms/forms/forms.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { FormsComponent } from './forms.component';
4 |
5 | describe('FormsComponent', () => {
6 | let component: FormsComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ FormsComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(FormsComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/forms/forms/forms.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, OnInit } from '@angular/core';
2 | import { FORMS } from '../forms.index';
3 |
4 | @Component({
5 | selector: 'app-forms',
6 | templateUrl: './forms.component.html',
7 | styleUrls: ['./forms.component.scss']
8 | })
9 | export class FormsComponent implements OnInit {
10 | public forms: any[];
11 | constructor() {
12 | this.forms = FORMS.filter((item: any) => {
13 | return !!item.path;
14 | });
15 | }
16 |
17 | ngOnInit() {
18 | }
19 | }
20 |
--------------------------------------------------------------------------------
/src/app/forms/kitchen/form.ts:
--------------------------------------------------------------------------------
1 | export const FORM: any = {
2 | title: 'Registration Form',
3 | components: [
4 | {
5 | input: true,
6 | tree: true,
7 | components: [
8 | {
9 | input: false,
10 | columns: [
11 | {
12 | components: [
13 | {
14 | input: true,
15 | tableView: true,
16 | inputType: 'text',
17 | inputMask: '',
18 | label: 'First Name',
19 | key: 'firstName',
20 | placeholder: 'Enter your first name',
21 | prefix: '',
22 | suffix: '',
23 | multiple: false,
24 | defaultValue: '',
25 | protected: false,
26 | unique: false,
27 | persistent: true,
28 | validate: {
29 | required: false,
30 | minLength: 6,
31 | maxLength: 10,
32 | pattern: '',
33 | custom: '',
34 | customPrivate: false
35 | },
36 | conditional: {
37 | show: '',
38 | when: null,
39 | eq: ''
40 | },
41 | type: 'textfield'
42 | },
43 | {
44 | type: 'email',
45 | persistent: true,
46 | unique: false,
47 | protected: false,
48 | defaultValue: '',
49 | suffix: '',
50 | prefix: '',
51 | placeholder: 'Enter your email address',
52 | key: 'email',
53 | label: 'Email',
54 | inputType: 'email',
55 | tableView: true,
56 | input: true
57 | },
58 | {
59 | input: true,
60 | inputType: 'checkbox',
61 | tableView: true,
62 | hideLabel: true,
63 | label: 'Do you have a phone number?',
64 | key: 'havePhoneNumber',
65 | defaultValue: false,
66 | protected: false,
67 | persistent: true,
68 | validate: {
69 | required: false
70 | },
71 | type: 'checkbox',
72 | conditional: {
73 | show: '',
74 | when: null,
75 | eq: ''
76 | },
77 | lockKey: true
78 | },
79 | {
80 | input: true,
81 | tableView: true,
82 | inputMask: '(999) 999-9999',
83 | label: 'Phone Number',
84 | key: 'phoneNumber',
85 | placeholder: '',
86 | prefix: '',
87 | suffix: '',
88 | multiple: false,
89 | protected: false,
90 | unique: false,
91 | persistent: true,
92 | defaultValue: '',
93 | validate: {
94 | required: false
95 | },
96 | type: 'phoneNumber',
97 | conditional: {
98 | show: 'true',
99 | when: 'havePhoneNumber',
100 | eq: 'true'
101 | }
102 | }
103 | ]
104 | },
105 | {
106 | components: [
107 | {
108 | input: true,
109 | tableView: true,
110 | inputType: 'text',
111 | inputMask: '',
112 | label: 'Last Name',
113 | key: 'lastName',
114 | placeholder: 'Enter your last name',
115 | prefix: '',
116 | suffix: '',
117 | multiple: false,
118 | defaultValue: '',
119 | protected: false,
120 | unique: false,
121 | persistent: true,
122 | validate: {
123 | required: false,
124 | minLength: 2,
125 | maxLength: 10,
126 | pattern: '',
127 | custom: '',
128 | customPrivate: false
129 | },
130 | conditional: {
131 | show: '',
132 | when: null,
133 | eq: ''
134 | },
135 | type: 'textfield'
136 | },
137 | {
138 | input: true,
139 | tableView: true,
140 | inputType: 'number',
141 | inputMask: '',
142 | label: 'Number',
143 | key: 'number',
144 | placeholder: 'Enter Number',
145 | prefix: '',
146 | suffix: '',
147 | multiple: false,
148 | defaultValue: 0,
149 | protected: false,
150 | unique: false,
151 | persistent: true,
152 | validate: {
153 | required: false,
154 | min: 10,
155 | max: 100,
156 | step: 5,
157 | custom: '',
158 | customPrivate: false
159 | },
160 | conditional: {
161 | show: '',
162 | when: null,
163 | eq: ''
164 | },
165 | type: 'number'
166 | },
167 | {
168 | input: true,
169 | tableView: false,
170 | inputType: 'password',
171 | label: 'Password',
172 | key: 'password',
173 | placeholder: 'Enter Your Password',
174 | prefix: '$',
175 | suffix: '@',
176 | defaultValue: '',
177 | protected: true,
178 | persistent: true,
179 | type: 'password',
180 | conditional: {
181 | show: null,
182 | when: null,
183 | eq: ''
184 | },
185 | validate: {
186 | required: false,
187 | minLength: 8,
188 | maxLength: 20,
189 | pattern: '',
190 | custom: '',
191 | customPrivate: false
192 | },
193 | unique: true
194 | }
195 | ]
196 | }
197 | ],
198 | type: 'columns',
199 | key: 'columns',
200 | conditional: {
201 | show: '',
202 | when: null,
203 | eq: ''
204 | }
205 | },
206 | {
207 | type: 'textfield',
208 | conditional: {
209 | eq: '',
210 | when: null,
211 | show: ''
212 | },
213 | validate: {
214 | customPrivate: false,
215 | custom: '',
216 | pattern: '',
217 | maxLength: '',
218 | minLength: '',
219 | required: false
220 | },
221 | persistent: true,
222 | unique: false,
223 | protected: false,
224 | defaultValue: '',
225 | multiple: true,
226 | suffix: '',
227 | prefix: '',
228 | placeholder: 'Enter your kids names',
229 | key: 'kids',
230 | label: 'Kids',
231 | inputMask: '',
232 | inputType: 'text',
233 | tableView: true,
234 | input: true
235 | }
236 | ],
237 | tableView: true,
238 | label: '',
239 | key: 'user',
240 | protected: false,
241 | persistent: true,
242 | type: 'container',
243 | conditional: {
244 | show: '',
245 | when: null,
246 | eq: ''
247 | },
248 | lockKey: true
249 | },
250 | {
251 | input: true,
252 | tableView: true,
253 | label: 'Day',
254 | key: 'day',
255 | fields: {
256 | day: {
257 | type: 'text',
258 | placeholder: 'Enter day',
259 | required: true
260 | },
261 | month: {
262 | type: 'select',
263 | placeholder: 'Select month',
264 | required: true
265 | },
266 | year: {
267 | type: 'text',
268 | placeholder: 'Enter year',
269 | required: true
270 | }
271 | },
272 | dayFirst: true,
273 | protected: false,
274 | persistent: true,
275 | validate: {
276 | custom: ''
277 | },
278 | type: 'day',
279 | tags: [],
280 | conditional: {
281 | show: '',
282 | when: null,
283 | eq: ''
284 | },
285 | customClass: 'dayCustomClass',
286 | tabindex: '5'
287 | },
288 | {
289 | input: true,
290 | tree: true,
291 | components: [{
292 | input: true,
293 | tableView: true,
294 | inputType: 'text',
295 | inputMask: '',
296 | label: 'Make',
297 | key: 'make',
298 | placeholder: 'Chevy, Ford, etc.',
299 | prefix: '',
300 | suffix: '',
301 | multiple: false,
302 | defaultValue: '',
303 | protected: false,
304 | unique: false,
305 | persistent: true,
306 | validate: {
307 | required: false,
308 | minLength: '',
309 | maxLength: '',
310 | pattern: '',
311 | custom: '',
312 | customPrivate: false
313 | },
314 | conditional: '{"show": "", "when": null, "eq": ""}',
315 | type: 'textfield',
316 | hideLabel: true
317 | }, {
318 | input: true,
319 | tableView: true,
320 | inputType: 'text',
321 | inputMask: '',
322 | label: 'Model',
323 | key: 'model',
324 | placeholder: 'Tahoe, F-150, etc.',
325 | prefix: '',
326 | suffix: '',
327 | multiple: false,
328 | defaultValue: '',
329 | protected: false,
330 | unique: false,
331 | persistent: true,
332 | validate: {
333 | required: false,
334 | minLength: '',
335 | maxLength: '',
336 | pattern: '',
337 | custom: '',
338 | customPrivate: false
339 | },
340 | conditional: '{"show": "", "when": null, "eq": ""}',
341 | type: 'textfield',
342 | hideLabel: true
343 | }, {
344 | input: true,
345 | tableView: true,
346 | inputType: 'text',
347 | inputMask: '',
348 | label: 'Year',
349 | key: 'year',
350 | placeholder: '2014, 2015, etc',
351 | prefix: '',
352 | suffix: '',
353 | multiple: false,
354 | defaultValue: '',
355 | protected: false,
356 | unique: false,
357 | persistent: true,
358 | validate: {
359 | required: false,
360 | minLength: '',
361 | maxLength: '',
362 | pattern: '',
363 | custom: '',
364 | customPrivate: false
365 | },
366 | conditional: '{"show": "", "when": null, "eq": ""}',
367 | type: 'textfield',
368 | hideLabel: true
369 | }],
370 | tableView: true,
371 | label: 'Cars',
372 | key: 'cars',
373 | protected: false,
374 | persistent: true,
375 | type: 'datagrid',
376 | conditional: '{"show": "", "when": null, "eq": ""}',
377 | striped: true,
378 | bordered: true
379 | },
380 | {
381 | input: false,
382 | html: 'Good Morning Guys!!! This is Content component.
',
383 | type: 'content',
384 | conditional: {
385 | show: null,
386 | when: null,
387 | eq: ''
388 | },
389 | key: 'mycontent',
390 | lockKey: true
391 | },
392 | {
393 | input: false,
394 | numRows: 2,
395 | numCols: 2,
396 | rows: [
397 | [{
398 | components: [{
399 | input: true,
400 | tableView: true,
401 | inputType: 'text',
402 | inputMask: '',
403 | label: 'First Name',
404 | key: 'firstName',
405 | placeholder: 'Enter your first name',
406 | prefix: '',
407 | suffix: '',
408 | multiple: false,
409 | defaultValue: '',
410 | protected: false,
411 | unique: false,
412 | persistent: true,
413 | validate: {
414 | required: false,
415 | minLength: 6,
416 | maxLength: 10,
417 | pattern: '',
418 | custom: '',
419 | customPrivate: false
420 | },
421 | conditional: {
422 | show: '',
423 | when: null,
424 | eq: ''
425 | },
426 | type: 'textfield'
427 | }],
428 | }, {
429 | components: [{
430 | input: true,
431 | tableView: true,
432 | inputType: 'text',
433 | inputMask: '',
434 | label: 'Last Name',
435 | key: 'lastName',
436 | placeholder: 'Enter your last name',
437 | prefix: '',
438 | suffix: '',
439 | multiple: false,
440 | defaultValue: '',
441 | protected: false,
442 | unique: false,
443 | persistent: true,
444 | validate: {
445 | required: false,
446 | minLength: 6,
447 | maxLength: 10,
448 | pattern: '',
449 | custom: '',
450 | customPrivate: false
451 | },
452 | conditional: {
453 | show: '',
454 | when: null,
455 | eq: ''
456 | },
457 | type: 'textfield'
458 | }],
459 | }],
460 | [{
461 | components: [{
462 | type: 'email',
463 | persistent: true,
464 | unique: false,
465 | protected: false,
466 | defaultValue: '',
467 | suffix: '',
468 | prefix: '',
469 | placeholder: 'Enter your email address',
470 | key: 'email',
471 | label: 'Email',
472 | inputType: 'email',
473 | tableView: true,
474 | input: true
475 | }],
476 | }, {
477 | components: [{
478 | input: true,
479 | inputType: 'checkbox',
480 | tableView: false,
481 | hideLabel: true,
482 | label: 'Checkbox',
483 | key: 'checkbox',
484 | defaultValue: true,
485 | protected: false,
486 | persistent: true,
487 | validate: {
488 | required: false
489 | },
490 | type: 'checkbox',
491 | conditional: {
492 | show: null,
493 | when: null,
494 | eq: ''
495 | }
496 | }],
497 | }]
498 | ],
499 | header: [],
500 | caption: '',
501 | striped: true,
502 | bordered: true,
503 | hover: true,
504 | condensed: false,
505 | type: 'table',
506 | conditional: {
507 | show: null,
508 | when: null,
509 | eq: ''
510 | }
511 | },
512 | {
513 | input: true,
514 | tableView: true,
515 | label: 'Textarea',
516 | key: 'textarea',
517 | placeholder: 'Enter Your Text Here',
518 | prefix: '$',
519 | suffix: '@',
520 | rows: 3,
521 | multiple: false,
522 | defaultValue: '',
523 | protected: false,
524 | persistent: true,
525 | validate: {
526 | required: false,
527 | minLength: 5,
528 | maxLength: 100,
529 | pattern: '',
530 | custom: ''
531 | },
532 | type: 'textarea',
533 | conditional: {
534 | show: null,
535 | when: null,
536 | eq: ''
537 | }
538 | },
539 | {
540 | input: false,
541 | type: 'well',
542 | key: 'Well',
543 | lockKey: true,
544 | components: [{
545 | input: true,
546 | tableView: true,
547 | inputType: 'text',
548 | inputMask: '',
549 | label: 'Textfield',
550 | key: 'text',
551 | placeholder: 'Enter your text',
552 | prefix: '',
553 | suffix: '',
554 | multiple: false,
555 | defaultValue: '',
556 | protected: false,
557 | unique: false,
558 | persistent: true,
559 | validate: {
560 | required: false,
561 | minLength: 6,
562 | maxLength: 10,
563 | pattern: '',
564 | custom: '',
565 | customPrivate: false
566 | },
567 | conditional: {
568 | show: '',
569 | when: null,
570 | eq: ''
571 | },
572 | type: 'textfield'
573 | }, {
574 | input: true,
575 | tableView: true,
576 | label: 'Textarea',
577 | key: 'textarea',
578 | placeholder: 'Enter Your Text Here',
579 | prefix: '',
580 | suffix: '',
581 | rows: 3,
582 | multiple: false,
583 | defaultValue: '',
584 | protected: false,
585 | persistent: true,
586 | validate: {
587 | required: false,
588 | minLength: 5,
589 | maxLength: 100,
590 | pattern: '',
591 | custom: ''
592 | },
593 | type: 'textarea',
594 | conditional: {
595 | show: null,
596 | when: null,
597 | eq: ''
598 | }
599 | }],
600 | conditional: {
601 | show: null,
602 | when: null,
603 | eq: ''
604 | }
605 | },
606 | {
607 | input: true,
608 | tableView: true,
609 | inputType: 'radio',
610 | label: 'Options',
611 | key: 'radio',
612 | values: [
613 | {
614 | value: 'val1',
615 | label: 'option1'
616 | },
617 | {
618 | value: 'val2',
619 | label: 'option2'
620 | },
621 | {
622 | value: 'val3',
623 | label: 'option3'
624 | }
625 | ],
626 | defaultValue: true,
627 | protected: false,
628 | persistent: true,
629 | validate: {
630 | required: false,
631 | custom: '',
632 | customPrivate: false
633 | },
634 | type: 'radio',
635 | inline: false,
636 | multiple: false,
637 | conditional: {
638 | show: null,
639 | when: null,
640 | eq: ''
641 | }
642 | },
643 | {
644 | input: false,
645 | tableView: true,
646 | legend: 'User Information',
647 | type: 'fieldset',
648 | conditional: {
649 | show: null,
650 | when: null,
651 | eq: ''
652 | },
653 | components: [{
654 | input: true,
655 | tableView: true,
656 | inputType: 'text',
657 | inputMask: '',
658 | label: 'FirstName',
659 | key: 'firstName',
660 | placeholder: 'Enter FirstName',
661 | prefix: '',
662 | suffix: '',
663 | multiple: false,
664 | defaultValue: '',
665 | protected: false,
666 | unique: false,
667 | persistent: true,
668 | validate: {
669 | required: false,
670 | minLength: '',
671 | maxLength: '',
672 | pattern: '',
673 | custom: '',
674 | customPrivate: false
675 | },
676 | conditional: {
677 | show: null,
678 | when: null,
679 | eq: ''
680 | },
681 | type: 'textfield'
682 | },
683 | {
684 | input: true,
685 | tableView: true,
686 | inputType: 'text',
687 | inputMask: '',
688 | label: 'LastName',
689 | key: 'lastName',
690 | placeholder: 'Enter LastName',
691 | prefix: '',
692 | suffix: '',
693 | multiple: false,
694 | defaultValue: '',
695 | protected: false,
696 | unique: false,
697 | persistent: true,
698 | validate: {
699 | required: false,
700 | minLength: '',
701 | maxLength: '',
702 | pattern: '',
703 | custom: '',
704 | customPrivate: false
705 | },
706 | conditional: {
707 | show: null,
708 | when: null,
709 | eq: ''
710 | },
711 | type: 'textfield'
712 | }]
713 | },
714 | {
715 | input: true,
716 | tableView: true,
717 | inputType: 'text',
718 | inputMask: '',
719 | customClass: 'customClass',
720 | multiple: true,
721 | label: 'Currency',
722 | key: 'currency',
723 | placeholder: 'currency',
724 | prefix: '$',
725 | suffix: '@',
726 | defaultValue: '',
727 | protected: false,
728 | persistent: true,
729 | validate: {
730 | required: false,
731 | multiple: '',
732 | custom: ''
733 | },
734 | conditional: {
735 | show: null,
736 | when: null,
737 | eq: ''
738 | },
739 | type: 'currency',
740 | },
741 | {
742 | input: true,
743 | inputType: 'checkbox',
744 | tableView: false,
745 | hideLabel: true,
746 | label: 'Checkbox 2',
747 | key: 'checkbox2',
748 | defaultValue: false,
749 | protected: false,
750 | persistent: true,
751 | validate: {
752 | required: false
753 | },
754 | type: 'checkbox',
755 | conditional: {
756 | show: null,
757 | when: null,
758 | eq: ''
759 | }
760 | },
761 | {
762 | input: true,
763 | tableView: true,
764 | label: 'Select box',
765 | key: 'selectbox',
766 | values: [
767 | {
768 | value: 'coffee',
769 | label: 'Tea'
770 | },
771 | {
772 | value: 'coffee',
773 | label: 'Coffee'
774 | },
775 | {
776 | value: 'chocolate',
777 | label: 'Chocolate'
778 | },
779 | {
780 | value: 'ice-cream',
781 | label: 'Ice-Cream'
782 | }
783 | ],
784 | inline: true,
785 | protected: false,
786 | persistent: true,
787 | validate: {
788 | required: false
789 | },
790 | type: 'selectboxes',
791 | conditional: {
792 | show: null,
793 | when: null,
794 | eq: ''
795 | },
796 | customClass: 'myselect'
797 | },
798 | {
799 | input: false,
800 | title: 'Panel',
801 | theme: 'primary',
802 | components: [{
803 | input: true,
804 | tableView: true,
805 | inputType: 'text',
806 | inputMask: '',
807 | label: 'Name',
808 | key: 'name',
809 | placeholder: 'Enter your Name',
810 | prefix: '',
811 | suffix: '',
812 | multiple: false,
813 | defaultValue: '',
814 | protected: false,
815 | unique: false,
816 | persistent: true,
817 | validate: {
818 | required: false,
819 | minLength: 6,
820 | maxLength: 10,
821 | pattern: '',
822 | custom: '',
823 | customPrivate: false
824 | },
825 | conditional: {
826 | show: '',
827 | when: null,
828 | eq: ''
829 | },
830 | type: 'textfield'
831 | }, {
832 | input: true,
833 | tableView: true,
834 | label: 'Textarea',
835 | key: 'textarea',
836 | placeholder: 'Enter Your Text Here',
837 | prefix: '',
838 | suffix: '',
839 | rows: 3,
840 | multiple: false,
841 | defaultValue: '',
842 | protected: false,
843 | persistent: true,
844 | validate: {
845 | required: false,
846 | minLength: 5,
847 | maxLength: 100,
848 | pattern: '',
849 | custom: ''
850 | },
851 | type: 'textarea',
852 | conditional: {
853 | show: null,
854 | when: null,
855 | eq: ''
856 | }
857 | }],
858 | type: 'panel',
859 | conditional: {
860 | show: null,
861 | when: null,
862 | eq: ''
863 | }
864 | },
865 | {
866 | input: true,
867 | tableView: true,
868 | label: 'Survey',
869 | key: 'survey',
870 | customClass: 'customClass',
871 | questions: [
872 | {
873 | value: 'QueValue',
874 | label: 'QueLabel',
875 | },
876 | {
877 | value: 'QueValue1',
878 | label: 'QueLabel1',
879 | },
880 | {
881 | value: 'QueValue2',
882 | label: 'QueLabel2',
883 | }
884 | ],
885 | values: [
886 | {
887 | value: 'AnsValue',
888 | label: 'AnsLabel',
889 | },
890 | {
891 | value: 'AnsValue1',
892 | label: 'AnsLabel1',
893 | },
894 | {
895 | value: 'AnsValue2',
896 | label: 'AnsLabel2',
897 | },
898 | {
899 | value: 'AnsValue3',
900 | label: 'AnsLabel3',
901 | }
902 | ],
903 | defaultValue: '',
904 | protected: false,
905 | persistent: true,
906 | validate: {
907 | required: false,
908 | custom: '',
909 | customPrivate: false
910 | },
911 | type: 'survey',
912 | conditional: {
913 | show: null,
914 | when: null,
915 | eq: ''
916 | }
917 | },
918 | {
919 | input: true,
920 | tableView: true,
921 | label: 'DateTime',
922 | key: 'dateTime',
923 | placeholder: 'Select date and time',
924 | format: 'yyyy-MM-dd HH:mm',
925 | enableDate: true,
926 | enableTime: true,
927 | datepickerMode: 'day',
928 | datePicker: {
929 | showWeeks: true,
930 | startingDay: '0',
931 | initDate: '',
932 | minMode: 'day',
933 | maxMode: 'year',
934 | yearRange: '25',
935 | datepickerMode: 'day'
936 | },
937 | timePicker: {
938 | hourStep: 1,
939 | minuteStep: 1,
940 | showMeridian: true,
941 | readonlyInput: true,
942 | mousewheel: true,
943 | arrowkeys: false
944 | },
945 | protected: false,
946 | persistent: true,
947 | validate: {
948 | required: false,
949 | custom: ''
950 | },
951 | type: 'datetime',
952 | conditional: {
953 | show: null,
954 | when: null,
955 | eq: ''
956 | },
957 | minDate: '2016-07-01T18:30:00.000Z',
958 | maxDate: '2016-08-30T18:30:00.000Z'
959 | },
960 | {
961 | input: false,
962 | tag: 'p',
963 | key: 'pname',
964 | lockKey: true,
965 | attrs: [
966 | {
967 | attr: 'src',
968 | value: '/img'
969 | }
970 | ],
971 | className: 'customClass',
972 | content: 'Hello, Good Morning!!! This is Html Element.',
973 | type: 'htmlelement',
974 | tags: ['span'],
975 | conditional: {
976 | show: null,
977 | when: null,
978 | eq: ''
979 | }
980 | },
981 | {
982 | input: true,
983 | tableView: true,
984 | label: 'Fruits',
985 | key: 'fruits',
986 | placeholder: 'Select favourite',
987 | data: {
988 | values: [
989 | {
990 | value: 'opt1',
991 | label: 'mango'
992 | },
993 | {
994 | value: 'opt2',
995 | label: 'apple'
996 | },
997 | {
998 | value: 'opt3',
999 | label: 'pineapple'
1000 | },
1001 | {
1002 | value: 'opt4',
1003 | label: 'grapes'
1004 | }],
1005 | json: [
1006 | {
1007 | label: 'one',
1008 | test: 'opt1'
1009 | },
1010 | {
1011 | label: 'two',
1012 | test: 'opt2'
1013 | },
1014 | {
1015 | label: 'three',
1016 | test: 'opt3'
1017 | }],
1018 | url: 'https://api.github.com/users/hadley/orgs',
1019 | resource: 'manager'
1020 | },
1021 | dataSrc: 'values',
1022 | valueProperty: '',
1023 | defaultValue: '',
1024 | refreshOn: '',
1025 | filter: '',
1026 | authenticate: false,
1027 | template: '{{ item.label }} ',
1028 | multiple: false,
1029 | protected: false,
1030 | unique: false,
1031 | persistent: true,
1032 | validate: {
1033 | required: false
1034 | },
1035 | type: 'select',
1036 | conditional: {
1037 | show: null,
1038 | when: null,
1039 | eq: ''
1040 | }
1041 | },
1042 | {
1043 | input: true,
1044 | tableView: true,
1045 | label: 'Address',
1046 | key: 'address',
1047 | placeholder: 'Enter Address',
1048 | multiple: false,
1049 | protected: false,
1050 | unique: false,
1051 | persistent: true,
1052 | validate: {
1053 | required: true
1054 | },
1055 | type: 'address',
1056 | conditional: {
1057 | show: null,
1058 | when: null,
1059 | eq: ''
1060 | },
1061 | customClass: 'myclass'
1062 | },
1063 | {
1064 | customClass: 'myclass',
1065 | conditional: {
1066 | eq: '',
1067 | when: null,
1068 | show: ''
1069 | },
1070 | type: 'resource',
1071 | defaultPermission: '',
1072 | validate: '{"required": false}',
1073 | persistent: true,
1074 | protected: false,
1075 | multiple: false,
1076 | searchFields: ['data.fullName'],
1077 | selectFields: 'data.fullName, data.email',
1078 | template: '{{ item.data }} ',
1079 | defaultValue: [],
1080 | resource: '5757ea1c6e37370100cb5bce',
1081 | project: '5757ea1c6e37370100cb5bc8',
1082 | placeholder: 'Select Resource',
1083 | key: 'resource',
1084 | label: 'Resource',
1085 | tableView: true,
1086 | input: true,
1087 | tags: []
1088 | },
1089 | {
1090 | input: true,
1091 | tableView: true,
1092 | label: 'Signature',
1093 | key: 'signature',
1094 | placeholder: 'Please Sign here...',
1095 | footer: 'Sign above',
1096 | width: '50%',
1097 | height: '200px',
1098 | penColor: 'green',
1099 | backgroundColor: 'rgb(245,245,235)',
1100 | minWidth: '0.5',
1101 | maxWidth: '2.5',
1102 | protected: false,
1103 | persistent: true,
1104 | validate: {
1105 | required: false
1106 | },
1107 | type: 'signature',
1108 | hideLabel: false,
1109 | conditional: {
1110 | show: null,
1111 | when: null,
1112 | eq: ''
1113 | },
1114 | customClass: 'myclass'
1115 | },
1116 | {
1117 | input: true,
1118 | tableView: true,
1119 | key: 'nameHidden',
1120 | label: 'Name',
1121 | protected: false,
1122 | unique: true,
1123 | persistent: true,
1124 | type: 'hidden',
1125 | conditional: {
1126 | show: true,
1127 | when: '',
1128 | eq: ''
1129 | }
1130 | },
1131 | {
1132 | input: true,
1133 | label: 'Submit',
1134 | tableView: false,
1135 | key: 'submit',
1136 | size: 'md',
1137 | leftIcon: '',
1138 | rightIcon: '',
1139 | block: false,
1140 | action: 'submit',
1141 | disableOnInvalid: false,
1142 | theme: 'primary',
1143 | type: 'button'
1144 | }
1145 | ]
1146 | };
1147 |
1148 | export const FORM_WIZARD: any = {
1149 | components: [
1150 | {
1151 | type: 'panel',
1152 | input: false,
1153 | title: 'Page 1',
1154 | theme: 'default',
1155 | components: [
1156 | {
1157 | input: true,
1158 | tableView: true,
1159 | inputType: 'text',
1160 | inputMask: '',
1161 | label: 'First Name',
1162 | key: 'firstName',
1163 | placeholder: 'Enter your first name',
1164 | prefix: '',
1165 | suffix: '',
1166 | multiple: false,
1167 | defaultValue: '',
1168 | protected: false,
1169 | unique: false,
1170 | persistent: true,
1171 | validate: {
1172 | required: false,
1173 | minLength: '',
1174 | maxLength: '',
1175 | pattern: '',
1176 | custom: '',
1177 | customPrivate: false
1178 | },
1179 | conditional: {
1180 | show: false,
1181 | when: null,
1182 | eq: ''
1183 | },
1184 | type: 'textfield'
1185 | },
1186 | {
1187 | input: true,
1188 | tableView: true,
1189 | inputType: 'text',
1190 | inputMask: '',
1191 | label: 'Last Name',
1192 | key: 'lastName',
1193 | placeholder: 'Enter your last name',
1194 | prefix: '',
1195 | suffix: '',
1196 | multiple: false,
1197 | defaultValue: '',
1198 | protected: false,
1199 | unique: false,
1200 | persistent: true,
1201 | validate: {
1202 | required: false,
1203 | minLength: '',
1204 | maxLength: '',
1205 | pattern: '',
1206 | custom: '',
1207 | customPrivate: false
1208 | },
1209 | conditional: {
1210 | show: false,
1211 | when: null,
1212 | eq: ''
1213 | },
1214 | type: 'textfield'
1215 | }
1216 | ],
1217 | },
1218 | {
1219 | type: 'panel',
1220 | title: 'Page 2',
1221 | isNew: true,
1222 | components: [
1223 | {
1224 | input: true,
1225 | tableView: true,
1226 | label: 'Write about you',
1227 | key: 'aboutu',
1228 | placeholder: 'Write about yourself here',
1229 | prefix: '',
1230 | suffix: '',
1231 | rows: 3,
1232 | multiple: false,
1233 | defaultValue: '',
1234 | protected: false,
1235 | persistent: true,
1236 | validate: {
1237 | required: false,
1238 | minLength: 6,
1239 | maxLength: 100,
1240 | pattern: '',
1241 | custom: ''
1242 | },
1243 | type: 'textarea',
1244 | conditional: {
1245 | show: null,
1246 | when: null,
1247 | eq: ''
1248 | }
1249 | }
1250 | ],
1251 | input: false,
1252 | key: 'page2',
1253 | theme: 'default'
1254 | },
1255 | {
1256 | type: 'panel',
1257 | title: 'Page 3',
1258 | isNew: true,
1259 | components: [
1260 | {
1261 | input: true,
1262 | tableView: true,
1263 | label: 'Textarea',
1264 | key: 'textarea',
1265 | placeholder: 'Enter Your Text Here',
1266 | prefix: '',
1267 | suffix: '',
1268 | rows: 3,
1269 | multiple: false,
1270 | defaultValue: '',
1271 | protected: false,
1272 | persistent: true,
1273 | validate: {
1274 | required: false,
1275 | minLength: 6,
1276 | maxLength: 100,
1277 | pattern: '',
1278 | custom: ''
1279 | },
1280 | type: 'textarea',
1281 | conditional: {
1282 | show: null,
1283 | when: null,
1284 | eq: ''
1285 | }
1286 | }
1287 | ],
1288 | input: false,
1289 | key: 'page3',
1290 | theme: 'default'
1291 | }
1292 | ],
1293 | display: 'wizard',
1294 | page: 0,
1295 | numPages: 2
1296 | };
1297 |
--------------------------------------------------------------------------------
/src/app/forms/kitchen/kitchen.component.html:
--------------------------------------------------------------------------------
1 | Kitchen Sink Form
2 |
3 |
--------------------------------------------------------------------------------
/src/app/forms/kitchen/kitchen.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/forms/kitchen/kitchen.component.scss
--------------------------------------------------------------------------------
/src/app/forms/kitchen/kitchen.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { KitchenComponent } from './kitchen.component';
4 |
5 | describe('KitchenComponent', () => {
6 | let component: KitchenComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ KitchenComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(KitchenComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/forms/kitchen/kitchen.component.ts:
--------------------------------------------------------------------------------
1 | import { Component } from '@angular/core';
2 | import { FORM } from './form';
3 | @Component({
4 | selector: 'app-kitchen',
5 | templateUrl: './kitchen.component.html',
6 | styleUrls: ['./kitchen.component.scss']
7 | })
8 | export class KitchenComponent {
9 | public form: any = FORM;
10 | public options: any = {
11 | hooks: {
12 | beforeSubmit: (submission: object, cb: any) => {
13 | console.log('Before Submit');
14 | console.log(submission);
15 | setTimeout(() => cb(null, submission), 1000);
16 | }
17 | }
18 | };
19 | /* tslint:disable:max-line-length */
20 | public submission: any = {
21 | data: {
22 | user: {
23 | firstName: 'Joe',
24 | lastName: 'Smith',
25 | email: 'joe@example.com',
26 | kids: [
27 | 'Susie',
28 | 'Jack'
29 | ]
30 | },
31 | cars: [
32 | {
33 | make: 'Jeep',
34 | model: 'Wrangler',
35 | year: '2010'
36 | },
37 | {
38 | make: 'Ford',
39 | model: 'Mustang',
40 | year: '2014'
41 | }
42 | ],
43 | signature: ''
44 | }
45 | };
46 | /* tslint:enable:max-line-length */
47 |
48 | onRender() {
49 | console.log('onRender');
50 | }
51 | onSubmit(value: any) {
52 | console.log('onSubmit');
53 | console.log(value);
54 | }
55 | onChange(value: any) {
56 | console.log('onChange');
57 | console.log(value);
58 | }
59 | }
60 |
--------------------------------------------------------------------------------
/src/app/forms/language/language.component.html:
--------------------------------------------------------------------------------
1 | Multiple Languages
2 | Read Documentation
3 |
4 | English
5 | Español
6 | 中文
7 |
8 |
9 |
--------------------------------------------------------------------------------
/src/app/forms/language/language.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/forms/language/language.component.scss
--------------------------------------------------------------------------------
/src/app/forms/language/language.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { LanguageComponent } from './language.component';
4 |
5 | describe('LanguageComponent', () => {
6 | let component: LanguageComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ LanguageComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(LanguageComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/forms/language/language.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, EventEmitter } from '@angular/core';
2 | import { FormioOptions, FormioAppConfig } from '@formio/angular';
3 |
4 | @Component({
5 | selector: 'app-language',
6 | templateUrl: './language.component.html',
7 | styleUrls: ['./language.component.scss']
8 | })
9 | export class LanguageComponent {
10 | public language: EventEmitter;
11 | public options: FormioOptions;
12 |
13 | /* tslint:disable:max-line-length */
14 | constructor(public config: FormioAppConfig) {
15 | this.language = new EventEmitter();
16 | this.options = {
17 | i18n: {
18 | sp: {
19 | 'First Name': 'Nombre de pila',
20 | 'Last Name': 'Apellido',
21 | 'Enter your first name': 'Ponga su primer nombre',
22 | 'Enter your last name': 'Introduce tu apellido',
23 | Email: 'Email',
24 | 'Enter your email address':
25 | 'Ingrese su dirección de correo electrónico',
26 | 'Phone Number': 'Número de teléfono',
27 | 'Enter your phone number': 'Ingrese su número telefónico',
28 | Submit: 'Enviar',
29 | 'This is a dynamically rendered JSON form built with Form.io. Using a simple drag-and-drop form builder, you can create any form that includes e-signatures, wysiwyg editors, date fields, layout components, data grids, surveys, etc.':
30 | 'Se trata de un formulario JSON dinámicamente generado con Form.io. Utilizando un simple constructor de formularios de arrastrar y soltar, puede crear cualquier formulario que incluya firmas electrónicas, editores wysiwyg, campos de fecha, componentes de diseño, cuadrículas de datos, encuestas, etc.',
31 | 'Form.io Example Form': 'Ejemplo Form.io',
32 | Survey: 'Encuesta',
33 | 'How would you rate the Form.io platform?':
34 | '¿Cómo calificaría la plataforma Form.io?',
35 | 'How was Customer Support?':
36 | '¿Cómo fue el servicio de atención al cliente?',
37 | 'Overall Experience?': '¿Experiencia general?',
38 | Excellent: 'Excelente',
39 | Great: 'Estupendo',
40 | Good: 'Bueno',
41 | Average: 'Promedio',
42 | Poor: 'Pobre',
43 | 'Sign above': 'Signo de arriba'
44 | },
45 | ch: {
46 | 'First Name': '名字',
47 | 'Last Name': '姓',
48 | 'Enter your first name': '输入你的名字',
49 | 'Enter your last name': '输入你的姓氏',
50 | Email: '电子邮件',
51 | 'Enter your email address': '输入你的电子邮箱地址',
52 | 'Phone Number': '电话号码',
53 | 'Enter your phone number': '输入你的电话号码',
54 | Submit: '提交',
55 | 'This is a dynamically rendered JSON form built with Form.io. Using a simple drag-and-drop form builder, you can create any form that includes e-signatures, wysiwyg editors, date fields, layout components, data grids, surveys, etc.':
56 | '这是一个使用Form.io构建的动态呈现的JSON表单。使用简单的拖放表单构建器,您可以创建包括电子签名,wysiwyg编辑器,日期字段,布局组件,数据网格,调查等的任何表单。',
57 | 'Form.io Example Form': 'Form.io示例表单',
58 | Survey: '调查',
59 | 'How would you rate the Form.io platform?': '你如何评价Form.io平台?',
60 | 'How was Customer Support?': '客户支持如何?',
61 | 'Overall Experience?': '总体体验?',
62 | Excellent: '优秀',
63 | Great: '大',
64 | Good: '好',
65 | Average: '平均',
66 | Poor: '错',
67 | 'Sign above': '上面标注'
68 | }
69 | }
70 | };
71 | }
72 | /* tslint:enable:max-line-length */
73 |
74 | changeLanguage(lang: string) {
75 | console.log(lang);
76 | this.language.emit(lang);
77 | }
78 | }
79 |
--------------------------------------------------------------------------------
/src/app/forms/pdf/pdf.component.html:
--------------------------------------------------------------------------------
1 | PDF Form
2 |
3 |
--------------------------------------------------------------------------------
/src/app/forms/pdf/pdf.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/forms/pdf/pdf.component.scss
--------------------------------------------------------------------------------
/src/app/forms/pdf/pdf.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { PdfComponent } from './pdf.component';
4 |
5 | describe('PdfComponent', () => {
6 | let component: PdfComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ PdfComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(PdfComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/forms/pdf/pdf.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, OnInit } from '@angular/core';
2 | import { FormioAppConfig } from '@formio/angular';
3 | @Component({
4 | selector: 'app-pdf',
5 | templateUrl: './pdf.component.html',
6 | styleUrls: ['./pdf.component.scss']
7 | })
8 | export class PdfComponent implements OnInit {
9 | constructor(public config: FormioAppConfig) {}
10 | ngOnInit() {}
11 | }
12 |
--------------------------------------------------------------------------------
/src/app/forms/renderer/renderer.component.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
The Angular JSON form renderer is a wrapper around the Form.io Core Renderer . This provides the ability to render any Form within the Form.io platform, using the following syntax.
4 |
5 |
<formio src="https://examples.com/example"></formio>
6 |
7 |
You can also provide a variable as the source as follows.
8 |
9 |
<formio [src]="formSrc"></formio>
10 |
11 |
And even listen for Change and Submit events as follows.
12 |
13 |
<formio
14 | [src]="formSrc"
15 | (change)="onChange($event)"
16 | (submit)="onSubmit($event)"
17 | ></formio>
18 |
19 |
Or pass JSON directly
20 |
21 |
<formio [form]="{components: [
22 | {
23 | type: 'textfield',
24 | label: 'FirstName',
25 | key: 'firstName',
26 | input: true
27 | },
28 | {
29 | type: 'textfield',
30 | label: 'LastName',
31 | key: 'lastName',
32 | input: true
33 | },
34 | {
35 | type: 'email',
36 | label: 'Email',
37 | key: 'email',
38 | input: true
39 | },
40 | {
41 | type: 'button',
42 | action: 'Submit',
43 | label: 'Submit',
44 | theme: 'primary'
45 | }
46 | ]}"></formio>
47 |
48 |
and populate with data
49 |
50 |
<formio [form]="{components: [
51 | {
52 | type: 'textfield',
53 | label: 'FirstName',
54 | key: 'firstName',
55 | input: true
56 | },
57 | {
58 | type: 'textfield',
59 | label: 'LastName',
60 | key: 'lastName',
61 | input: true
62 | },
63 | {
64 | type: 'email',
65 | label: 'Email',
66 | key: 'email',
67 | input: true
68 | },
69 | {
70 | type: 'button',
71 | action: 'submit',
72 | label: 'Submit',
73 | theme: 'primary'
74 | }
75 | ]}" [submission]="{
76 | data: {
77 | firstName: 'Joe',
78 | lastName: 'Smith',
79 | email: 'joe@example.com'
80 | }
81 | }"></formio>
82 |
83 |
84 |
126 |
127 |
--------------------------------------------------------------------------------
/src/app/forms/renderer/renderer.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/forms/renderer/renderer.component.scss
--------------------------------------------------------------------------------
/src/app/forms/renderer/renderer.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { RendererComponent } from './renderer.component';
4 |
5 | describe('RendererComponent', () => {
6 | let component: RendererComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ RendererComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(RendererComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/forms/renderer/renderer.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, AfterViewInit } from '@angular/core';
2 | import { PrismService } from '../../Prism.service';
3 |
4 | @Component({
5 | selector: 'app-renderer',
6 | templateUrl: './renderer.component.html',
7 | styleUrls: ['./renderer.component.scss']
8 | })
9 | export class RendererComponent implements AfterViewInit {
10 |
11 | constructor(public prism: PrismService) { }
12 | ngAfterViewInit() {
13 | this.prism.init();
14 | }
15 |
16 | }
17 |
--------------------------------------------------------------------------------
/src/app/forms/simple/simple.component.html:
--------------------------------------------------------------------------------
1 | JSON Powered Forms
2 | Form.io is a platform for JSON powered forms within Angular. Forms can be embedded as easy as the following code.
3 |
4 | <formio src="https://examples.form.io/example"></formio>
5 | Read Documentation
6 |
7 |
--------------------------------------------------------------------------------
/src/app/forms/simple/simple.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/forms/simple/simple.component.scss
--------------------------------------------------------------------------------
/src/app/forms/simple/simple.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { SimpleComponent } from './simple.component';
4 |
5 | describe('SimpleComponent', () => {
6 | let component: SimpleComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ SimpleComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(SimpleComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/forms/simple/simple.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, AfterViewInit } from '@angular/core';
2 | import { FormioAppConfig } from '@formio/angular';
3 | import { PrismService } from '../../Prism.service';
4 |
5 | @Component({
6 | selector: 'app-simple',
7 | templateUrl: './simple.component.html',
8 | styleUrls: ['./simple.component.scss']
9 | })
10 | export class SimpleComponent implements AfterViewInit {
11 | constructor(
12 | public config: FormioAppConfig,
13 | public prism: PrismService
14 | ) {}
15 | ngAfterViewInit() {
16 | this.prism.init();
17 | }
18 | }
19 |
--------------------------------------------------------------------------------
/src/app/forms/wizard/wizard.component.html:
--------------------------------------------------------------------------------
1 | Wizard Forms
2 | Form.io provides a way to build multi-page forms and easily embed them within your application using the following code.
3 | <formio src="{{ config.appUrl }}/wizard"></formio>
4 |
5 |
--------------------------------------------------------------------------------
/src/app/forms/wizard/wizard.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/forms/wizard/wizard.component.scss
--------------------------------------------------------------------------------
/src/app/forms/wizard/wizard.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { WizardComponent } from './wizard.component';
4 |
5 | describe('WizardComponent', () => {
6 | let component: WizardComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ WizardComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(WizardComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/forms/wizard/wizard.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, AfterViewInit } from '@angular/core';
2 | import { FormioAppConfig } from '@formio/angular';
3 | import { PrismService } from '../../Prism.service';
4 |
5 | @Component({
6 | selector: 'app-wizard',
7 | templateUrl: './wizard.component.html',
8 | styleUrls: ['./wizard.component.scss']
9 | })
10 | export class WizardComponent implements AfterViewInit {
11 | constructor(
12 | public config: FormioAppConfig,
13 | public prism: PrismService
14 | ) {}
15 |
16 | ngAfterViewInit() {
17 | this.prism.init();
18 | }
19 | }
20 |
--------------------------------------------------------------------------------
/src/app/home/home.component.html:
--------------------------------------------------------------------------------
1 |
2 |
JavaScript Powered Forms for by
3 |
This library provides JavaScript powered forms for Angular . This allows you to render the JSON schema forms produced by Form.io and render those within your application using Angular 5, as well as provides an interface SDK to communicate to the Form.io API's. The benefits of this library include.
4 |
5 | Renders a JSON schema as a webform and hooks up that form to the Form.io API's
6 | Nested components, layouts, Date/Time, Select, Input Masks, and many more included features
7 | Full JavaScript API SDK library on top of Form.io
8 |
9 |
10 |
11 |
12 |
Example
13 |
14 |
<formio src="{{ config.appUrl }}/example"></formio>
15 |
16 |
17 |
18 |
19 |
20 |
Result
21 |
22 |
23 |
24 |
25 |
26 |
--------------------------------------------------------------------------------
/src/app/home/home.component.scss:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/app/home/home.component.scss
--------------------------------------------------------------------------------
/src/app/home/home.component.spec.ts:
--------------------------------------------------------------------------------
1 | import { async, ComponentFixture, TestBed } from '@angular/core/testing';
2 |
3 | import { HomeComponent } from './home.component';
4 |
5 | describe('HomeComponent', () => {
6 | let component: HomeComponent;
7 | let fixture: ComponentFixture;
8 |
9 | beforeEach(async(() => {
10 | TestBed.configureTestingModule({
11 | declarations: [ HomeComponent ]
12 | })
13 | .compileComponents();
14 | }));
15 |
16 | beforeEach(() => {
17 | fixture = TestBed.createComponent(HomeComponent);
18 | component = fixture.componentInstance;
19 | fixture.detectChanges();
20 | });
21 |
22 | it('should create', () => {
23 | expect(component).toBeTruthy();
24 | });
25 | });
26 |
--------------------------------------------------------------------------------
/src/app/home/home.component.ts:
--------------------------------------------------------------------------------
1 | import { Component, AfterViewInit } from '@angular/core';
2 | import { FormioAppConfig } from '@formio/angular';
3 | import { PrismService } from '../Prism.service';
4 | @Component({
5 | selector: 'app-home',
6 | templateUrl: './home.component.html',
7 | styleUrls: ['./home.component.scss']
8 | })
9 | export class HomeComponent implements AfterViewInit {
10 | constructor(
11 | public config: FormioAppConfig,
12 | public prism: PrismService
13 | ) {}
14 |
15 | ngAfterViewInit() {
16 | this.prism.init();
17 | }
18 | }
19 |
--------------------------------------------------------------------------------
/src/assets/.gitkeep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/assets/.gitkeep
--------------------------------------------------------------------------------
/src/environments/environment.prod.ts:
--------------------------------------------------------------------------------
1 | export const environment = {
2 | production: true
3 | };
4 |
--------------------------------------------------------------------------------
/src/environments/environment.ts:
--------------------------------------------------------------------------------
1 | // This file can be replaced during build by using the `fileReplacements` array.
2 | // `ng build ---prod` replaces `environment.ts` with `environment.prod.ts`.
3 | // The list of file replacements can be found in `angular.json`.
4 |
5 | export const environment = {
6 | production: false
7 | };
8 |
9 | /*
10 | * In development mode, for easier debugging, you can ignore zone related error
11 | * stack frames such as `zone.run`/`zoneDelegate.invokeTask` by importing the
12 | * below file. Don't forget to comment it out in production mode
13 | * because it will have a performance impact when errors are thrown
14 | */
15 | // import 'zone.js/dist/zone-error'; // Included with Angular CLI.
16 |
--------------------------------------------------------------------------------
/src/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/formio/angular-demo/df0c2ce2f1930211db57092757a0fdd8a9fed35c/src/favicon.ico
--------------------------------------------------------------------------------
/src/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | Form.io + Angular Demo
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
--------------------------------------------------------------------------------
/src/karma.conf.js:
--------------------------------------------------------------------------------
1 | // Karma configuration file, see link for more information
2 | // https://karma-runner.github.io/1.0/config/configuration-file.html
3 |
4 | module.exports = function (config) {
5 | config.set({
6 | basePath: '',
7 | frameworks: ['jasmine', '@angular-devkit/build-angular'],
8 | plugins: [
9 | require('karma-jasmine'),
10 | require('karma-chrome-launcher'),
11 | require('karma-jasmine-html-reporter'),
12 | require('karma-coverage-istanbul-reporter'),
13 | require('@angular-devkit/build-angular/plugins/karma')
14 | ],
15 | client: {
16 | clearContext: false // leave Jasmine Spec Runner output visible in browser
17 | },
18 | coverageIstanbulReporter: {
19 | dir: require('path').join(__dirname, '../coverage'),
20 | reports: ['html', 'lcovonly'],
21 | fixWebpackSourcePaths: true
22 | },
23 | reporters: ['progress', 'kjhtml'],
24 | port: 9876,
25 | colors: true,
26 | logLevel: config.LOG_INFO,
27 | autoWatch: true,
28 | browsers: ['Chrome'],
29 | singleRun: false
30 | });
31 | };
--------------------------------------------------------------------------------
/src/main.ts:
--------------------------------------------------------------------------------
1 | import { enableProdMode } from '@angular/core';
2 | import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
3 |
4 | import { AppModule } from './app/app.module';
5 | import { environment } from './environments/environment';
6 |
7 | if (environment.production) {
8 | enableProdMode();
9 | }
10 |
11 | platformBrowserDynamic().bootstrapModule(AppModule)
12 | .catch(err => console.log(err));
13 |
--------------------------------------------------------------------------------
/src/polyfills.ts:
--------------------------------------------------------------------------------
1 | /**
2 | * This file includes polyfills needed by Angular and is loaded before the app.
3 | * You can add your own extra polyfills to this file.
4 | *
5 | * This file is divided into 2 sections:
6 | * 1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers.
7 | * 2. Application imports. Files imported after ZoneJS that should be loaded before your main
8 | * file.
9 | *
10 | * The current setup is for so-called "evergreen" browsers; the last versions of browsers that
11 | * automatically update themselves. This includes Safari >= 10, Chrome >= 55 (including Opera),
12 | * Edge >= 13 on the desktop, and iOS 10 and Chrome on mobile.
13 | *
14 | * Learn more in https://angular.io/docs/ts/latest/guide/browser-support.html
15 | */
16 |
17 | /***************************************************************************************************
18 | * BROWSER POLYFILLS
19 | */
20 |
21 | /** IE9, IE10 and IE11 requires all of the following polyfills. **/
22 | // import 'core-js/es6/symbol';
23 | // import 'core-js/es6/object';
24 | // import 'core-js/es6/function';
25 | // import 'core-js/es6/parse-int';
26 | // import 'core-js/es6/parse-float';
27 | // import 'core-js/es6/number';
28 | // import 'core-js/es6/math';
29 | // import 'core-js/es6/string';
30 | // import 'core-js/es6/date';
31 | // import 'core-js/es6/array';
32 | // import 'core-js/es6/regexp';
33 | // import 'core-js/es6/map';
34 | // import 'core-js/es6/weak-map';
35 | // import 'core-js/es6/set';
36 |
37 | /** IE10 and IE11 requires the following for NgClass support on SVG elements */
38 | // import 'classlist.js'; // Run `npm install --save classlist.js`.
39 |
40 | /** IE10 and IE11 requires the following for the Reflect API. */
41 | // import 'core-js/es6/reflect';
42 |
43 |
44 | /** Evergreen browsers require these. **/
45 | // Used for reflect-metadata in JIT. If you use AOT (and only Angular decorators), you can remove.
46 | // import 'core-js/es7/reflect';
47 |
48 |
49 | /**
50 | * Web Animations `@angular/platform-browser/animations`
51 | * Only required if AnimationBuilder is used within the application and using IE/Edge or Safari.
52 | * Standard animation support in Angular DOES NOT require any polyfills (as of Angular 6.0).
53 | **/
54 | // import 'web-animations-js'; // Run `npm install --save web-animations-js`.
55 |
56 | /**
57 | * By default, zone.js will patch all possible macroTask and DomEvents
58 | * user can disable parts of macroTask/DomEvents patch by setting following flags
59 | */
60 |
61 | // (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame
62 | // (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick
63 | // (window as any).__zone_symbol__BLACK_LISTED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames
64 |
65 | /*
66 | * in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js
67 | * with the following flag, it will bypass `zone.js` patch for IE/Edge
68 | */
69 | // (window as any).__Zone_enable_cross_context_check = true;
70 |
71 | /***************************************************************************************************
72 | * Zone JS is required by default for Angular itself.
73 | */
74 | import 'zone.js';; // Included with Angular CLI.
75 |
76 | /***************************************************************************************************
77 | * APPLICATION IMPORTS
78 | */
--------------------------------------------------------------------------------
/src/styles.scss:
--------------------------------------------------------------------------------
1 | @import "bootswatch/dist/cosmo/_variables.scss";
2 | @import "bootstrap/scss/bootstrap.scss";
3 | @import "bootswatch/dist/cosmo/_bootswatch.scss";
4 | $fa-font-path: '~font-awesome/fonts';
5 | @import 'font-awesome/scss/font-awesome';
6 |
--------------------------------------------------------------------------------
/src/test.ts:
--------------------------------------------------------------------------------
1 | // This file is required by karma.conf.js and loads recursively all the .spec and framework files
2 |
3 | import 'zone.js/dist/zone-testing';
4 | import { getTestBed } from '@angular/core/testing';
5 | import {
6 | BrowserDynamicTestingModule,
7 | platformBrowserDynamicTesting
8 | } from '@angular/platform-browser-dynamic/testing';
9 |
10 | declare const require: any;
11 |
12 | // First, initialize the Angular testing environment.
13 | getTestBed().initTestEnvironment(
14 | BrowserDynamicTestingModule,
15 | platformBrowserDynamicTesting()
16 | );
17 | // Then we find all the tests.
18 | const context = require.context('./', true, /\.spec\.ts$/);
19 | // And load the modules.
20 | context.keys().map(context);
21 |
--------------------------------------------------------------------------------
/src/tsconfig.app.json:
--------------------------------------------------------------------------------
1 | {
2 | "extends": "../tsconfig.json",
3 | "compilerOptions": {
4 | "outDir": "../out-tsc/app",
5 | "types": ["node"]
6 | },
7 | "exclude": [
8 | "test.ts",
9 | "**/*.spec.ts"
10 | ]
11 | }
12 |
--------------------------------------------------------------------------------
/src/tsconfig.spec.json:
--------------------------------------------------------------------------------
1 | {
2 | "extends": "../tsconfig.json",
3 | "compilerOptions": {
4 | "outDir": "../out-tsc/spec",
5 | "types": [
6 | "jasmine",
7 | "node"
8 | ]
9 | },
10 | "files": [
11 | "test.ts",
12 | "polyfills.ts"
13 | ],
14 | "include": [
15 | "**/*.spec.ts",
16 | "**/*.d.ts"
17 | ]
18 | }
19 |
--------------------------------------------------------------------------------
/src/tslint.json:
--------------------------------------------------------------------------------
1 | {
2 | "extends": "../tslint.json",
3 | "rules": {
4 | "directive-selector": [
5 | true,
6 | "attribute",
7 | "app",
8 | "camelCase"
9 | ],
10 | "component-selector": [
11 | true,
12 | "element",
13 | "app",
14 | "kebab-case"
15 | ]
16 | }
17 | }
18 |
--------------------------------------------------------------------------------
/tsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "compileOnSave": false,
3 | "compilerOptions": {
4 | "baseUrl": "./",
5 | "outDir": "./dist/out-tsc",
6 | "sourceMap": true,
7 | "declaration": false,
8 | "module": "es2020",
9 | "moduleResolution": "node",
10 | "emitDecoratorMetadata": true,
11 | "experimentalDecorators": true,
12 | "target": "es6",
13 | "typeRoots": [
14 | "node_modules/@types"
15 | ],
16 | "lib": [
17 | "es2017",
18 | "dom"
19 | ]
20 | }
21 | }
22 |
--------------------------------------------------------------------------------
/tslint.json:
--------------------------------------------------------------------------------
1 | {
2 | "rulesDirectory": [
3 | "node_modules/codelyzer"
4 | ],
5 | "rules": {
6 | "arrow-return-shorthand": true,
7 | "callable-types": true,
8 | "class-name": true,
9 | "comment-format": [
10 | true,
11 | "check-space"
12 | ],
13 | "curly": true,
14 | "deprecation": {
15 | "severity": "warn"
16 | },
17 | "eofline": true,
18 | "forin": true,
19 | "import-blacklist": [
20 | true,
21 | "rxjs/Rx"
22 | ],
23 | "import-spacing": true,
24 | "indent": [
25 | true,
26 | "spaces"
27 | ],
28 | "interface-over-type-literal": true,
29 | "label-position": true,
30 | "max-line-length": [
31 | true,
32 | 140
33 | ],
34 | "member-access": false,
35 | "member-ordering": [
36 | true,
37 | {
38 | "order": [
39 | "static-field",
40 | "instance-field",
41 | "static-method",
42 | "instance-method"
43 | ]
44 | }
45 | ],
46 | "no-arg": true,
47 | "no-bitwise": true,
48 | "no-console": [
49 | true,
50 | "debug",
51 | "info",
52 | "time",
53 | "timeEnd",
54 | "trace"
55 | ],
56 | "no-construct": true,
57 | "no-debugger": true,
58 | "no-duplicate-super": true,
59 | "no-empty": false,
60 | "no-empty-interface": true,
61 | "no-eval": true,
62 | "no-inferrable-types": [
63 | true,
64 | "ignore-params"
65 | ],
66 | "no-misused-new": true,
67 | "no-non-null-assertion": true,
68 | "no-shadowed-variable": true,
69 | "no-string-literal": false,
70 | "no-string-throw": true,
71 | "no-switch-case-fall-through": true,
72 | "no-trailing-whitespace": true,
73 | "no-unnecessary-initializer": true,
74 | "no-unused-expression": true,
75 | "no-var-keyword": true,
76 | "object-literal-sort-keys": false,
77 | "one-line": [
78 | true,
79 | "check-open-brace",
80 | "check-catch",
81 | "check-else",
82 | "check-whitespace"
83 | ],
84 | "prefer-const": true,
85 | "quotemark": [
86 | true,
87 | "single"
88 | ],
89 | "radix": true,
90 | "semicolon": [
91 | true,
92 | "always"
93 | ],
94 | "triple-equals": [
95 | true,
96 | "allow-null-check"
97 | ],
98 | "typedef-whitespace": [
99 | true,
100 | {
101 | "call-signature": "nospace",
102 | "index-signature": "nospace",
103 | "parameter": "nospace",
104 | "property-declaration": "nospace",
105 | "variable-declaration": "nospace"
106 | }
107 | ],
108 | "unified-signatures": true,
109 | "variable-name": false,
110 | "whitespace": [
111 | true,
112 | "check-branch",
113 | "check-decl",
114 | "check-operator",
115 | "check-separator",
116 | "check-type"
117 | ],
118 | "no-output-on-prefix": true,
119 | "use-input-property-decorator": true,
120 | "use-output-property-decorator": true,
121 | "use-host-property-decorator": true,
122 | "no-input-rename": true,
123 | "no-output-rename": true,
124 | "use-life-cycle-interface": true,
125 | "use-pipe-transform-interface": true,
126 | "component-class-suffix": true,
127 | "directive-class-suffix": true
128 | }
129 | }
130 |
--------------------------------------------------------------------------------