Merge branch 'master' of ssh://lab.theresno.cloud:1251/hackathon-fr-20/plana
This commit is contained in:
commit
1c35a4946a
@ -24,6 +24,7 @@
|
|||||||
"@ionic-native/splash-screen": "^5.0.0",
|
"@ionic-native/splash-screen": "^5.0.0",
|
||||||
"@ionic-native/status-bar": "^5.0.0",
|
"@ionic-native/status-bar": "^5.0.0",
|
||||||
"@ionic/angular": "^5.0.0",
|
"@ionic/angular": "^5.0.0",
|
||||||
|
"csv-parser": "^2.3.2",
|
||||||
"leaflet": "^1.6.0",
|
"leaflet": "^1.6.0",
|
||||||
"rxjs": "~6.5.1",
|
"rxjs": "~6.5.1",
|
||||||
"tslib": "^1.10.0",
|
"tslib": "^1.10.0",
|
||||||
|
@ -5,6 +5,14 @@ const routes: Routes = [
|
|||||||
{
|
{
|
||||||
path: '',
|
path: '',
|
||||||
loadChildren: () => import('./tabs/tabs.module').then(m => m.TabsPageModule)
|
loadChildren: () => import('./tabs/tabs.module').then(m => m.TabsPageModule)
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'searchresults',
|
||||||
|
loadChildren: () => import('./searchresults/searchresults.module').then( m => m.SearchresultsPageModule)
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'offers',
|
||||||
|
loadChildren: () => import('./offers/offers.module').then( m => m.OffersPageModule)
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
@NgModule({
|
@NgModule({
|
||||||
|
82
src/app/offer.model.ts
Normal file
82
src/app/offer.model.ts
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
export interface Offer {
|
||||||
|
adr_anfahrt: string;
|
||||||
|
adr_hausnr: string;
|
||||||
|
adr_ort: string;
|
||||||
|
adr_plz: string;
|
||||||
|
adr_strasse: string;
|
||||||
|
con_fax: string;
|
||||||
|
con_mobile: string;
|
||||||
|
con_tel: string;
|
||||||
|
descr_einrichtung: string;
|
||||||
|
descr_long: string;
|
||||||
|
descr_short: string;
|
||||||
|
descr_titel: string;
|
||||||
|
descr_zusatz: string;
|
||||||
|
descr_date: Date;
|
||||||
|
detail_anmeldung: string;
|
||||||
|
detail_gender: string;
|
||||||
|
detail_cost: string;
|
||||||
|
details_teilnehmer: string;
|
||||||
|
details_zeit: string;
|
||||||
|
details_ziel: string;
|
||||||
|
detail_methods: string;
|
||||||
|
categories: {
|
||||||
|
"Elternbildung": boolean;
|
||||||
|
"Soziale Teilhabe": boolean;
|
||||||
|
"Beratung": boolean;
|
||||||
|
"Erährung und Bewegung": boolean;
|
||||||
|
"Familienfreundliche Angebote": boolean;
|
||||||
|
"Förderung der allgem. Lebenskompetenz": boolean;
|
||||||
|
"Frühe Hilfen": boolean;
|
||||||
|
"Körperliche Gesundheit": boolean;
|
||||||
|
"Seelische Gesundheit": boolean;
|
||||||
|
"Inklusion": boolean;
|
||||||
|
"Medienpädagogik/-kompetenz": boolean;
|
||||||
|
"Migration und Integration": boolean;
|
||||||
|
"Offene Familientreffs": boolean;
|
||||||
|
"Partnerschaft und Sexualität": boolean;
|
||||||
|
"Planung, Unterstützung, Material": boolean;
|
||||||
|
"Prävention von Gewalt und Rechtsextremismus": boolean;
|
||||||
|
"Prävention von sexueller Gewalt": boolean;
|
||||||
|
"Prävention von Sucht": boolean;
|
||||||
|
"Sontiges": boolean;
|
||||||
|
"Übergang in Kita/Schule/Beruf": boolean;
|
||||||
|
};
|
||||||
|
region: {
|
||||||
|
"Batzenberg, Schönberg, Hexental": boolean;
|
||||||
|
"Dreisamtal, Gundelfingen": boolean;
|
||||||
|
"Glottertal": boolean;
|
||||||
|
"Hochschwarzwald": boolean;
|
||||||
|
"Kaiserstuhl, Tuniberg": boolean;
|
||||||
|
"Markgräflerland Nord": boolean;
|
||||||
|
"Markgräflerland Süd": boolean;
|
||||||
|
"Stadt Freiburg": boolean;
|
||||||
|
};
|
||||||
|
zielgruppe: {
|
||||||
|
"Einrichtungen und Vereine": boolean;
|
||||||
|
"Eltern": boolean;
|
||||||
|
"Erwachsene": boolean;
|
||||||
|
"Gemeinden": boolean;
|
||||||
|
"Kinder und Jugendliche": boolean;
|
||||||
|
"Medizinische Fachkräfte": boolean;
|
||||||
|
"Pädagogische Fachkräfte": boolean;
|
||||||
|
"allgemeine Bevölkerung": boolean;
|
||||||
|
};
|
||||||
|
|
||||||
|
altersgruppe: {
|
||||||
|
"0-3 Jahre": boolean;
|
||||||
|
"3-6 Jahre": boolean;
|
||||||
|
"6-10 Jahre": boolean;
|
||||||
|
"10-16 Jahre": boolean;
|
||||||
|
"16-18 Jahre": boolean;
|
||||||
|
"18-27 Jahre": boolean;
|
||||||
|
"Erwachsene": boolean;
|
||||||
|
"Familienphase": boolean;
|
||||||
|
"Senioren und Familien": boolean;
|
||||||
|
};
|
||||||
|
|
||||||
|
geo_lat: number;
|
||||||
|
geo_lon: number;
|
||||||
|
link_title: string;
|
||||||
|
link_url: string;
|
||||||
|
}
|
17
src/app/offers/offers-routing.module.ts
Normal file
17
src/app/offers/offers-routing.module.ts
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import { NgModule } from '@angular/core';
|
||||||
|
import { Routes, RouterModule } from '@angular/router';
|
||||||
|
|
||||||
|
import { OffersPage } from './offers.page';
|
||||||
|
|
||||||
|
const routes: Routes = [
|
||||||
|
{
|
||||||
|
path: '',
|
||||||
|
component: OffersPage
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [RouterModule.forChild(routes)],
|
||||||
|
exports: [RouterModule],
|
||||||
|
})
|
||||||
|
export class OffersPageRoutingModule {}
|
20
src/app/offers/offers.module.ts
Normal file
20
src/app/offers/offers.module.ts
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import { NgModule } from '@angular/core';
|
||||||
|
import { CommonModule } from '@angular/common';
|
||||||
|
import { FormsModule } from '@angular/forms';
|
||||||
|
|
||||||
|
import { IonicModule } from '@ionic/angular';
|
||||||
|
|
||||||
|
import { OffersPageRoutingModule } from './offers-routing.module';
|
||||||
|
|
||||||
|
import { OffersPage } from './offers.page';
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [
|
||||||
|
CommonModule,
|
||||||
|
FormsModule,
|
||||||
|
IonicModule,
|
||||||
|
OffersPageRoutingModule
|
||||||
|
],
|
||||||
|
declarations: [OffersPage]
|
||||||
|
})
|
||||||
|
export class OffersPageModule {}
|
9
src/app/offers/offers.page.html
Normal file
9
src/app/offers/offers.page.html
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<ion-header>
|
||||||
|
<ion-toolbar>
|
||||||
|
<ion-title>offers</ion-title>
|
||||||
|
</ion-toolbar>
|
||||||
|
</ion-header>
|
||||||
|
|
||||||
|
<ion-content>
|
||||||
|
|
||||||
|
</ion-content>
|
0
src/app/offers/offers.page.scss
Normal file
0
src/app/offers/offers.page.scss
Normal file
24
src/app/offers/offers.page.spec.ts
Normal file
24
src/app/offers/offers.page.spec.ts
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
import { IonicModule } from '@ionic/angular';
|
||||||
|
|
||||||
|
import { OffersPage } from './offers.page';
|
||||||
|
|
||||||
|
describe('OffersPage', () => {
|
||||||
|
let component: OffersPage;
|
||||||
|
let fixture: ComponentFixture<OffersPage>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ OffersPage ],
|
||||||
|
imports: [IonicModule.forRoot()]
|
||||||
|
}).compileComponents();
|
||||||
|
|
||||||
|
fixture = TestBed.createComponent(OffersPage);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
}));
|
||||||
|
|
||||||
|
it('should create', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
15
src/app/offers/offers.page.ts
Normal file
15
src/app/offers/offers.page.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import { Component, OnInit } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'app-offers',
|
||||||
|
templateUrl: './offers.page.html',
|
||||||
|
styleUrls: ['./offers.page.scss'],
|
||||||
|
})
|
||||||
|
export class OffersPage implements OnInit {
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
17
src/app/searchresults/searchresults-routing.module.ts
Normal file
17
src/app/searchresults/searchresults-routing.module.ts
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import { NgModule } from '@angular/core';
|
||||||
|
import { Routes, RouterModule } from '@angular/router';
|
||||||
|
|
||||||
|
import { SearchresultsPage } from './searchresults.page';
|
||||||
|
|
||||||
|
const routes: Routes = [
|
||||||
|
{
|
||||||
|
path: '',
|
||||||
|
component: SearchresultsPage
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [RouterModule.forChild(routes)],
|
||||||
|
exports: [RouterModule],
|
||||||
|
})
|
||||||
|
export class SearchresultsPageRoutingModule {}
|
20
src/app/searchresults/searchresults.module.ts
Normal file
20
src/app/searchresults/searchresults.module.ts
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import { NgModule } from '@angular/core';
|
||||||
|
import { CommonModule } from '@angular/common';
|
||||||
|
import { FormsModule } from '@angular/forms';
|
||||||
|
|
||||||
|
import { IonicModule } from '@ionic/angular';
|
||||||
|
|
||||||
|
import { SearchresultsPageRoutingModule } from './searchresults-routing.module';
|
||||||
|
|
||||||
|
import { SearchresultsPage } from './searchresults.page';
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [
|
||||||
|
CommonModule,
|
||||||
|
FormsModule,
|
||||||
|
IonicModule,
|
||||||
|
SearchresultsPageRoutingModule
|
||||||
|
],
|
||||||
|
declarations: [SearchresultsPage]
|
||||||
|
})
|
||||||
|
export class SearchresultsPageModule {}
|
13
src/app/searchresults/searchresults.page.html
Normal file
13
src/app/searchresults/searchresults.page.html
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<ion-header>
|
||||||
|
<ion-toolbar>
|
||||||
|
<ion-buttons slot=start><ion-back-button></ion-back-button></ion-buttons>
|
||||||
|
<ion-title>Suchergebnisse</ion-title>
|
||||||
|
</ion-toolbar>
|
||||||
|
</ion-header>
|
||||||
|
|
||||||
|
<ion-content>
|
||||||
|
<ion-list>
|
||||||
|
|
||||||
|
</ion-list>
|
||||||
|
|
||||||
|
</ion-content>
|
0
src/app/searchresults/searchresults.page.scss
Normal file
0
src/app/searchresults/searchresults.page.scss
Normal file
24
src/app/searchresults/searchresults.page.spec.ts
Normal file
24
src/app/searchresults/searchresults.page.spec.ts
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
import { IonicModule } from '@ionic/angular';
|
||||||
|
|
||||||
|
import { SearchresultsPage } from './searchresults.page';
|
||||||
|
|
||||||
|
describe('SearchresultsPage', () => {
|
||||||
|
let component: SearchresultsPage;
|
||||||
|
let fixture: ComponentFixture<SearchresultsPage>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ SearchresultsPage ],
|
||||||
|
imports: [IonicModule.forRoot()]
|
||||||
|
}).compileComponents();
|
||||||
|
|
||||||
|
fixture = TestBed.createComponent(SearchresultsPage);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
}));
|
||||||
|
|
||||||
|
it('should create', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
15
src/app/searchresults/searchresults.page.ts
Normal file
15
src/app/searchresults/searchresults.page.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import { Component, OnInit } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'app-searchresults',
|
||||||
|
templateUrl: './searchresults.page.html',
|
||||||
|
styleUrls: ['./searchresults.page.scss'],
|
||||||
|
})
|
||||||
|
export class SearchresultsPage implements OnInit {
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,13 +1,12 @@
|
|||||||
<ion-header [translucent]="true">
|
<ion-header [translucent]="true">
|
||||||
<ion-toolbar>
|
<ion-toolbar>
|
||||||
<img
|
<img
|
||||||
src="https://www.breisgau-hochschwarzwald.de/pb/site/Breisgau-Hochschwarzwald/get/params_E491248136/282741/plAn%20Logo.JPG"
|
src="https://www.breisgau-hochschwarzwald.de/pb/site/Breisgau-Hochschwarzwald/get/params_E491248136/282741/plAn%20Logo.JPG"
|
||||||
/>
|
/>
|
||||||
</ion-toolbar>
|
</ion-toolbar>
|
||||||
</ion-header>
|
</ion-header>
|
||||||
|
|
||||||
<ion-content [fullscreen]="true">
|
<ion-content [fullscreen]="true">
|
||||||
|
|
||||||
<ion-searchbar placeholder="Suche"></ion-searchbar>
|
<ion-searchbar placeholder="Suche"></ion-searchbar>
|
||||||
<ion-list>
|
<ion-list>
|
||||||
<ion-item>
|
<ion-item>
|
||||||
@ -63,12 +62,15 @@
|
|||||||
<ion-select-option value="a"
|
<ion-select-option value="a"
|
||||||
>Batzenberg – Schönberg – Hexental</ion-select-option
|
>Batzenberg – Schönberg – Hexental</ion-select-option
|
||||||
>
|
>
|
||||||
<ion-select-option value="b">Dreisamtal, Gundelfingen-Glottertal</ion-select-option>
|
<ion-select-option value="b"
|
||||||
|
>Dreisamtal, Gundelfingen-Glottertal</ion-select-option
|
||||||
|
>
|
||||||
<ion-select-option value="c">Hochschwarzwald</ion-select-option>
|
<ion-select-option value="c">Hochschwarzwald</ion-select-option>
|
||||||
<ion-select-option value="d">Stadt Freiburg</ion-select-option>
|
<ion-select-option value="d">Stadt Freiburg</ion-select-option>
|
||||||
</ion-select>
|
</ion-select>
|
||||||
</ion-item>
|
</ion-item>
|
||||||
|
<ion-button expand="block" [routerLink]="['/searchresults']"
|
||||||
<ion-button expand="block">Suche</ion-button>
|
>Suche</ion-button
|
||||||
|
>
|
||||||
</ion-list>
|
</ion-list>
|
||||||
</ion-content>
|
</ion-content>
|
||||||
|
@ -1,99 +1,15 @@
|
|||||||
import { Component, OnInit } from '@angular/core';
|
import { Component, OnInit } from "@angular/core";
|
||||||
|
import { Offer } from "src/app/offer.model";
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-offer',
|
selector: "app-offer",
|
||||||
templateUrl: './offer.component.html',
|
templateUrl: "./offer.component.html",
|
||||||
styleUrls: ['./offer.component.scss'],
|
styleUrls: ["./offer.component.scss"],
|
||||||
})
|
})
|
||||||
export class OfferComponent implements OnInit {
|
export class OfferComponent implements OnInit {
|
||||||
adr_anfahrt: string;
|
private static instance: Offer;
|
||||||
adr_hausnr: string;
|
|
||||||
adr_ort: string;
|
|
||||||
adr_plz: string;
|
|
||||||
adr_strasse: string;
|
|
||||||
con_fax: string;
|
|
||||||
con_mobile: string;
|
|
||||||
con_tel: string;
|
|
||||||
descr_einrichtung: string;
|
|
||||||
descr_long: string;
|
|
||||||
descr_short: string;
|
|
||||||
descr_titel: string;
|
|
||||||
descr_zusatz: string;
|
|
||||||
descr_date: Date;
|
|
||||||
detail_anmeldung: string;
|
|
||||||
detail_gender: string;
|
|
||||||
detail_cost: string;
|
|
||||||
details_teilnehmer: string;
|
|
||||||
details_zeit: string;
|
|
||||||
details_ziel: string;
|
|
||||||
detail_methods: string;
|
|
||||||
categories: {
|
|
||||||
"Elternbildung": boolean,
|
|
||||||
"Soziale Teilhabe": boolean,
|
|
||||||
"Beratung": boolean,
|
|
||||||
"Erährung und Bewegung": boolean,
|
|
||||||
"Familienfreundliche Angebote": boolean,
|
|
||||||
"Förderung der allgem. Lebenskompetenz": boolean,
|
|
||||||
"Frühe Hilfen": boolean,
|
|
||||||
"Körperliche Gesundheit": boolean,
|
|
||||||
"Seelische Gesundheit": boolean,
|
|
||||||
"Inklusion": boolean,
|
|
||||||
"Medienpädagogik/-kompetenz": boolean,
|
|
||||||
"Migration und Integration": boolean,
|
|
||||||
"Offene Familientreffs": boolean,
|
|
||||||
"Partnerschaft und Sexualität": boolean,
|
|
||||||
"Planung, Unterstützung, Material": boolean,
|
|
||||||
"Prävention von Gewalt und Rechtsextremismus": boolean,
|
|
||||||
"Prävention von sexueller Gewalt": boolean,
|
|
||||||
"Prävention von Sucht": boolean,
|
|
||||||
"Sontiges": boolean,
|
|
||||||
"Übergang in Kita/Schule/Beruf": boolean,
|
|
||||||
}
|
|
||||||
region: {
|
|
||||||
"Batzenberg, Schönberg, Hexental": boolean;
|
|
||||||
"Dreisamtal, Gundelfingen": boolean;
|
|
||||||
"Glottertal": boolean;
|
|
||||||
"Hochschwarzwald": boolean;
|
|
||||||
"Kaiserstuhl, Tuniberg": boolean;
|
|
||||||
"Markgräflerland Nord": boolean;
|
|
||||||
"Markgräflerland Süd": boolean;
|
|
||||||
"Stadt Freiburg": boolean;
|
|
||||||
}
|
|
||||||
zielgruppe: {
|
|
||||||
"Einrichtungen und Vereine" : boolean;
|
|
||||||
"Eltern" : boolean;
|
|
||||||
"Erwachsene" : boolean;
|
|
||||||
"Gemeinden" : boolean;
|
|
||||||
"Kinder und Jugendliche" : boolean;
|
|
||||||
"Medizinische Fachkräfte" : boolean;
|
|
||||||
"Pädagogische Fachkräfte" : boolean;
|
|
||||||
"allgemeine Bevölkerung" : boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
altergruppe: {
|
private constructor() {}
|
||||||
"0-3 Jahre": boolean;
|
|
||||||
"3-6 Jahre": boolean;
|
|
||||||
"6-10 Jahre": boolean;
|
|
||||||
"10-16 Jahre": boolean;
|
|
||||||
"16-18 Jahre": boolean;
|
|
||||||
"18-27 Jahre": boolean;
|
|
||||||
"Erwachsene": boolean;
|
|
||||||
"Familienphase": boolean;
|
|
||||||
"Senioren und Familien": boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
geo_lat: number;
|
|
||||||
geo_lon: number;
|
|
||||||
link_title: string;
|
|
||||||
link_url: string;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
constructor() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
ngOnInit() {}
|
ngOnInit() {}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user