mirror of
https://gitlab.com/openstapps/openstapps.git
synced 2026-01-23 10:02:51 +00:00
Compare commits
2 Commits
@openstapp
...
623673440d
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
623673440d | ||
|
c1883abb50
|
5
.changeset/forty-bulldogs-help.md
Normal file
5
.changeset/forty-bulldogs-help.md
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
"@openstapps/app": patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Migrated IonIcons replacer to a custom component
|
||||||
7
.changeset/thin-dodos-thank.md
Normal file
7
.changeset/thin-dodos-thank.md
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
"@openstapps/app": patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Migrated to Ionic standalone components
|
||||||
|
|
||||||
|
Angular ESBuild will not work with `IonicModule` apps
|
||||||
5
.changeset/yellow-jobs-guess.md
Normal file
5
.changeset/yellow-jobs-guess.md
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
"@openstapps/app": patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Migrated to Angular ESBuild
|
||||||
@@ -67,9 +67,9 @@ build:
|
|||||||
# "🦋 error Error: Failed to find where HEAD diverged from master. Does master exist?"
|
# "🦋 error Error: Failed to find where HEAD diverged from master. Does master exist?"
|
||||||
# - pnpm changeset:status
|
# - pnpm changeset:status
|
||||||
- pnpm build:full $TURBO_CACHE_BYPASS
|
- pnpm build:full $TURBO_CACHE_BYPASS
|
||||||
- .gitlab/ci/enableGitlabReviewToolbar.sh frontend/app/www/index.html "$CI_PROJECT_ID" "$CI_OPEN_MERGE_REQUESTS"
|
- .gitlab/ci/enableGitlabReviewToolbar.sh frontend/app/www/browser/index.html "$CI_PROJECT_ID" "$CI_OPEN_MERGE_REQUESTS"
|
||||||
- cp frontend/app/www/index.html frontend/app/www/200.html
|
- cp frontend/app/www/browser/index.html frontend/app/www/browser/200.html
|
||||||
- pnpm dlx surge -p frontend/app/www -d https://$CI_PROJECT_NAME-$DEPLOY_ID.surge.sh/
|
- pnpm dlx surge -p frontend/app/www/browser -d https://$CI_PROJECT_NAME-$DEPLOY_ID.surge.sh/
|
||||||
cache:
|
cache:
|
||||||
<<: *pnpm_cache
|
<<: *pnpm_cache
|
||||||
policy: pull-push
|
policy: pull-push
|
||||||
|
|||||||
85
flake.nix
85
flake.nix
@@ -4,68 +4,71 @@
|
|||||||
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
|
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
|
||||||
flake-utils.url = "github:numtide/flake-utils";
|
flake-utils.url = "github:numtide/flake-utils";
|
||||||
};
|
};
|
||||||
outputs = {
|
outputs =
|
||||||
|
{
|
||||||
self,
|
self,
|
||||||
nixpkgs,
|
nixpkgs,
|
||||||
flake-utils,
|
flake-utils,
|
||||||
}: let
|
}:
|
||||||
|
let
|
||||||
aapt2buildToolsVersion = "33.0.2";
|
aapt2buildToolsVersion = "33.0.2";
|
||||||
in
|
in
|
||||||
flake-utils.lib.eachDefaultSystem (system: let
|
flake-utils.lib.eachDefaultSystem (
|
||||||
|
system:
|
||||||
|
let
|
||||||
pkgs = import nixpkgs {
|
pkgs = import nixpkgs {
|
||||||
inherit system;
|
inherit system;
|
||||||
overlays = [
|
|
||||||
(final: prev: rec {
|
|
||||||
fontMin = prev.python311.withPackages (ps: with ps; [brotli fonttools] ++ (with fonttools.optional-dependencies; [woff]));
|
|
||||||
android = prev.androidenv.composeAndroidPackages {
|
|
||||||
buildToolsVersions = ["30.0.3" aapt2buildToolsVersion];
|
|
||||||
platformVersions = ["33"];
|
|
||||||
};
|
|
||||||
cypress = prev.cypress.overrideAttrs (cyPrev: rec {
|
|
||||||
version = "13.2.0";
|
|
||||||
src = prev.fetchzip {
|
|
||||||
url = "https://cdn.cypress.io/desktop/${version}/linux-x64/cypress.zip";
|
|
||||||
hash = "sha256-9o0nprGcJhudS1LNm+T7Vf0Dwd1RBauYKI+w1FBQ3ZM=";
|
|
||||||
};
|
|
||||||
});
|
|
||||||
nodejs = prev.nodejs_18;
|
|
||||||
})
|
|
||||||
];
|
|
||||||
config = {
|
config = {
|
||||||
allowUnfree = true;
|
allowUnfree = true;
|
||||||
android_sdk.accept_license = true;
|
android_sdk.accept_license = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
androidFhs = pkgs.buildFHSUserEnv {
|
fontMin = pkgs.python311.withPackages (
|
||||||
name = "android-env";
|
ps:
|
||||||
targetPkgs = pkgs: with pkgs; [];
|
with ps;
|
||||||
runScript = "bash";
|
[
|
||||||
profile = ''
|
brotli
|
||||||
export ALLOW_NINJA_ENV=true
|
fonttools
|
||||||
export USE_CCACHE=1
|
]
|
||||||
export LD_LIBRARY_PATH=/usr/lib:/usr/lib32
|
++ (with fonttools.optional-dependencies; [ woff ])
|
||||||
'';
|
);
|
||||||
|
android = pkgs.androidenv.composeAndroidPackages {
|
||||||
|
buildToolsVersions = [
|
||||||
|
"30.0.3"
|
||||||
|
aapt2buildToolsVersion
|
||||||
|
];
|
||||||
|
platformVersions = [ "33" ];
|
||||||
};
|
};
|
||||||
in {
|
androidJdk = pkgs.jdk17;
|
||||||
|
cypress = pkgs.cypress.overrideAttrs (cyPrev: rec {
|
||||||
|
version = "13.2.0";
|
||||||
|
src = pkgs.fetchzip {
|
||||||
|
url = "https://cdn.cypress.io/desktop/${version}/linux-x64/cypress.zip";
|
||||||
|
hash = "sha256-9o0nprGcJhudS1LNm+T7Vf0Dwd1RBauYKI+w1FBQ3ZM=";
|
||||||
|
};
|
||||||
|
});
|
||||||
|
in
|
||||||
|
{
|
||||||
devShell = pkgs.mkShell rec {
|
devShell = pkgs.mkShell rec {
|
||||||
nativeBuildInputs = [androidFhs];
|
buildInputs = [
|
||||||
buildInputs = with pkgs; [
|
pkgs.nodejs_18
|
||||||
nodejs
|
pkgs.corepack
|
||||||
corepack
|
|
||||||
# tools
|
# tools
|
||||||
curl
|
pkgs.curl
|
||||||
jq
|
pkgs.jq
|
||||||
fontMin
|
fontMin
|
||||||
cypress
|
cypress
|
||||||
# android
|
# android
|
||||||
jdk17
|
androidJdk
|
||||||
android.androidsdk
|
android.androidsdk
|
||||||
];
|
];
|
||||||
ANDROID_JAVA_HOME = "${pkgs.jdk.home}";
|
ANDROID_JAVA_HOME = "${androidJdk.home}";
|
||||||
ANDROID_SDK_ROOT = "${pkgs.android.androidsdk}/libexec/android-sdk";
|
ANDROID_SDK_ROOT = "${android.androidsdk}/libexec/android-sdk";
|
||||||
GRADLE_OPTS = "-Dorg.gradle.project.android.aapt2FromMavenOverride=${ANDROID_SDK_ROOT}/build-tools/${aapt2buildToolsVersion}/aapt2";
|
GRADLE_OPTS = "-Dorg.gradle.project.android.aapt2FromMavenOverride=${ANDROID_SDK_ROOT}/build-tools/${aapt2buildToolsVersion}/aapt2";
|
||||||
CYPRESS_INSTALL_BINARY = "0";
|
CYPRESS_INSTALL_BINARY = "0";
|
||||||
CYPRESS_RUN_BINARY = "${pkgs.cypress}/bin/Cypress";
|
CYPRESS_RUN_BINARY = "${cypress}/bin/Cypress";
|
||||||
|
CHROME_BIN = pkgs.lib.getExe pkgs.chromium;
|
||||||
};
|
};
|
||||||
});
|
}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,10 +4,10 @@
|
|||||||
FROM node:18-alpine3.18
|
FROM node:18-alpine3.18
|
||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY www/ /app/www
|
COPY www/browser /app/www/browser
|
||||||
COPY package.json /app
|
COPY package.json /app
|
||||||
|
|
||||||
EXPOSE 8100
|
EXPOSE 8100
|
||||||
|
|
||||||
RUN npm install -g http-server
|
RUN npm install -g http-server
|
||||||
CMD http-server www --p 8100
|
CMD http-server www/browser --p 8100
|
||||||
|
|||||||
@@ -11,12 +11,12 @@
|
|||||||
"schematics": {},
|
"schematics": {},
|
||||||
"architect": {
|
"architect": {
|
||||||
"build": {
|
"build": {
|
||||||
"builder": "@angular-devkit/build-angular:browser",
|
"builder": "@angular-devkit/build-angular:application",
|
||||||
"options": {
|
"options": {
|
||||||
"outputPath": "www",
|
"outputPath": "www",
|
||||||
"index": "src/index.html",
|
"index": "src/index.html",
|
||||||
"main": "src/main.ts",
|
"browser": "src/main.ts",
|
||||||
"polyfills": "zone.js",
|
"polyfills": ["zone.js", "src/ion-icons.js"],
|
||||||
"tsConfig": "tsconfig.app.json",
|
"tsConfig": "tsconfig.app.json",
|
||||||
"allowedCommonJsDependencies": [
|
"allowedCommonJsDependencies": [
|
||||||
"moment",
|
"moment",
|
||||||
@@ -67,9 +67,7 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"development": {
|
"development": {
|
||||||
"buildOptimizer": false,
|
|
||||||
"optimization": false,
|
"optimization": false,
|
||||||
"vendorChunk": true,
|
|
||||||
"extractLicenses": false,
|
"extractLicenses": false,
|
||||||
"sourceMap": true,
|
"sourceMap": true,
|
||||||
"namedChunks": true
|
"namedChunks": true
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import {CapacitorConfig} from '@capacitor/cli';
|
|||||||
const config: CapacitorConfig = {
|
const config: CapacitorConfig = {
|
||||||
appId: 'de.anyschool.app',
|
appId: 'de.anyschool.app',
|
||||||
appName: 'StApps',
|
appName: 'StApps',
|
||||||
webDir: 'www',
|
webDir: 'www/browser',
|
||||||
cordova: {
|
cordova: {
|
||||||
preferences: {
|
preferences: {
|
||||||
'AndroidXEnabled': 'true',
|
'AndroidXEnabled': 'true',
|
||||||
|
|||||||
@@ -14,12 +14,9 @@
|
|||||||
"Thea Schöbl <dev@theaninova.de>"
|
"Thea Schöbl <dev@theaninova.de>"
|
||||||
],
|
],
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"analyze": "webpack-bundle-analyzer www/stats.json",
|
"build": "pnpm check-icons && ng build --configuration=production",
|
||||||
"build": "pnpm check-icons && ng build --configuration=production --stats-json && webpack-bundle-analyzer www/stats.json --mode static --report www/bundle-info.html --no-open",
|
|
||||||
"build:analyze": "npm run build:stats && npm run analyze",
|
|
||||||
"build:android": "ionic capacitor build android --no-open && cd android && ./gradlew clean assemble && cd ..",
|
"build:android": "ionic capacitor build android --no-open && cd android && ./gradlew clean assemble && cd ..",
|
||||||
"build:prod": "ng build --configuration=production",
|
"build:prod": "ng build --configuration=production",
|
||||||
"build:stats": "ng build --configuration=production --stats-json",
|
|
||||||
"changelog": "conventional-changelog -p angular -i src/assets/about/CHANGELOG.md -s -r 0",
|
"changelog": "conventional-changelog -p angular -i src/assets/about/CHANGELOG.md -s -r 0",
|
||||||
"check-icons": "node scripts/check-icon-correctness.mjs",
|
"check-icons": "node scripts/check-icon-correctness.mjs",
|
||||||
"chromium:no-cors": "chromium --disable-web-security --user-data-dir=\".browser-data/chromium\"",
|
"chromium:no-cors": "chromium --disable-web-security --user-data-dir=\".browser-data/chromium\"",
|
||||||
@@ -40,7 +37,7 @@
|
|||||||
"lint:fix": "eslint --fix -c .eslintrc.json --ignore-path .eslintignore --ext .ts,.html src/ && stylelint --fix \"**/*.scss\"",
|
"lint:fix": "eslint --fix -c .eslintrc.json --ignore-path .eslintignore --ext .ts,.html src/ && stylelint --fix \"**/*.scss\"",
|
||||||
"minify-icons": "node scripts/minify-icon-font.mjs",
|
"minify-icons": "node scripts/minify-icon-font.mjs",
|
||||||
"postinstall": "jetify && echo \"skipping jetify in production mode\"",
|
"postinstall": "jetify && echo \"skipping jetify in production mode\"",
|
||||||
"preview": "http-server www --p 8101 -o",
|
"preview": "http-server www/browser --p 8101 -o",
|
||||||
"push": "git push && git push origin \"v$npm_package_version\"",
|
"push": "git push && git push origin \"v$npm_package_version\"",
|
||||||
"resources:ios": "capacitor-assets generate --ios --iconBackgroundColor $(grep -oE \"^@include ion-color\\(primary, #[a-fA-F0-9]{3,6}\" src/theme/colors.scss | grep -oE \"#[a-fA-F0-9]{3,6}\") --splashBackgroundColor $(grep -oE \"^@include ion-color\\(primary, #[a-fA-F0-9]{3,6}\" src/theme/colors.scss | grep -oE \"#[a-fA-F0-9]{3,6}\")",
|
"resources:ios": "capacitor-assets generate --ios --iconBackgroundColor $(grep -oE \"^@include ion-color\\(primary, #[a-fA-F0-9]{3,6}\" src/theme/colors.scss | grep -oE \"#[a-fA-F0-9]{3,6}\") --splashBackgroundColor $(grep -oE \"^@include ion-color\\(primary, #[a-fA-F0-9]{3,6}\" src/theme/colors.scss | grep -oE \"#[a-fA-F0-9]{3,6}\")",
|
||||||
"run:android": "ionic capacitor run android --livereload --external",
|
"run:android": "ionic capacitor run android --livereload --external",
|
||||||
@@ -97,6 +94,7 @@
|
|||||||
"form-data": "4.0.0",
|
"form-data": "4.0.0",
|
||||||
"geojson": "0.5.0",
|
"geojson": "0.5.0",
|
||||||
"ionic-appauth": "0.9.0",
|
"ionic-appauth": "0.9.0",
|
||||||
|
"ionicons": "7.4.0",
|
||||||
"jsonpath-plus": "6.0.1",
|
"jsonpath-plus": "6.0.1",
|
||||||
"maplibre-gl": "4.0.2",
|
"maplibre-gl": "4.0.2",
|
||||||
"material-symbols": "0.17.1",
|
"material-symbols": "0.17.1",
|
||||||
@@ -181,8 +179,7 @@
|
|||||||
"stylelint-config-standard-scss": "13.0.0",
|
"stylelint-config-standard-scss": "13.0.0",
|
||||||
"surge": "0.23.1",
|
"surge": "0.23.1",
|
||||||
"ts-node": "10.9.2",
|
"ts-node": "10.9.2",
|
||||||
"typescript": "5.4.2",
|
"typescript": "5.4.2"
|
||||||
"webpack-bundle-analyzer": "4.10.1"
|
|
||||||
},
|
},
|
||||||
"cordova": {
|
"cordova": {
|
||||||
"plugins": {},
|
"plugins": {},
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {AnimationBuilder, AnimationController} from '@ionic/angular';
|
import {AnimationBuilder, AnimationController} from '@ionic/angular/standalone';
|
||||||
import {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
import {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
||||||
import {iosDuration, iosEasing, mdDuration, mdEasing} from './easings';
|
import {iosDuration, iosEasing, mdDuration, mdEasing} from './easings';
|
||||||
|
|
||||||
|
|||||||
@@ -17,7 +17,7 @@
|
|||||||
import {CUSTOM_ELEMENTS_SCHEMA} from '@angular/core';
|
import {CUSTOM_ELEMENTS_SCHEMA} from '@angular/core';
|
||||||
import {TestBed} from '@angular/core/testing';
|
import {TestBed} from '@angular/core/testing';
|
||||||
|
|
||||||
import {ModalController, Platform} from '@ionic/angular';
|
import {ModalController, Platform} from '@ionic/angular/standalone';
|
||||||
|
|
||||||
import {TranslateService} from '@ngx-translate/core';
|
import {TranslateService} from '@ngx-translate/core';
|
||||||
import {ThingTranslateService} from './translation/thing-translate.service';
|
import {ThingTranslateService} from './translation/thing-translate.service';
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
import {AfterContentInit, Component, NgZone} from '@angular/core';
|
import {AfterContentInit, Component, NgZone} from '@angular/core';
|
||||||
import {Router} from '@angular/router';
|
import {Router} from '@angular/router';
|
||||||
import {App, URLOpenListenerEvent} from '@capacitor/app';
|
import {App, URLOpenListenerEvent} from '@capacitor/app';
|
||||||
import {Platform, ToastController} from '@ionic/angular';
|
import {Platform, ToastController} from '@ionic/angular/standalone';
|
||||||
import {SettingsProvider} from './modules/settings/settings.provider';
|
import {SettingsProvider} from './modules/settings/settings.provider';
|
||||||
import {AuthHelperService} from './modules/auth/auth-helper.service';
|
import {AuthHelperService} from './modules/auth/auth-helper.service';
|
||||||
import {environment} from '../environments/environment';
|
import {environment} from '../environments/environment';
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ import localeDe from '@angular/common/locales/de';
|
|||||||
import {APP_INITIALIZER, NgModule} from '@angular/core';
|
import {APP_INITIALIZER, NgModule} from '@angular/core';
|
||||||
import {BrowserModule} from '@angular/platform-browser';
|
import {BrowserModule} from '@angular/platform-browser';
|
||||||
import {RouteReuseStrategy} from '@angular/router';
|
import {RouteReuseStrategy} from '@angular/router';
|
||||||
import {IonicModule, IonicRouteStrategy, Platform} from '@ionic/angular';
|
import {IonicRouteStrategy, Platform, provideIonicAngular, IonApp} from '@ionic/angular/standalone';
|
||||||
import {TranslateLoader, TranslateModule, TranslateService} from '@ngx-translate/core';
|
import {TranslateLoader, TranslateModule, TranslateService} from '@ngx-translate/core';
|
||||||
import {TranslateHttpLoader} from '@ngx-translate/http-loader';
|
import {TranslateHttpLoader} from '@ngx-translate/http-loader';
|
||||||
import moment from 'moment';
|
import moment from 'moment';
|
||||||
@@ -61,7 +61,6 @@ import {RoutingStackService} from './util/routing-stack.service';
|
|||||||
import {SCLanguageCode, SCSettingValue} from '@openstapps/core';
|
import {SCLanguageCode, SCSettingValue} from '@openstapps/core';
|
||||||
import {DefaultAuthService} from './modules/auth/default-auth.service';
|
import {DefaultAuthService} from './modules/auth/default-auth.service';
|
||||||
import {PAIAAuthService} from './modules/auth/paia/paia-auth.service';
|
import {PAIAAuthService} from './modules/auth/paia/paia-auth.service';
|
||||||
import {IonIconModule} from './util/ion-icon/ion-icon.module';
|
|
||||||
import {NavigationModule} from './modules/menu/navigation/navigation.module';
|
import {NavigationModule} from './modules/menu/navigation/navigation.module';
|
||||||
import {browserFactory, SimpleBrowser} from './util/browser.factory';
|
import {browserFactory, SimpleBrowser} from './util/browser.factory';
|
||||||
import {getDateFnsLocale} from './translation/dfns-locale';
|
import {getDateFnsLocale} from './translation/dfns-locale';
|
||||||
@@ -156,8 +155,6 @@ export function createTranslateLoader(http: HttpClient) {
|
|||||||
DashboardModule,
|
DashboardModule,
|
||||||
DataModule,
|
DataModule,
|
||||||
HebisModule,
|
HebisModule,
|
||||||
IonicModule.forRoot(),
|
|
||||||
IonIconModule,
|
|
||||||
JobModule,
|
JobModule,
|
||||||
FavoritesModule,
|
FavoritesModule,
|
||||||
LibraryModule,
|
LibraryModule,
|
||||||
@@ -185,6 +182,7 @@ export function createTranslateLoader(http: HttpClient) {
|
|||||||
LoggerModule.forRoot({
|
LoggerModule.forRoot({
|
||||||
level: environment.production ? NgxLoggerLevel.FATAL : NgxLoggerLevel.TRACE,
|
level: environment.production ? NgxLoggerLevel.FATAL : NgxLoggerLevel.TRACE,
|
||||||
}),
|
}),
|
||||||
|
IonApp,
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
{
|
{
|
||||||
@@ -221,6 +219,7 @@ export function createTranslateLoader(http: HttpClient) {
|
|||||||
useClass: ServiceHandlerInterceptor,
|
useClass: ServiceHandlerInterceptor,
|
||||||
multi: true,
|
multi: true,
|
||||||
},
|
},
|
||||||
|
provideIonicAngular(),
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
export class AppModule {
|
export class AppModule {
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Component, OnInit} from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
import {ModalController} from '@ionic/angular';
|
import {ModalController} from '@ionic/angular/standalone';
|
||||||
import {AboutLicenseModalComponent} from './about-license-modal.component';
|
import {AboutLicenseModalComponent} from './about-license-modal.component';
|
||||||
import licensesFile from 'src/assets/about/licenses.json';
|
import licensesFile from 'src/assets/about/licenses.json';
|
||||||
|
|
||||||
|
|||||||
@@ -16,7 +16,6 @@ import {RouterModule, Routes} from '@angular/router';
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {AboutPageComponent} from './about-page/about-page.component';
|
import {AboutPageComponent} from './about-page/about-page.component';
|
||||||
@@ -28,7 +27,30 @@ import {ScrollingModule} from '@angular/cdk/scrolling';
|
|||||||
import {AboutLicenseModalComponent} from './about-license-modal.component';
|
import {AboutLicenseModalComponent} from './about-license-modal.component';
|
||||||
import {AboutChangelogComponent} from './about-changelog.component';
|
import {AboutChangelogComponent} from './about-changelog.component';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCardSubtitle,
|
||||||
|
IonCardTitle,
|
||||||
|
IonChip,
|
||||||
|
IonCol,
|
||||||
|
IonContent,
|
||||||
|
IonGrid,
|
||||||
|
IonHeader,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonRouterLink,
|
||||||
|
IonRow,
|
||||||
|
IonSkeletonText,
|
||||||
|
IonText,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const settingsRoutes: Routes = [
|
const settingsRoutes: Routes = [
|
||||||
{path: 'about', component: AboutPageComponent},
|
{path: 'about', component: AboutPageComponent},
|
||||||
@@ -52,9 +74,8 @@ const settingsRoutes: Routes = [
|
|||||||
],
|
],
|
||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonicModule.forRoot(),
|
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
ThingTranslateModule.forChild(),
|
ThingTranslateModule.forChild(),
|
||||||
RouterModule.forChild(settingsRoutes),
|
RouterModule.forChild(settingsRoutes),
|
||||||
@@ -62,6 +83,27 @@ const settingsRoutes: Routes = [
|
|||||||
DataModule,
|
DataModule,
|
||||||
ScrollingModule,
|
ScrollingModule,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonRouterLink,
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonText,
|
||||||
|
IonSkeletonText,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
IonHeader,
|
||||||
|
IonLabel,
|
||||||
|
IonGrid,
|
||||||
|
IonRow,
|
||||||
|
IonCol,
|
||||||
|
IonCard,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCardTitle,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardSubtitle,
|
||||||
|
IonChip,
|
||||||
|
IonList,
|
||||||
|
IonContent,
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
export class AboutModule {}
|
export class AboutModule {}
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import {Injectable} from '@angular/core';
|
import {Injectable} from '@angular/core';
|
||||||
import {StorageProvider} from '../storage/storage.provider';
|
import {StorageProvider} from '../storage/storage.provider';
|
||||||
import {ConfigProvider} from '../config/config.provider';
|
import {ConfigProvider} from '../config/config.provider';
|
||||||
import {ModalController} from '@ionic/angular';
|
import {ModalController} from '@ionic/angular/standalone';
|
||||||
import {Capacitor} from '@capacitor/core';
|
import {Capacitor} from '@capacitor/core';
|
||||||
import {ReleaseNotesComponent} from './release-notes.component';
|
import {ReleaseNotesComponent} from './release-notes.component';
|
||||||
import {SCAppVersionInfo} from '@openstapps/core';
|
import {SCAppVersionInfo} from '@openstapps/core';
|
||||||
|
|||||||
@@ -2,7 +2,14 @@ import {ChangeDetectionStrategy, Component, Input} from '@angular/core';
|
|||||||
import {SCAppVersionInfo} from '@openstapps/core';
|
import {SCAppVersionInfo} from '@openstapps/core';
|
||||||
import {MarkdownModule} from 'ngx-markdown';
|
import {MarkdownModule} from 'ngx-markdown';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {IonicModule, ModalController} from '@ionic/angular';
|
import {
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonHeader,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
ModalController,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
|
|
||||||
@@ -12,7 +19,17 @@ import {UtilModule} from '../../util/util.module';
|
|||||||
styleUrls: ['release-notes.scss'],
|
styleUrls: ['release-notes.scss'],
|
||||||
standalone: true,
|
standalone: true,
|
||||||
changeDetection: ChangeDetectionStrategy.OnPush,
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
||||||
imports: [UtilModule, MarkdownModule, ThingTranslateModule, IonicModule, TranslateModule],
|
imports: [
|
||||||
|
UtilModule,
|
||||||
|
MarkdownModule,
|
||||||
|
ThingTranslateModule,
|
||||||
|
TranslateModule,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonToolbar,
|
||||||
|
IonHeader,
|
||||||
|
IonTitle,
|
||||||
|
],
|
||||||
})
|
})
|
||||||
export class ReleaseNotesComponent {
|
export class ReleaseNotesComponent {
|
||||||
@Input() versionInfos: SCAppVersionInfo[];
|
@Input() versionInfos: SCAppVersionInfo[];
|
||||||
|
|||||||
@@ -19,7 +19,6 @@ import {AssessmentBaseInfoComponent} from './types/assessment/assessment-base-in
|
|||||||
import {AssessmentDetailComponent} from './types/assessment/assessment-detail.component';
|
import {AssessmentDetailComponent} from './types/assessment/assessment-detail.component';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {DataModule} from '../data/data.module';
|
import {DataModule} from '../data/data.module';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
@@ -35,8 +34,25 @@ import {AssessmentsProvider} from './assessments.provider';
|
|||||||
import {AssessmentsSimpleDataListComponent} from './list/assessments-simple-data-list.component';
|
import {AssessmentsSimpleDataListComponent} from './list/assessments-simple-data-list.component';
|
||||||
import {ProtectedRoutes} from '../auth/protected.routes';
|
import {ProtectedRoutes} from '../auth/protected.routes';
|
||||||
import {AssessmentsTreeListComponent} from './list/assessments-tree-list.component';
|
import {AssessmentsTreeListComponent} from './list/assessments-tree-list.component';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
|
import {
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonContent,
|
||||||
|
IonHeader,
|
||||||
|
IonItem,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonNote,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const routes: ProtectedRoutes = [
|
const routes: ProtectedRoutes = [
|
||||||
{
|
{
|
||||||
@@ -69,14 +85,28 @@ const routes: ProtectedRoutes = [
|
|||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
IonicModule,
|
|
||||||
RouterModule.forChild(routes),
|
RouterModule.forChild(routes),
|
||||||
TranslateModule,
|
TranslateModule,
|
||||||
DataModule,
|
DataModule,
|
||||||
ThingTranslateModule,
|
ThingTranslateModule,
|
||||||
MomentModule,
|
MomentModule,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonBackButton,
|
||||||
|
IonList,
|
||||||
|
IonItem,
|
||||||
|
IonNote,
|
||||||
|
IonCardContent,
|
||||||
|
IonCard,
|
||||||
|
IonLabel,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonButtons,
|
||||||
|
IonTitle,
|
||||||
|
IonContent,
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonButton,
|
||||||
],
|
],
|
||||||
providers: [AssessmentsProvider],
|
providers: [AssessmentsProvider],
|
||||||
exports: [],
|
exports: [],
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ import {Component, DestroyRef, inject, Input, OnInit, ViewChild} from '@angular/
|
|||||||
import {ActivatedRoute} from '@angular/router';
|
import {ActivatedRoute} from '@angular/router';
|
||||||
import {AssessmentsProvider} from '../assessments.provider';
|
import {AssessmentsProvider} from '../assessments.provider';
|
||||||
import {DataDetailComponent, ExternalDataLoadEvent} from '../../data/detail/data-detail.component';
|
import {DataDetailComponent, ExternalDataLoadEvent} from '../../data/detail/data-detail.component';
|
||||||
import {NavController} from '@ionic/angular';
|
import {NavController} from '@ionic/angular/standalone';
|
||||||
import {DataRoutingService} from '../../data/data-routing.service';
|
import {DataRoutingService} from '../../data/data-routing.service';
|
||||||
import {SCAssessment} from '@openstapps/core';
|
import {SCAssessment} from '@openstapps/core';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Component} from '@angular/core';
|
import {Component} from '@angular/core';
|
||||||
import {NavController} from '@ionic/angular';
|
import {NavController} from '@ionic/angular/standalone';
|
||||||
import {Router} from '@angular/router';
|
import {Router} from '@angular/router';
|
||||||
import {AuthActions, IAuthAction} from 'ionic-appauth';
|
import {AuthActions, IAuthAction} from 'ionic-appauth';
|
||||||
import {AuthHelperService} from '../../auth-helper.service';
|
import {AuthHelperService} from '../../auth-helper.service';
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ import {StorageProvider} from '../storage/storage.provider';
|
|||||||
import {DefaultAuthService} from './default-auth.service';
|
import {DefaultAuthService} from './default-auth.service';
|
||||||
import {PAIAAuthService} from './paia/paia-auth.service';
|
import {PAIAAuthService} from './paia/paia-auth.service';
|
||||||
import {SimpleBrowser} from '../../util/browser.factory';
|
import {SimpleBrowser} from '../../util/browser.factory';
|
||||||
import {AlertController} from '@ionic/angular';
|
import {AlertController} from '@ionic/angular/standalone';
|
||||||
|
|
||||||
const AUTH_ORIGIN_PATH = 'stapps.auth.origin_path';
|
const AUTH_ORIGIN_PATH = 'stapps.auth.origin_path';
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {Platform} from '@ionic/angular';
|
import {Platform} from '@ionic/angular/standalone';
|
||||||
import {Requestor, StorageBackend} from '@openid/appauth';
|
import {Requestor, StorageBackend} from '@openid/appauth';
|
||||||
import {storageFactory} from './factories';
|
import {storageFactory} from './factories';
|
||||||
import {Browser} from 'ionic-appauth';
|
import {Browser} from 'ionic-appauth';
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import {HttpClient} from '@angular/common/http';
|
import {HttpClient} from '@angular/common/http';
|
||||||
import {Platform} from '@ionic/angular';
|
import {Platform} from '@ionic/angular/standalone';
|
||||||
import {CapacitorRequestor} from '../capacitor-requestor';
|
import {CapacitorRequestor} from '../capacitor-requestor';
|
||||||
import {NgHttpService} from '../ng-http.service';
|
import {NgHttpService} from '../ng-http.service';
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {Platform} from '@ionic/angular';
|
import {Platform} from '@ionic/angular/standalone';
|
||||||
import {IonicStorage} from 'ionic-appauth/lib';
|
import {IonicStorage} from 'ionic-appauth/lib';
|
||||||
import {SafeCapacitorSecureStorage} from '../../storage/capacitor-secure-storage';
|
import {SafeCapacitorSecureStorage} from '../../storage/capacitor-secure-storage';
|
||||||
|
|
||||||
|
|||||||
@@ -67,7 +67,7 @@
|
|||||||
<div class="horizontal-flex">
|
<div class="horizontal-flex">
|
||||||
<ion-button fill="clear" (click)="export()">
|
<ion-button fill="clear" (click)="export()">
|
||||||
{{ 'share' | translate }}
|
{{ 'share' | translate }}
|
||||||
<ion-icon slot="end" md="share" ios="ios_share"></ion-icon>
|
<ion-icon slot="end" name="share"></ion-icon>
|
||||||
</ion-button>
|
</ion-button>
|
||||||
@if (isWeb) {
|
@if (isWeb) {
|
||||||
<ion-button fill="outline" (click)="download()">
|
<ion-button fill="outline" (click)="download()">
|
||||||
|
|||||||
@@ -18,26 +18,46 @@ import {AddEventReviewModalComponent} from './add-event-review-modal.component';
|
|||||||
import {Calendar} from '@awesome-cordova-plugins/calendar/ngx';
|
import {Calendar} from '@awesome-cordova-plugins/calendar/ngx';
|
||||||
import {CalendarService} from './calendar.service';
|
import {CalendarService} from './calendar.service';
|
||||||
import {ScheduleProvider} from './schedule.provider';
|
import {ScheduleProvider} from './schedule.provider';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {MomentModule} from 'ngx-moment';
|
import {MomentModule} from 'ngx-moment';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonButton,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCardTitle,
|
||||||
|
IonItem,
|
||||||
|
IonItemDivider,
|
||||||
|
IonItemGroup,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonNote,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
declarations: [AddEventReviewModalComponent],
|
declarations: [AddEventReviewModalComponent],
|
||||||
imports: [
|
imports: [
|
||||||
IonicModule.forRoot(),
|
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
ThingTranslateModule.forChild(),
|
ThingTranslateModule.forChild(),
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
CommonModule,
|
CommonModule,
|
||||||
MomentModule,
|
MomentModule,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonButton,
|
||||||
|
IonItem,
|
||||||
|
IonNote,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonItemGroup,
|
||||||
|
IonItemDivider,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardTitle,
|
||||||
|
IonCardHeader,
|
||||||
],
|
],
|
||||||
exports: [],
|
exports: [],
|
||||||
providers: [Calendar, CalendarService, ScheduleProvider],
|
providers: [Calendar, CalendarService, ScheduleProvider],
|
||||||
|
|||||||
@@ -16,14 +16,29 @@ import {CommonModule} from '@angular/common';
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {MomentModule} from 'ngx-moment';
|
import {MomentModule} from 'ngx-moment';
|
||||||
import {DataModule} from '../data/data.module';
|
import {DataModule} from '../data/data.module';
|
||||||
import {SettingsProvider} from '../settings/settings.provider';
|
import {SettingsProvider} from '../settings/settings.provider';
|
||||||
import {CatalogComponent} from './catalog.component';
|
import {CatalogComponent} from './catalog.component';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonButtons,
|
||||||
|
IonBackButton,
|
||||||
|
IonTitle,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonLabel,
|
||||||
|
IonContent,
|
||||||
|
IonList,
|
||||||
|
IonItem,
|
||||||
|
IonGrid,
|
||||||
|
IonRow,
|
||||||
|
IonCol,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const catalogRoutes: Routes = [
|
const catalogRoutes: Routes = [
|
||||||
{path: 'catalog', component: CatalogComponent},
|
{path: 'catalog', component: CatalogComponent},
|
||||||
@@ -36,15 +51,28 @@ const catalogRoutes: Routes = [
|
|||||||
@NgModule({
|
@NgModule({
|
||||||
declarations: [CatalogComponent],
|
declarations: [CatalogComponent],
|
||||||
imports: [
|
imports: [
|
||||||
IonicModule.forRoot(),
|
|
||||||
FormsModule,
|
FormsModule,
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
RouterModule.forChild(catalogRoutes),
|
RouterModule.forChild(catalogRoutes),
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
CommonModule,
|
CommonModule,
|
||||||
MomentModule,
|
MomentModule,
|
||||||
DataModule,
|
DataModule,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonButtons,
|
||||||
|
IonBackButton,
|
||||||
|
IonTitle,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonLabel,
|
||||||
|
IonContent,
|
||||||
|
IonList,
|
||||||
|
IonItem,
|
||||||
|
IonGrid,
|
||||||
|
IonRow,
|
||||||
|
IonCol,
|
||||||
],
|
],
|
||||||
providers: [SettingsProvider],
|
providers: [SettingsProvider],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {Animation, AnimationController} from '@ionic/angular';
|
import {Animation, AnimationController} from '@ionic/angular/standalone';
|
||||||
import {NgZone} from '@angular/core';
|
import {NgZone} from '@angular/core';
|
||||||
|
|
||||||
export class DashboardCollapse {
|
export class DashboardCollapse {
|
||||||
|
|||||||
@@ -118,10 +118,6 @@ ion-content {
|
|||||||
font-weight: var(--font-weight-semi-bold);
|
font-weight: var(--font-weight-semi-bold);
|
||||||
word-break: break-word;
|
word-break: break-word;
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover ::ng-deep stapps-icon {
|
|
||||||
--fill: 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
a:last-child {
|
a:last-child {
|
||||||
@@ -159,4 +155,8 @@ ion-content {
|
|||||||
line-height: 1.2;
|
line-height: 1.2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
a:first-child:hover {
|
||||||
|
--fill: 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ import moment from 'moment';
|
|||||||
import {SCDateSeries, SCUuid} from '@openstapps/core';
|
import {SCDateSeries, SCUuid} from '@openstapps/core';
|
||||||
import {DataRoutingService} from '../data/data-routing.service';
|
import {DataRoutingService} from '../data/data-routing.service';
|
||||||
import {ScheduleProvider} from '../calendar/schedule.provider';
|
import {ScheduleProvider} from '../calendar/schedule.provider';
|
||||||
import {AnimationController, IonContent} from '@ionic/angular';
|
import {AnimationController, IonContent} from '@ionic/angular/standalone';
|
||||||
import {DashboardCollapse} from './dashboard-collapse';
|
import {DashboardCollapse} from './dashboard-collapse';
|
||||||
import {BreakpointObserver} from '@angular/cdk/layout';
|
import {BreakpointObserver} from '@angular/cdk/layout';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
@@ -37,7 +37,7 @@ import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
|||||||
@Component({
|
@Component({
|
||||||
selector: 'app-dashboard',
|
selector: 'app-dashboard',
|
||||||
templateUrl: './dashboard.component.html',
|
templateUrl: './dashboard.component.html',
|
||||||
styleUrls: ['./dashboard.component.scss', '/dashboard.collapse.component.scss'],
|
styleUrls: ['./dashboard.component.scss', './dashboard.collapse.component.scss'],
|
||||||
})
|
})
|
||||||
export class DashboardComponent implements OnInit, OnDestroy, AfterViewInit {
|
export class DashboardComponent implements OnInit, OnDestroy, AfterViewInit {
|
||||||
@ViewChild('toolbar', {read: ElementRef}) toolbarRef: ElementRef;
|
@ViewChild('toolbar', {read: ElementRef}) toolbarRef: ElementRef;
|
||||||
|
|||||||
@@ -16,7 +16,6 @@ import {CommonModule} from '@angular/common';
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {SwiperModule} from 'swiper/angular';
|
import {SwiperModule} from 'swiper/angular';
|
||||||
import {TranslateModule, TranslatePipe} from '@ngx-translate/core';
|
import {TranslateModule, TranslatePipe} from '@ngx-translate/core';
|
||||||
import {MomentModule} from 'ngx-moment';
|
import {MomentModule} from 'ngx-moment';
|
||||||
@@ -30,10 +29,23 @@ import {MensaSectionContentComponent} from './sections/mensa-section/mensa-secti
|
|||||||
import {FavoritesSectionComponent} from './sections/favorites-section/favorites-section.component';
|
import {FavoritesSectionComponent} from './sections/favorites-section/favorites-section.component';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {NewsModule} from '../news/news.module';
|
import {NewsModule} from '../news/news.module';
|
||||||
import {JobSectionComponent} from './sections/jobs-section/job-section.component';
|
import {JobSectionComponent} from './sections/jobs-section/job-section.component';
|
||||||
import {JobModule} from '../jobs/jobs.module';
|
import {JobModule} from '../jobs/jobs.module';
|
||||||
|
import {
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonLabel,
|
||||||
|
IonImg,
|
||||||
|
IonContent,
|
||||||
|
IonButton,
|
||||||
|
IonItem,
|
||||||
|
IonThumbnail,
|
||||||
|
IonSearchbar,
|
||||||
|
IonRippleEffect,
|
||||||
|
IonRouterLink,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const catalogRoutes: Routes = [
|
const catalogRoutes: Routes = [
|
||||||
{
|
{
|
||||||
@@ -56,8 +68,7 @@ const catalogRoutes: Routes = [
|
|||||||
JobSectionComponent,
|
JobSectionComponent,
|
||||||
],
|
],
|
||||||
imports: [
|
imports: [
|
||||||
IonicModule.forRoot(),
|
IonIconDirective,
|
||||||
IonIconModule,
|
|
||||||
FormsModule,
|
FormsModule,
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
RouterModule.forChild(catalogRoutes),
|
RouterModule.forChild(catalogRoutes),
|
||||||
@@ -69,6 +80,17 @@ const catalogRoutes: Routes = [
|
|||||||
UtilModule,
|
UtilModule,
|
||||||
NewsModule,
|
NewsModule,
|
||||||
JobModule,
|
JobModule,
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonImg,
|
||||||
|
IonContent,
|
||||||
|
IonButton,
|
||||||
|
IonItem,
|
||||||
|
IonLabel,
|
||||||
|
IonThumbnail,
|
||||||
|
IonSearchbar,
|
||||||
|
IonRippleEffect,
|
||||||
|
IonRouterLink,
|
||||||
],
|
],
|
||||||
providers: [SettingsProvider, TranslatePipe],
|
providers: [SettingsProvider, TranslatePipe],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -35,4 +35,6 @@ export class JobSectionComponent {
|
|||||||
from: 0,
|
from: 0,
|
||||||
})
|
})
|
||||||
.then((result: SCSearchResult) => result.data);
|
.then((result: SCSearchResult) => result.data);
|
||||||
|
|
||||||
|
constructor() {}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {AnimationController} from '@ionic/angular';
|
import {AnimationController} from '@ionic/angular/standalone';
|
||||||
import {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
import {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Component} from '@angular/core';
|
import {Component} from '@angular/core';
|
||||||
import {AnimationController} from '@ionic/angular';
|
import {AnimationController} from '@ionic/angular/standalone';
|
||||||
import {homePageSearchTransition} from './search-route-transition';
|
import {homePageSearchTransition} from './search-route-transition';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Component, DestroyRef, inject, Input, ViewChild} from '@angular/core';
|
import {Component, DestroyRef, inject, Input, ViewChild} from '@angular/core';
|
||||||
import {IonRouterOutlet, ModalController} from '@ionic/angular';
|
import {IonRouterOutlet, ModalController} from '@ionic/angular/standalone';
|
||||||
import {SCDateSeries, SCThing, SCThingType, SCUuid} from '@openstapps/core';
|
import {SCDateSeries, SCThing, SCThingType, SCUuid} from '@openstapps/core';
|
||||||
import {Subscription} from 'rxjs';
|
import {Subscription} from 'rxjs';
|
||||||
import {ScheduleProvider} from '../../../calendar/schedule.provider';
|
import {ScheduleProvider} from '../../../calendar/schedule.provider';
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output} from '@angular/core';
|
import {ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output} from '@angular/core';
|
||||||
import {ModalController} from '@ionic/angular';
|
import {ModalController} from '@ionic/angular/standalone';
|
||||||
import {SCDateSeries} from '@openstapps/core';
|
import {SCDateSeries} from '@openstapps/core';
|
||||||
import {
|
import {
|
||||||
DateSeriesRelevantData,
|
DateSeriesRelevantData,
|
||||||
|
|||||||
@@ -13,6 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Component, EventEmitter, Input, Output} from '@angular/core';
|
import {Component, EventEmitter, Input, Output} from '@angular/core';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Shows a chip filter
|
* Shows a chip filter
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -17,13 +17,55 @@ import {CommonModule} from '@angular/common';
|
|||||||
import {HttpClientModule} from '@angular/common/http';
|
import {HttpClientModule} from '@angular/common/http';
|
||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {IonicModule, Platform} from '@ionic/angular';
|
import {
|
||||||
|
IonAccordion,
|
||||||
|
IonButton,
|
||||||
|
IonCard,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCardTitle,
|
||||||
|
IonCardContent,
|
||||||
|
IonAccordionGroup,
|
||||||
|
IonBreadcrumb,
|
||||||
|
IonBreadcrumbs,
|
||||||
|
IonButtons,
|
||||||
|
IonChip,
|
||||||
|
IonCol,
|
||||||
|
IonContent,
|
||||||
|
IonGrid,
|
||||||
|
IonHeader,
|
||||||
|
IonImg,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonListHeader,
|
||||||
|
IonNote,
|
||||||
|
IonPopover,
|
||||||
|
IonRow,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonText,
|
||||||
|
IonThumbnail,
|
||||||
|
IonToolbar,
|
||||||
|
Platform,
|
||||||
|
IonMenuButton,
|
||||||
|
IonSearchbar,
|
||||||
|
IonTitle,
|
||||||
|
IonBackButton,
|
||||||
|
IonInfiniteScroll,
|
||||||
|
IonInfiniteScrollContent,
|
||||||
|
IonItem,
|
||||||
|
IonSkeletonText,
|
||||||
|
IonToast,
|
||||||
|
IonBadge,
|
||||||
|
IonCardSubtitle,
|
||||||
|
IonCheckbox,
|
||||||
|
IonFooter,
|
||||||
|
IonRouterLink,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {MarkdownModule} from 'ngx-markdown';
|
import {MarkdownModule} from 'ngx-markdown';
|
||||||
import {MomentModule} from 'ngx-moment';
|
import {MomentModule} from 'ngx-moment';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {SimpleBrowser, browserFactory} from '../../util/browser.factory';
|
import {SimpleBrowser, browserFactory} from '../../util/browser.factory';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {RoutingStackService} from '../../util/routing-stack.service';
|
import {RoutingStackService} from '../../util/routing-stack.service';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {CalendarService} from '../calendar/calendar.service';
|
import {CalendarService} from '../calendar/calendar.service';
|
||||||
@@ -106,6 +148,7 @@ import {SemesterListItemComponent} from './types/semester/semester-list-item.com
|
|||||||
import {VideoDetailContentComponent} from './types/video/video-detail-content.component';
|
import {VideoDetailContentComponent} from './types/video/video-detail-content.component';
|
||||||
import {VideoListItemComponent} from './types/video/video-list-item.component';
|
import {VideoListItemComponent} from './types/video/video-list-item.component';
|
||||||
import {ShareButtonComponent} from './elements/share-button.component';
|
import {ShareButtonComponent} from './elements/share-button.component';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Module for handling data
|
* Module for handling data
|
||||||
@@ -187,10 +230,9 @@ import {ShareButtonComponent} from './elements/share-button.component';
|
|||||||
FormsModule,
|
FormsModule,
|
||||||
MapWidgetComponent,
|
MapWidgetComponent,
|
||||||
HttpClientModule,
|
HttpClientModule,
|
||||||
IonicModule.forRoot(),
|
|
||||||
MarkdownModule.forRoot(),
|
MarkdownModule.forRoot(),
|
||||||
MenuModule,
|
MenuModule,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
MomentModule.forRoot({
|
MomentModule.forRoot({
|
||||||
relativeTimeThresholdOptions: {
|
relativeTimeThresholdOptions: {
|
||||||
m: 59,
|
m: 59,
|
||||||
@@ -202,6 +244,47 @@ import {ShareButtonComponent} from './elements/share-button.component';
|
|||||||
ThingTranslateModule.forChild(),
|
ThingTranslateModule.forChild(),
|
||||||
UtilModule,
|
UtilModule,
|
||||||
GeoNavigationDirective,
|
GeoNavigationDirective,
|
||||||
|
IonButton,
|
||||||
|
IonCard,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCardTitle,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardSubtitle,
|
||||||
|
IonNote,
|
||||||
|
IonLabel,
|
||||||
|
IonGrid,
|
||||||
|
IonCol,
|
||||||
|
IonRow,
|
||||||
|
IonList,
|
||||||
|
IonSegment,
|
||||||
|
IonListHeader,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonChip,
|
||||||
|
IonImg,
|
||||||
|
IonPopover,
|
||||||
|
IonThumbnail,
|
||||||
|
IonBreadcrumbs,
|
||||||
|
IonBreadcrumb,
|
||||||
|
IonAccordion,
|
||||||
|
IonAccordionGroup,
|
||||||
|
IonText,
|
||||||
|
IonContent,
|
||||||
|
IonButtons,
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonMenuButton,
|
||||||
|
IonSearchbar,
|
||||||
|
IonTitle,
|
||||||
|
IonBackButton,
|
||||||
|
IonInfiniteScroll,
|
||||||
|
IonInfiniteScrollContent,
|
||||||
|
IonItem,
|
||||||
|
IonSkeletonText,
|
||||||
|
IonToast,
|
||||||
|
IonBadge,
|
||||||
|
IonCheckbox,
|
||||||
|
IonFooter,
|
||||||
|
IonRouterLink,
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
CoordinatedSearchProvider,
|
CoordinatedSearchProvider,
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
*/
|
*/
|
||||||
import {Injectable} from '@angular/core';
|
import {Injectable} from '@angular/core';
|
||||||
import {SCFeedbackRequestMetaData} from '@openstapps/core';
|
import {SCFeedbackRequestMetaData} from '@openstapps/core';
|
||||||
import {Platform} from '@ionic/angular';
|
import {Platform} from '@ionic/angular/standalone';
|
||||||
import {DataProvider} from './data.provider';
|
import {DataProvider} from './data.provider';
|
||||||
import {NavigationEnd, Router} from '@angular/router';
|
import {NavigationEnd, Router} from '@angular/router';
|
||||||
import {SettingsProvider} from '../settings/settings.provider';
|
import {SettingsProvider} from '../settings/settings.provider';
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
import {Component, Input, TemplateRef} from '@angular/core';
|
import {Component, Input, TemplateRef} from '@angular/core';
|
||||||
import {SCThings} from '@openstapps/core';
|
import {SCThings} from '@openstapps/core';
|
||||||
import {DataListContext} from '../list/data-list.component';
|
import {DataListContext} from '../list/data-list.component';
|
||||||
import {ModalController} from '@ionic/angular';
|
import {ModalController} from '@ionic/angular/standalone';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO
|
* TODO
|
||||||
|
|||||||
@@ -26,6 +26,7 @@ import {DataDetailComponent} from './data-detail.component';
|
|||||||
import {Observable, of} from 'rxjs';
|
import {Observable, of} from 'rxjs';
|
||||||
import {StorageProvider} from '../../storage/storage.provider';
|
import {StorageProvider} from '../../storage/storage.provider';
|
||||||
import {LoggerModule, NgxLoggerLevel} from 'ngx-logger';
|
import {LoggerModule, NgxLoggerLevel} from 'ngx-logger';
|
||||||
|
import {provideIonicAngular} from '@ionic/angular/standalone';
|
||||||
|
|
||||||
const translations: any = {data: {detail: {TITLE: 'Foo'}}};
|
const translations: any = {data: {detail: {TITLE: 'Foo'}}};
|
||||||
|
|
||||||
@@ -71,6 +72,7 @@ describe('DataDetailComponent', () => {
|
|||||||
LoggerModule.forRoot({level: NgxLoggerLevel.TRACE}),
|
LoggerModule.forRoot({level: NgxLoggerLevel.TRACE}),
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
|
provideIonicAngular(),
|
||||||
{
|
{
|
||||||
provide: ActivatedRoute,
|
provide: ActivatedRoute,
|
||||||
useValue: fakeActivatedRoute,
|
useValue: fakeActivatedRoute,
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
*/
|
*/
|
||||||
import {Component, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef} from '@angular/core';
|
import {Component, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef} from '@angular/core';
|
||||||
import {ActivatedRoute, Router} from '@angular/router';
|
import {ActivatedRoute, Router} from '@angular/router';
|
||||||
import {ModalController} from '@ionic/angular';
|
import {ModalController} from '@ionic/angular/standalone';
|
||||||
import {LangChangeEvent, TranslateService} from '@ngx-translate/core';
|
import {LangChangeEvent, TranslateService} from '@ngx-translate/core';
|
||||||
import {SCLanguageCode, SCSaveableThing, SCThings, SCUuid} from '@openstapps/core';
|
import {SCLanguageCode, SCSaveableThing, SCThings, SCUuid} from '@openstapps/core';
|
||||||
import {DataProvider, DataScope} from '../data.provider';
|
import {DataProvider, DataScope} from '../data.provider';
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ import {DataProvider, DataScope} from '../data.provider';
|
|||||||
import {fromEvent, Observable} from 'rxjs';
|
import {fromEvent, Observable} from 'rxjs';
|
||||||
import {map, startWith} from 'rxjs/operators';
|
import {map, startWith} from 'rxjs/operators';
|
||||||
import {DataRoutingService} from '../data-routing.service';
|
import {DataRoutingService} from '../data-routing.service';
|
||||||
import {NavController} from '@ionic/angular';
|
import {NavController} from '@ionic/angular/standalone';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
|||||||
@@ -18,7 +18,6 @@ ion-button {
|
|||||||
--background-hover: currentcolor;
|
--background-hover: currentcolor;
|
||||||
--background-focused: currentcolor;
|
--background-focused: currentcolor;
|
||||||
|
|
||||||
aspect-ratio: 1;
|
|
||||||
color: inherit;
|
color: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -27,7 +26,7 @@ ion-button {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@media (hover: hover) {
|
@media (hover: hover) {
|
||||||
ion-button:hover ::ng-deep stapps-icon {
|
ion-button:hover > ion-icon {
|
||||||
--fill: 1 !important;
|
--fill: 1 !important;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
ion-button {
|
ion-button {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
|
|
||||||
&.button-disabled::ng-deep stapps-icon {
|
&.button-disabled {
|
||||||
--fill: 1;
|
--fill: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -39,17 +39,17 @@ ion-button {
|
|||||||
border-radius: var(--border-radius-default);
|
border-radius: var(--border-radius-default);
|
||||||
|
|
||||||
> ion-icon {
|
> ion-icon {
|
||||||
&:active::ng-deep stapps-icon,
|
&:active,
|
||||||
&:has(:checked)::ng-deep stapps-icon,
|
&:has(:checked),
|
||||||
&:has(:checked)::ng-deep ~ *::ng-deep stapps-icon,
|
&:has(:checked) ~ *,
|
||||||
&:active::ng-deep ~ *::ng-deep stapps-icon {
|
&:active ~ * {
|
||||||
--fill: 1;
|
--fill: 1;
|
||||||
|
|
||||||
color: var(--ion-color-dark);
|
color: var(--ion-color-dark);
|
||||||
}
|
}
|
||||||
@media (hover: hover) {
|
@media (hover: hover) {
|
||||||
&:hover ~ *::ng-deep stapps-icon,
|
&:hover ~ *,
|
||||||
&:hover::ng-deep stapps-icon {
|
&:hover {
|
||||||
--fill: 1;
|
--fill: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import {Component, Input} from '@angular/core';
|
import {Component, Input} from '@angular/core';
|
||||||
import {ToastController} from '@ionic/angular';
|
import {ToastController} from '@ionic/angular/standalone';
|
||||||
import {environment} from '../../../../environments/environment';
|
import {environment} from '../../../../environments/environment';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ import {
|
|||||||
} from '@angular/core';
|
} from '@angular/core';
|
||||||
import {SCThings} from '@openstapps/core';
|
import {SCThings} from '@openstapps/core';
|
||||||
import {BehaviorSubject, Observable} from 'rxjs';
|
import {BehaviorSubject, Observable} from 'rxjs';
|
||||||
import {IonInfiniteScroll} from '@ionic/angular';
|
import {IonInfiniteScroll} from '@ionic/angular/standalone';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
|
|
||||||
export interface DataListContext<T> {
|
export interface DataListContext<T> {
|
||||||
|
|||||||
@@ -13,8 +13,8 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import type {AnimationBuilder} from '@ionic/angular';
|
import type {AnimationBuilder} from '@ionic/angular/standalone';
|
||||||
import {AnimationController} from '@ionic/angular';
|
import {AnimationController} from '@ionic/angular/standalone';
|
||||||
import type {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
import type {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
import {Component, DestroyRef, inject, Input, OnInit} from '@angular/core';
|
import {Component, DestroyRef, inject, Input, OnInit} from '@angular/core';
|
||||||
import {ActivatedRoute, Router} from '@angular/router';
|
import {ActivatedRoute, Router} from '@angular/router';
|
||||||
import {Keyboard} from '@capacitor/keyboard';
|
import {Keyboard} from '@capacitor/keyboard';
|
||||||
import {AlertController, AnimationBuilder, AnimationController} from '@ionic/angular';
|
import {AlertController, AnimationBuilder, AnimationController} from '@ionic/angular/standalone';
|
||||||
import {Capacitor} from '@capacitor/core';
|
import {Capacitor} from '@capacitor/core';
|
||||||
import {
|
import {
|
||||||
SCFacet,
|
SCFacet,
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ import {AfterViewInit, Component, DestroyRef, inject, Input} from '@angular/core
|
|||||||
import {SCDish, SCISO8601Date, SCPlace} from '@openstapps/core';
|
import {SCDish, SCISO8601Date, SCPlace} from '@openstapps/core';
|
||||||
import {PlaceMensaService} from './place-mensa-service';
|
import {PlaceMensaService} from './place-mensa-service';
|
||||||
import {Router} from '@angular/router';
|
import {Router} from '@angular/router';
|
||||||
import {IonRouterOutlet} from '@ionic/angular';
|
import {IonRouterOutlet} from '@ionic/angular/standalone';
|
||||||
import {DataRoutingService} from '../../../../data-routing.service';
|
import {DataRoutingService} from '../../../../data-routing.service';
|
||||||
import {groupBy} from '@openstapps/collection-utils';
|
import {groupBy} from '@openstapps/collection-utils';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Component, OnInit} from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
import {AlertController, AnimationController} from '@ionic/angular';
|
import {AlertController, AnimationController} from '@ionic/angular/standalone';
|
||||||
import {ActivatedRoute, Router} from '@angular/router';
|
import {ActivatedRoute, Router} from '@angular/router';
|
||||||
import {NGXLogger} from 'ngx-logger';
|
import {NGXLogger} from 'ngx-logger';
|
||||||
import {debounceTime, distinctUntilChanged, startWith, take} from 'rxjs/operators';
|
import {debounceTime, distinctUntilChanged, startWith, take} from 'rxjs/operators';
|
||||||
|
|||||||
@@ -15,14 +15,25 @@
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {FavoritesPageComponent} from './favorites-page.component';
|
import {FavoritesPageComponent} from './favorites-page.component';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {MenuModule} from '../menu/menu.module';
|
import {MenuModule} from '../menu/menu.module';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {DataModule} from '../data/data.module';
|
import {DataModule} from '../data/data.module';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonContent,
|
||||||
|
IonHeader,
|
||||||
|
IonLabel,
|
||||||
|
IonMenuButton,
|
||||||
|
IonSearchbar,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const favoritesRoutes: Routes = [
|
const favoritesRoutes: Routes = [
|
||||||
{
|
{
|
||||||
@@ -35,13 +46,22 @@ const favoritesRoutes: Routes = [
|
|||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonicModule,
|
|
||||||
RouterModule.forChild(favoritesRoutes),
|
RouterModule.forChild(favoritesRoutes),
|
||||||
MenuModule,
|
MenuModule,
|
||||||
TranslateModule,
|
TranslateModule,
|
||||||
DataModule,
|
DataModule,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonLabel,
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonButtons,
|
||||||
|
IonContent,
|
||||||
|
IonButton,
|
||||||
|
IonMenuButton,
|
||||||
|
IonSearchbar,
|
||||||
|
IonTitle,
|
||||||
|
IonBackButton,
|
||||||
],
|
],
|
||||||
declarations: [FavoritesPageComponent],
|
declarations: [FavoritesPageComponent],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ import {
|
|||||||
} from '@openstapps/core';
|
} from '@openstapps/core';
|
||||||
import {DataProvider} from '../data/data.provider';
|
import {DataProvider} from '../data/data.provider';
|
||||||
import {DebugDataCollectorService} from '../data/debug-data-collector.service';
|
import {DebugDataCollectorService} from '../data/debug-data-collector.service';
|
||||||
import {AlertController, ToastController} from '@ionic/angular';
|
import {AlertController, ToastController} from '@ionic/angular/standalone';
|
||||||
import {TranslateService} from '@ngx-translate/core';
|
import {TranslateService} from '@ngx-translate/core';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
|||||||
@@ -15,13 +15,30 @@
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {FeedbackPageComponent} from './feedback-page.component';
|
import {FeedbackPageComponent} from './feedback-page.component';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {MarkdownModule} from 'ngx-markdown';
|
import {MarkdownModule} from 'ngx-markdown';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardTitle,
|
||||||
|
IonCheckbox,
|
||||||
|
IonHeader,
|
||||||
|
IonInput,
|
||||||
|
IonItem,
|
||||||
|
IonLabel,
|
||||||
|
IonSelect,
|
||||||
|
IonSelectOption,
|
||||||
|
IonTextarea,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const feedbackRoutes: Routes = [
|
const feedbackRoutes: Routes = [
|
||||||
{
|
{
|
||||||
@@ -34,12 +51,27 @@ const feedbackRoutes: Routes = [
|
|||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonicModule,
|
IonIconDirective,
|
||||||
IonIconModule,
|
|
||||||
RouterModule.forChild(feedbackRoutes),
|
RouterModule.forChild(feedbackRoutes),
|
||||||
TranslateModule,
|
TranslateModule,
|
||||||
MarkdownModule,
|
MarkdownModule,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonBackButton,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonButton,
|
||||||
|
IonItem,
|
||||||
|
IonLabel,
|
||||||
|
IonCardTitle,
|
||||||
|
IonCheckbox,
|
||||||
|
IonTextarea,
|
||||||
|
IonInput,
|
||||||
|
IonSelect,
|
||||||
|
IonSelectOption,
|
||||||
|
IonTitle,
|
||||||
|
IonButtons,
|
||||||
|
IonToolbar,
|
||||||
|
IonHeader,
|
||||||
],
|
],
|
||||||
declarations: [FeedbackPageComponent],
|
declarations: [FeedbackPageComponent],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -27,6 +27,7 @@ import {StorageProvider} from '../../storage/storage.provider';
|
|||||||
import {DaiaDataProvider} from '../daia-data.provider';
|
import {DaiaDataProvider} from '../daia-data.provider';
|
||||||
import {ConfigProvider} from '../../config/config.provider';
|
import {ConfigProvider} from '../../config/config.provider';
|
||||||
import {LoggerTestingModule} from 'ngx-logger/testing';
|
import {LoggerTestingModule} from 'ngx-logger/testing';
|
||||||
|
import {provideIonicAngular} from '@ionic/angular/standalone';
|
||||||
|
|
||||||
const translations: any = {data: {detail: {TITLE: 'Foo'}}};
|
const translations: any = {data: {detail: {TITLE: 'Foo'}}};
|
||||||
|
|
||||||
@@ -74,6 +75,7 @@ describe('DaiaAvailabilityComponent', () => {
|
|||||||
LoggerTestingModule,
|
LoggerTestingModule,
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
|
provideIonicAngular(),
|
||||||
{
|
{
|
||||||
provide: ActivatedRoute,
|
provide: ActivatedRoute,
|
||||||
useValue: fakeActivatedRoute,
|
useValue: fakeActivatedRoute,
|
||||||
|
|||||||
@@ -37,6 +37,6 @@ ion-grid {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ion-icon ::ng-deep stapps-icon {
|
ion-icon {
|
||||||
--fill: 1;
|
--fill: 1;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -26,9 +26,9 @@ import {HebisDataProvider} from '../hebis-data.provider';
|
|||||||
import {HebisDetailComponent} from './hebis-detail.component';
|
import {HebisDetailComponent} from './hebis-detail.component';
|
||||||
import {Observable, of} from 'rxjs';
|
import {Observable, of} from 'rxjs';
|
||||||
import {StorageProvider} from '../../storage/storage.provider';
|
import {StorageProvider} from '../../storage/storage.provider';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {IonIconModule} from '../../../util/ion-icon/ion-icon.module';
|
|
||||||
import {LoggerModule, NgxLoggerLevel} from 'ngx-logger';
|
import {LoggerModule, NgxLoggerLevel} from 'ngx-logger';
|
||||||
|
import {IonIconDirective} from '../../../util/ion-icon/ion-icon.directive';
|
||||||
|
import {provideIonicAngular} from '@ionic/angular/standalone';
|
||||||
|
|
||||||
const translations: any = {data: {detail: {TITLE: 'Foo'}}};
|
const translations: any = {data: {detail: {TITLE: 'Foo'}}};
|
||||||
|
|
||||||
@@ -68,14 +68,14 @@ describe('HebisDetailComponent', () => {
|
|||||||
RouterModule.forRoot([]),
|
RouterModule.forRoot([]),
|
||||||
HebisRoutingModule,
|
HebisRoutingModule,
|
||||||
HebisModule,
|
HebisModule,
|
||||||
IonicModule,
|
IonIconDirective,
|
||||||
IonIconModule,
|
|
||||||
TranslateModule.forRoot({
|
TranslateModule.forRoot({
|
||||||
loader: {provide: TranslateLoader, useClass: TranslateFakeLoader},
|
loader: {provide: TranslateLoader, useClass: TranslateFakeLoader},
|
||||||
}),
|
}),
|
||||||
LoggerModule.forRoot({level: NgxLoggerLevel.TRACE}),
|
LoggerModule.forRoot({level: NgxLoggerLevel.TRACE}),
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
|
provideIonicAngular(),
|
||||||
{
|
{
|
||||||
provide: ActivatedRoute,
|
provide: ActivatedRoute,
|
||||||
useValue: fakeActivatedRoute,
|
useValue: fakeActivatedRoute,
|
||||||
|
|||||||
@@ -17,7 +17,6 @@ import {CommonModule} from '@angular/common';
|
|||||||
import {HttpClientModule} from '@angular/common/http';
|
import {HttpClientModule} from '@angular/common/http';
|
||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {MarkdownModule} from 'ngx-markdown';
|
import {MarkdownModule} from 'ngx-markdown';
|
||||||
import {MomentModule} from 'ngx-moment';
|
import {MomentModule} from 'ngx-moment';
|
||||||
@@ -34,8 +33,27 @@ import {HebisRoutingModule} from './hebis-routing.module';
|
|||||||
import {DataModule} from '../data/data.module';
|
import {DataModule} from '../data/data.module';
|
||||||
import {DaiaAvailabilityComponent} from './daia-availability/daia-availability.component';
|
import {DaiaAvailabilityComponent} from './daia-availability/daia-availability.component';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {DaiaHoldingComponent} from './daia-availability/daia-holding.component';
|
import {DaiaHoldingComponent} from './daia-availability/daia-holding.component';
|
||||||
|
import {
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCol,
|
||||||
|
IonContent,
|
||||||
|
IonGrid,
|
||||||
|
IonHeader,
|
||||||
|
IonItem,
|
||||||
|
IonLabel,
|
||||||
|
IonNote,
|
||||||
|
IonRow,
|
||||||
|
IonThumbnail,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Module for handling data
|
* Module for handling data
|
||||||
@@ -53,9 +71,8 @@ import {DaiaHoldingComponent} from './daia-availability/daia-holding.component';
|
|||||||
DataModule,
|
DataModule,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
HebisRoutingModule,
|
HebisRoutingModule,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
HttpClientModule,
|
HttpClientModule,
|
||||||
IonicModule.forRoot(),
|
|
||||||
MarkdownModule.forRoot(),
|
MarkdownModule.forRoot(),
|
||||||
MenuModule,
|
MenuModule,
|
||||||
MomentModule.forRoot({
|
MomentModule.forRoot({
|
||||||
@@ -68,6 +85,23 @@ import {DaiaHoldingComponent} from './daia-availability/daia-holding.component';
|
|||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
ThingTranslateModule.forChild(),
|
ThingTranslateModule.forChild(),
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonBackButton,
|
||||||
|
IonLabel,
|
||||||
|
IonButton,
|
||||||
|
IonContent,
|
||||||
|
IonButtons,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
IonNote,
|
||||||
|
IonHeader,
|
||||||
|
IonGrid,
|
||||||
|
IonRow,
|
||||||
|
IonCol,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardHeader,
|
||||||
|
IonItem,
|
||||||
|
IonThumbnail,
|
||||||
],
|
],
|
||||||
providers: [HebisDataProvider, DaiaDataProvider, StAppsWebHttpClient],
|
providers: [HebisDataProvider, DaiaDataProvider, StAppsWebHttpClient],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,25 +1,23 @@
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {MomentModule} from 'ngx-moment';
|
import {MomentModule} from 'ngx-moment';
|
||||||
import {DataModule} from '../data/data.module';
|
import {DataModule} from '../data/data.module';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {JobsPageComponent} from './page/jobs-page.component';
|
import {JobsPageComponent} from './page/jobs-page.component';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const jobsRoutes: Routes = [{path: 'jobs', component: JobsPageComponent}];
|
const jobsRoutes: Routes = [{path: 'jobs', component: JobsPageComponent}];
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
declarations: [JobsPageComponent],
|
declarations: [JobsPageComponent],
|
||||||
imports: [
|
imports: [
|
||||||
IonicModule.forRoot(),
|
|
||||||
ThingTranslateModule.forChild(),
|
ThingTranslateModule.forChild(),
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
RouterModule.forChild(jobsRoutes),
|
RouterModule.forChild(jobsRoutes),
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
CommonModule,
|
CommonModule,
|
||||||
MomentModule,
|
MomentModule,
|
||||||
DataModule,
|
DataModule,
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ import {PAIATokenResponse} from '../../auth/paia/paia-token-response';
|
|||||||
import {AuthHelperService} from '../../auth/auth-helper.service';
|
import {AuthHelperService} from '../../auth/auth-helper.service';
|
||||||
import {ConfigProvider} from '../../config/config.provider';
|
import {ConfigProvider} from '../../config/config.provider';
|
||||||
import {TranslateService} from '@ngx-translate/core';
|
import {TranslateService} from '@ngx-translate/core';
|
||||||
import {AlertController, ToastController} from '@ionic/angular';
|
import {AlertController, ToastController} from '@ionic/angular/standalone';
|
||||||
import {HebisSearchResponse} from '../../hebis/protocol/response';
|
import {HebisSearchResponse} from '../../hebis/protocol/response';
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
|
|||||||
@@ -16,7 +16,6 @@
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {LibraryAccountPageComponent} from './account/account.page';
|
import {LibraryAccountPageComponent} from './account/account.page';
|
||||||
@@ -32,7 +31,28 @@ import {MomentModule} from 'ngx-moment';
|
|||||||
import {FeeItemComponent} from './account/elements/fee-item/fee-item.component';
|
import {FeeItemComponent} from './account/elements/fee-item/fee-item.component';
|
||||||
import {DataModule} from '../data/data.module';
|
import {DataModule} from '../data/data.module';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonButtons,
|
||||||
|
IonBackButton,
|
||||||
|
IonTitle,
|
||||||
|
IonContent,
|
||||||
|
IonSkeletonText,
|
||||||
|
IonItem,
|
||||||
|
IonGrid,
|
||||||
|
IonCol,
|
||||||
|
IonRow,
|
||||||
|
IonLabel,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonList,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonButton,
|
||||||
|
IonBadge,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const routes: ProtectedRoutes | Routes = [
|
const routes: ProtectedRoutes | Routes = [
|
||||||
{
|
{
|
||||||
@@ -71,13 +91,31 @@ const routes: ProtectedRoutes | Routes = [
|
|||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonicModule,
|
IonIconDirective,
|
||||||
IonIconModule,
|
|
||||||
RouterModule.forChild(routes),
|
RouterModule.forChild(routes),
|
||||||
TranslateModule,
|
TranslateModule,
|
||||||
MomentModule,
|
MomentModule,
|
||||||
DataModule,
|
DataModule,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonHeader,
|
||||||
|
IonBadge,
|
||||||
|
IonToolbar,
|
||||||
|
IonButtons,
|
||||||
|
IonBackButton,
|
||||||
|
IonTitle,
|
||||||
|
IonContent,
|
||||||
|
IonSkeletonText,
|
||||||
|
IonItem,
|
||||||
|
IonGrid,
|
||||||
|
IonCol,
|
||||||
|
IonRow,
|
||||||
|
IonLabel,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonList,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonButton,
|
||||||
],
|
],
|
||||||
declarations: [
|
declarations: [
|
||||||
LibraryAccountPageComponent,
|
LibraryAccountPageComponent,
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
import {animate, style, transition, trigger} from '@angular/animations';
|
import {animate, style, transition, trigger} from '@angular/animations';
|
||||||
import {AsyncPipe} from '@angular/common';
|
import {AsyncPipe} from '@angular/common';
|
||||||
import {ChangeDetectionStrategy, Component, Input, inject} from '@angular/core';
|
import {ChangeDetectionStrategy, Component, Input, inject} from '@angular/core';
|
||||||
import {IonicModule} from '@ionic/angular';
|
import {IonButton} from '@ionic/angular/standalone';
|
||||||
import {MapService} from '@maplibre/ngx-maplibre-gl';
|
import {MapService} from '@maplibre/ngx-maplibre-gl';
|
||||||
import {map, delay, Subject, race, mergeWith} from 'rxjs';
|
import {map, delay, Subject, race, mergeWith} from 'rxjs';
|
||||||
import {IonIconModule} from 'src/app/util/ion-icon/ion-icon.module';
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'stapps-map-attribution',
|
selector: 'stapps-map-attribution',
|
||||||
@@ -12,7 +12,7 @@ import {IonIconModule} from 'src/app/util/ion-icon/ion-icon.module';
|
|||||||
styleUrl: './attribution.scss',
|
styleUrl: './attribution.scss',
|
||||||
standalone: true,
|
standalone: true,
|
||||||
changeDetection: ChangeDetectionStrategy.OnPush,
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
||||||
imports: [IonicModule, IonIconModule, AsyncPipe],
|
imports: [IonIconDirective, AsyncPipe, IonButton],
|
||||||
animations: [
|
animations: [
|
||||||
trigger('fade', [
|
trigger('fade', [
|
||||||
transition(':enter', [
|
transition(':enter', [
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
import {AsyncPipe} from '@angular/common';
|
import {AsyncPipe} from '@angular/common';
|
||||||
import {ChangeDetectionStrategy, Component} from '@angular/core';
|
import {ChangeDetectionStrategy, Component} from '@angular/core';
|
||||||
import {IonicModule} from '@ionic/angular';
|
import {IonFabButton} from '@ionic/angular/standalone';
|
||||||
import {MapService} from '@maplibre/ngx-maplibre-gl';
|
import {MapService} from '@maplibre/ngx-maplibre-gl';
|
||||||
import {MapEventType} from 'maplibre-gl';
|
import {MapEventType} from 'maplibre-gl';
|
||||||
import {map, mergeMap, fromEventPattern, merge} from 'rxjs';
|
import {map, mergeMap, fromEventPattern, merge} from 'rxjs';
|
||||||
import {IonIconModule} from 'src/app/util/ion-icon/ion-icon.module';
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'stapps-compass-control',
|
selector: 'stapps-compass-control',
|
||||||
@@ -12,7 +12,7 @@ import {IonIconModule} from 'src/app/util/ion-icon/ion-icon.module';
|
|||||||
styleUrl: './compass-control.scss',
|
styleUrl: './compass-control.scss',
|
||||||
standalone: true,
|
standalone: true,
|
||||||
changeDetection: ChangeDetectionStrategy.OnPush,
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
||||||
imports: [AsyncPipe, IonicModule, IonIconModule],
|
imports: [AsyncPipe, IonIconDirective, IonFabButton],
|
||||||
})
|
})
|
||||||
export class CompassControlComponent {
|
export class CompassControlComponent {
|
||||||
transform = this.mapService.mapCreated$.pipe(
|
transform = this.mapService.mapCreated$.pipe(
|
||||||
|
|||||||
@@ -8,12 +8,12 @@ import {
|
|||||||
OnDestroy,
|
OnDestroy,
|
||||||
ViewChild,
|
ViewChild,
|
||||||
} from '@angular/core';
|
} from '@angular/core';
|
||||||
import {IonicModule} from '@ionic/angular';
|
import {IonFabButton} from '@ionic/angular/standalone';
|
||||||
import {MapService} from '@maplibre/ngx-maplibre-gl';
|
import {MapService} from '@maplibre/ngx-maplibre-gl';
|
||||||
import {FitBoundsOptions, GeolocateControl, GeolocateControlOptions} from 'maplibre-gl';
|
import {FitBoundsOptions, GeolocateControl, GeolocateControlOptions} from 'maplibre-gl';
|
||||||
import {Map as MapLibre} from 'maplibre-gl';
|
import {Map as MapLibre} from 'maplibre-gl';
|
||||||
import {BehaviorSubject} from 'rxjs';
|
import {BehaviorSubject} from 'rxjs';
|
||||||
import {IonIconModule} from 'src/app/util/ion-icon/ion-icon.module';
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
type WatchState = InstanceType<typeof GeolocateControl>['_watchState'];
|
type WatchState = InstanceType<typeof GeolocateControl>['_watchState'];
|
||||||
|
|
||||||
@@ -52,7 +52,7 @@ class CustomGeolocateControl extends GeolocateControl {
|
|||||||
styleUrl: './geolocate-control.scss',
|
styleUrl: './geolocate-control.scss',
|
||||||
standalone: true,
|
standalone: true,
|
||||||
changeDetection: ChangeDetectionStrategy.OnPush,
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
||||||
imports: [AsyncPipe, IonicModule, IonIconModule],
|
imports: [AsyncPipe, IonIconDirective, IonFabButton],
|
||||||
})
|
})
|
||||||
export class GeolocateControlComponent implements AfterContentInit, OnDestroy {
|
export class GeolocateControlComponent implements AfterContentInit, OnDestroy {
|
||||||
@Input() position?: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
|
@Input() position?: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
import {ChangeDetectionStrategy, Component, HostBinding, Input, OnInit, Optional} from '@angular/core';
|
import {ChangeDetectionStrategy, Component, HostBinding, Input, OnInit, Optional} from '@angular/core';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {IonIconModule} from 'src/app/util/ion-icon/ion-icon.module';
|
|
||||||
import {MapIconDirective} from '../map-icon.directive';
|
import {MapIconDirective} from '../map-icon.directive';
|
||||||
import {Feature, Point} from 'geojson';
|
import {Feature, Point} from 'geojson';
|
||||||
import {SCFeatureProperties} from '../feature-collection.pipe';
|
import {SCFeatureProperties} from '../feature-collection.pipe';
|
||||||
import {MapDataProvider} from '../map-data.provider';
|
import {MapDataProvider} from '../map-data.provider';
|
||||||
import {DataRoutingService} from '../../data/data-routing.service';
|
import {DataRoutingService} from '../../data/data-routing.service';
|
||||||
import {AddWordBreakOpportunitiesPipe} from '../../../util/word-break-opportunities.pipe';
|
import {AddWordBreakOpportunitiesPipe} from '../../../util/word-break-opportunities.pipe';
|
||||||
|
import {IonButton, IonLabel} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'stapps-poi-marker',
|
selector: 'stapps-poi-marker',
|
||||||
@@ -14,7 +14,7 @@ import {AddWordBreakOpportunitiesPipe} from '../../../util/word-break-opportunit
|
|||||||
styleUrl: './poi-marker.scss',
|
styleUrl: './poi-marker.scss',
|
||||||
standalone: true,
|
standalone: true,
|
||||||
changeDetection: ChangeDetectionStrategy.OnPush,
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
||||||
imports: [IonicModule, IonIconModule, MapIconDirective, AddWordBreakOpportunitiesPipe],
|
imports: [IonIconDirective, MapIconDirective, AddWordBreakOpportunitiesPipe, IonLabel, IonButton],
|
||||||
})
|
})
|
||||||
export class PoiMarkerComponent implements OnInit {
|
export class PoiMarkerComponent implements OnInit {
|
||||||
@Input({required: true}) feature: Feature<Point, SCFeatureProperties>;
|
@Input({required: true}) feature: Feature<Point, SCFeatureProperties>;
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import {Directive, HostListener, Input} from '@angular/core';
|
import {Directive, HostListener, Input} from '@angular/core';
|
||||||
import {SCPlaceWithoutReferences, SCThings, SCThingWithoutReferences} from '@openstapps/core';
|
import {SCPlaceWithoutReferences, SCThings, SCThingWithoutReferences} from '@openstapps/core';
|
||||||
import {Device} from '@capacitor/device';
|
import {Device} from '@capacitor/device';
|
||||||
import {ActionSheetController, ActionSheetOptions, ToastController} from '@ionic/angular';
|
import {ActionSheetController, ActionSheetOptions, ToastController} from '@ionic/angular/standalone';
|
||||||
import {TranslateService} from '@ngx-translate/core';
|
import {TranslateService} from '@ngx-translate/core';
|
||||||
import {ThingTranslateService} from '../../translation/thing-translate.service';
|
import {ThingTranslateService} from '../../translation/thing-translate.service';
|
||||||
import {Clipboard} from '@capacitor/clipboard';
|
import {Clipboard} from '@capacitor/clipboard';
|
||||||
|
|||||||
@@ -12,8 +12,8 @@
|
|||||||
* You should have received a copy of the GNU General Public License along with
|
* You should have received a copy of the GNU General Public License along with
|
||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import type {AnimationBuilder} from '@ionic/angular';
|
import type {AnimationBuilder} from '@ionic/angular/standalone';
|
||||||
import {AnimationController} from '@ionic/angular';
|
import {AnimationController} from '@ionic/angular/standalone';
|
||||||
import type {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
import type {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
||||||
import {iosDuration, iosEasing, mdDuration, mdEasing} from 'src/app/animation/easings';
|
import {iosDuration, iosEasing, mdDuration, mdEasing} from 'src/app/animation/easings';
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,6 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {ChangeDetectionStrategy, Component} from '@angular/core';
|
import {ChangeDetectionStrategy, Component} from '@angular/core';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {LngLatBoundsLike, MapLibreEvent} from 'maplibre-gl';
|
import {LngLatBoundsLike, MapLibreEvent} from 'maplibre-gl';
|
||||||
import {
|
import {
|
||||||
ControlComponent,
|
ControlComponent,
|
||||||
@@ -28,7 +27,6 @@ import {MediaQueryPipe} from '../../util/media-query.pipe';
|
|||||||
import {MapStyleDirective} from './map-style.directive';
|
import {MapStyleDirective} from './map-style.directive';
|
||||||
import {DataProvider} from '../data/data.provider';
|
import {DataProvider} from '../data/data.provider';
|
||||||
import {SCSearchFilter, SCThingType} from '@openstapps/core';
|
import {SCSearchFilter, SCThingType} from '@openstapps/core';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {DataModule} from '../data/data.module';
|
import {DataModule} from '../data/data.module';
|
||||||
import {AsyncPipe} from '@angular/common';
|
import {AsyncPipe} from '@angular/common';
|
||||||
import {GeolocateControlComponent} from './controls/geolocate-control.component';
|
import {GeolocateControlComponent} from './controls/geolocate-control.component';
|
||||||
@@ -40,6 +38,8 @@ import {BuildingMarkersComponent} from './elements/building-markers.component';
|
|||||||
import {PoiMarkersComponent} from './elements/poi-markers.component';
|
import {PoiMarkersComponent} from './elements/poi-markers.component';
|
||||||
import {AttributionComponent} from './controls/attribution.component';
|
import {AttributionComponent} from './controls/attribution.component';
|
||||||
import {filter, map} from 'rxjs';
|
import {filter, map} from 'rxjs';
|
||||||
|
import {IonButton, IonContent, IonLabel, IonRouterLink} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The main page of the map
|
* The main page of the map
|
||||||
@@ -65,8 +65,7 @@ import {filter, map} from 'rxjs';
|
|||||||
DataModule,
|
DataModule,
|
||||||
GeolocateControlComponent,
|
GeolocateControlComponent,
|
||||||
GeolocateControlDirective,
|
GeolocateControlDirective,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
IonicModule,
|
|
||||||
MapAuto3dDirective,
|
MapAuto3dDirective,
|
||||||
MapComponent,
|
MapComponent,
|
||||||
MapSizeFixDirective,
|
MapSizeFixDirective,
|
||||||
@@ -78,6 +77,10 @@ import {filter, map} from 'rxjs';
|
|||||||
ThingPoiFeatureCollectionPipe,
|
ThingPoiFeatureCollectionPipe,
|
||||||
ThingPolygonFeatureCollectionPipe,
|
ThingPolygonFeatureCollectionPipe,
|
||||||
TranslateModule,
|
TranslateModule,
|
||||||
|
IonContent,
|
||||||
|
IonLabel,
|
||||||
|
IonRouterLink,
|
||||||
|
IonButton,
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
export class MapPageComponent {
|
export class MapPageComponent {
|
||||||
|
|||||||
@@ -15,11 +15,10 @@
|
|||||||
import {ChangeDetectionStrategy, Component, HostBinding, Input, inject} from '@angular/core';
|
import {ChangeDetectionStrategy, Component, HostBinding, Input, inject} from '@angular/core';
|
||||||
import {RouterLink} from '@angular/router';
|
import {RouterLink} from '@angular/router';
|
||||||
import {ControlComponent, MapComponent, MarkerComponent} from '@maplibre/ngx-maplibre-gl';
|
import {ControlComponent, MapComponent, MarkerComponent} from '@maplibre/ngx-maplibre-gl';
|
||||||
import {AnimationController, IonicModule} from '@ionic/angular';
|
import {AnimationController, IonRouterLink} from '@ionic/angular/standalone';
|
||||||
import {GeoNavigationDirective} from './geo-navigation.directive';
|
import {GeoNavigationDirective} from './geo-navigation.directive';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {MapAuto3dDirective} from './map-auto-3d.directive';
|
import {MapAuto3dDirective} from './map-auto-3d.directive';
|
||||||
import {MediaQueryPipe} from 'src/app/util/media-query.pipe';
|
import {MediaQueryPipe} from 'src/app/util/media-query.pipe';
|
||||||
import {MapStyleDirective} from './map-style.directive';
|
import {MapStyleDirective} from './map-style.directive';
|
||||||
@@ -31,6 +30,7 @@ import {BuildingMarkersComponent} from './elements/building-markers.component';
|
|||||||
import {ThingBoundsPipe} from './thing-bounds.pipe';
|
import {ThingBoundsPipe} from './thing-bounds.pipe';
|
||||||
import {AttributionComponent} from './controls/attribution.component';
|
import {AttributionComponent} from './controls/attribution.component';
|
||||||
import {mapMaximizeAnimation} from './map-maximize-animation';
|
import {mapMaximizeAnimation} from './map-maximize-animation';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The map widget (needs a container with explicit size)
|
* The map widget (needs a container with explicit size)
|
||||||
@@ -47,8 +47,7 @@ import {mapMaximizeAnimation} from './map-maximize-animation';
|
|||||||
CommonModule,
|
CommonModule,
|
||||||
ControlComponent,
|
ControlComponent,
|
||||||
GeoNavigationDirective,
|
GeoNavigationDirective,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
IonicModule,
|
|
||||||
MapAuto3dDirective,
|
MapAuto3dDirective,
|
||||||
MapComponent,
|
MapComponent,
|
||||||
MapSizeFixDirective,
|
MapSizeFixDirective,
|
||||||
@@ -61,6 +60,7 @@ import {mapMaximizeAnimation} from './map-maximize-animation';
|
|||||||
ThingPoiFeatureCollectionPipe,
|
ThingPoiFeatureCollectionPipe,
|
||||||
ThingPolygonFeatureCollectionPipe,
|
ThingPolygonFeatureCollectionPipe,
|
||||||
TranslateModule,
|
TranslateModule,
|
||||||
|
IonRouterLink,
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
export class MapWidgetComponent {
|
export class MapWidgetComponent {
|
||||||
|
|||||||
@@ -17,7 +17,6 @@ import {APP_BASE_HREF, CommonModule, Location, LocationStrategy, PathLocationStr
|
|||||||
import {ComponentFixture, TestBed} from '@angular/core/testing';
|
import {ComponentFixture, TestBed} from '@angular/core/testing';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {ChildrenOutletContexts, RouterModule, UrlSerializer} from '@angular/router';
|
import {ChildrenOutletContexts, RouterModule, UrlSerializer} from '@angular/router';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {SCFacet, SCThingType} from '@openstapps/core';
|
import {SCFacet, SCThingType} from '@openstapps/core';
|
||||||
import {ContextMenuComponent} from './context-menu.component';
|
import {ContextMenuComponent} from './context-menu.component';
|
||||||
@@ -26,6 +25,7 @@ import {ContextMenuService} from './context-menu.service';
|
|||||||
import {FilterContext, SortContext} from './context-type';
|
import {FilterContext, SortContext} from './context-type';
|
||||||
import {Component} from '@angular/core';
|
import {Component} from '@angular/core';
|
||||||
import {By} from '@angular/platform-browser';
|
import {By} from '@angular/platform-browser';
|
||||||
|
import {provideIonicAngular} from '@ionic/angular/standalone';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
template: `<ion-content id="foo"></ion-content><stapps-context contentId="foo"></stapps-context> `,
|
template: `<ion-content id="foo"></ion-content><stapps-context contentId="foo"></stapps-context> `,
|
||||||
@@ -40,6 +40,7 @@ describe('ContextMenuComponent', async () => {
|
|||||||
TestBed.configureTestingModule({
|
TestBed.configureTestingModule({
|
||||||
declarations: [ContextMenuComponent, ContextMenuContainerComponent],
|
declarations: [ContextMenuComponent, ContextMenuContainerComponent],
|
||||||
providers: [
|
providers: [
|
||||||
|
provideIonicAngular(),
|
||||||
ChildrenOutletContexts,
|
ChildrenOutletContexts,
|
||||||
Location,
|
Location,
|
||||||
UrlSerializer,
|
UrlSerializer,
|
||||||
@@ -49,7 +50,6 @@ describe('ContextMenuComponent', async () => {
|
|||||||
],
|
],
|
||||||
imports: [
|
imports: [
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonicModule.forRoot(),
|
|
||||||
TranslateModule.forRoot(),
|
TranslateModule.forRoot(),
|
||||||
CommonModule,
|
CommonModule,
|
||||||
SettingsModule,
|
SettingsModule,
|
||||||
|
|||||||
@@ -50,7 +50,7 @@
|
|||||||
</ion-list>
|
</ion-list>
|
||||||
<!-- Filter Context -->
|
<!-- Filter Context -->
|
||||||
@if (filterOption) {
|
@if (filterOption) {
|
||||||
<div class="context-filter">
|
<form class="context-filter">
|
||||||
<ion-list-header>
|
<ion-list-header>
|
||||||
<ion-icon name="filter_list"></ion-icon>
|
<ion-icon name="filter_list"></ion-icon>
|
||||||
<ion-title>{{ 'menu.context.filter.title' | translate | titlecase }}</ion-title>
|
<ion-title>{{ 'menu.context.filter.title' | translate | titlecase }}</ion-title>
|
||||||
@@ -80,6 +80,7 @@
|
|||||||
<ion-checkbox
|
<ion-checkbox
|
||||||
[(ngModel)]="bucket.checked"
|
[(ngModel)]="bucket.checked"
|
||||||
(ngModelChange)="filterChanged()"
|
(ngModelChange)="filterChanged()"
|
||||||
|
[name]="facet.onlyOnType + '-' + facet.field + '-' + bucket.key"
|
||||||
[value]="{
|
[value]="{
|
||||||
field: facet.field,
|
field: facet.field,
|
||||||
value: bucket.key,
|
value: bucket.key,
|
||||||
@@ -107,7 +108,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</ion-list>
|
</ion-list>
|
||||||
}
|
}
|
||||||
</div>
|
</form>
|
||||||
}
|
}
|
||||||
</ion-content>
|
</ion-content>
|
||||||
</ion-menu>
|
</ion-menu>
|
||||||
|
|||||||
@@ -17,12 +17,28 @@ import {NgModule} from '@angular/core';
|
|||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {RouterModule} from '@angular/router';
|
import {RouterModule} from '@angular/router';
|
||||||
import {LayoutModule} from '@angular/cdk/layout';
|
import {LayoutModule} from '@angular/cdk/layout';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {SettingsModule} from '../settings/settings.module';
|
import {SettingsModule} from '../settings/settings.module';
|
||||||
import {ContextMenuComponent} from './context/context-menu.component';
|
import {ContextMenuComponent} from './context/context-menu.component';
|
||||||
import {ContextMenuService} from './context/context-menu.service';
|
import {ContextMenuService} from './context/context-menu.service';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonButton,
|
||||||
|
IonCheckbox,
|
||||||
|
IonContent,
|
||||||
|
IonItem,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonListHeader,
|
||||||
|
IonMenu,
|
||||||
|
IonMenuToggle,
|
||||||
|
IonRadio,
|
||||||
|
IonRadioGroup,
|
||||||
|
IonTabBar,
|
||||||
|
IonTabButton,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Menu module
|
* Menu module
|
||||||
@@ -32,13 +48,27 @@ import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|||||||
exports: [ContextMenuComponent],
|
exports: [ContextMenuComponent],
|
||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonicModule.forRoot(),
|
|
||||||
RouterModule,
|
RouterModule,
|
||||||
SettingsModule,
|
SettingsModule,
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
LayoutModule,
|
LayoutModule,
|
||||||
|
IonLabel,
|
||||||
|
IonTabButton,
|
||||||
|
IonTabBar,
|
||||||
|
IonMenu,
|
||||||
|
IonMenuToggle,
|
||||||
|
IonButton,
|
||||||
|
IonCheckbox,
|
||||||
|
IonItem,
|
||||||
|
IonList,
|
||||||
|
IonListHeader,
|
||||||
|
IonTitle,
|
||||||
|
IonRadio,
|
||||||
|
IonRadioGroup,
|
||||||
|
IonContent,
|
||||||
|
IonToolbar,
|
||||||
],
|
],
|
||||||
providers: [ContextMenuService],
|
providers: [ContextMenuService],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -17,15 +17,49 @@ import {RootLinkDirective} from './root-link.directive';
|
|||||||
import {NavigationComponent} from './navigation.component';
|
import {NavigationComponent} from './navigation.component';
|
||||||
import {TabsComponent} from './tabs.component';
|
import {TabsComponent} from './tabs.component';
|
||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {IonIconModule} from '../../../util/ion-icon/ion-icon.module';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {RouterModule} from '@angular/router';
|
import {RouterModule} from '@angular/router';
|
||||||
import {OfflineNoticeComponent} from './offline-notice.component';
|
import {OfflineNoticeComponent} from './offline-notice.component';
|
||||||
|
import {
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonContent,
|
||||||
|
IonHeader,
|
||||||
|
IonImg,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonMenu,
|
||||||
|
IonMenuToggle,
|
||||||
|
IonRouterOutlet,
|
||||||
|
IonSplitPane,
|
||||||
|
IonTabBar,
|
||||||
|
IonTabButton,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
declarations: [RootLinkDirective, NavigationComponent, TabsComponent, OfflineNoticeComponent],
|
declarations: [RootLinkDirective, NavigationComponent, TabsComponent, OfflineNoticeComponent],
|
||||||
imports: [CommonModule, IonicModule, IonIconModule, TranslateModule, RouterModule],
|
imports: [
|
||||||
|
CommonModule,
|
||||||
|
IonIconDirective,
|
||||||
|
TranslateModule,
|
||||||
|
RouterModule,
|
||||||
|
IonLabel,
|
||||||
|
IonTabBar,
|
||||||
|
IonTabButton,
|
||||||
|
IonMenuToggle,
|
||||||
|
IonButton,
|
||||||
|
IonRouterOutlet,
|
||||||
|
IonList,
|
||||||
|
IonContent,
|
||||||
|
IonImg,
|
||||||
|
IonButtons,
|
||||||
|
IonHeader,
|
||||||
|
IonMenu,
|
||||||
|
IonToolbar,
|
||||||
|
IonSplitPane,
|
||||||
|
],
|
||||||
exports: [TabsComponent, RootLinkDirective, NavigationComponent],
|
exports: [TabsComponent, RootLinkDirective, NavigationComponent],
|
||||||
})
|
})
|
||||||
export class NavigationModule {}
|
export class NavigationModule {}
|
||||||
|
|||||||
@@ -77,9 +77,7 @@ ion-router-outlet {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.link-active > * {
|
.link-active > * {
|
||||||
color: var(--ion-color-primary);
|
|
||||||
|
|
||||||
::ng-deep stapps-icon {
|
|
||||||
--fill: 1;
|
--fill: 1;
|
||||||
}
|
|
||||||
|
color: var(--ion-color-primary);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {DestroyRef, Directive, ElementRef, inject, Input, OnInit, Renderer2} from '@angular/core';
|
import {DestroyRef, Directive, ElementRef, inject, Input, OnInit, Renderer2} from '@angular/core';
|
||||||
import {AnimationController, NavController} from '@ionic/angular';
|
import {AnimationController, NavController} from '@ionic/angular/standalone';
|
||||||
import {Router, RouterEvent} from '@angular/router';
|
import {Router, RouterEvent} from '@angular/router';
|
||||||
import {tabsTransition} from './tabs-transition';
|
import {tabsTransition} from './tabs-transition';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
|
|||||||
@@ -13,8 +13,8 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import type {AnimationBuilder} from '@ionic/angular';
|
import type {AnimationBuilder} from '@ionic/angular/standalone';
|
||||||
import {AnimationController} from '@ionic/angular';
|
import {AnimationController} from '@ionic/angular/standalone';
|
||||||
import type {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
import type {AnimationOptions} from '@ionic/angular/common/providers/nav-controller';
|
||||||
import {iosDuration, iosEasing, mdDuration, mdEasing} from 'src/app/animation/easings';
|
import {iosDuration, iosEasing, mdDuration, mdEasing} from 'src/app/animation/easings';
|
||||||
|
|
||||||
|
|||||||
@@ -60,6 +60,6 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.tab-selected ::ng-deep stapps-icon {
|
.tab-selected {
|
||||||
--fill: 1;
|
--fill: 1;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ import {ConfigProvider} from '../../config/config.provider';
|
|||||||
import {sampleAuthConfiguration} from '../../../_helpers/data/sample-configuration';
|
import {sampleAuthConfiguration} from '../../../_helpers/data/sample-configuration';
|
||||||
import {TranslateModule, TranslateService} from '@ngx-translate/core';
|
import {TranslateModule, TranslateService} from '@ngx-translate/core';
|
||||||
import {NGXLogger} from 'ngx-logger';
|
import {NGXLogger} from 'ngx-logger';
|
||||||
import {Platform} from '@ionic/angular';
|
import {Platform} from '@ionic/angular/standalone';
|
||||||
import {ThingTranslateService} from '../../../translation/thing-translate.service';
|
import {ThingTranslateService} from '../../../translation/thing-translate.service';
|
||||||
import {SettingsProvider} from '../../settings/settings.provider';
|
import {SettingsProvider} from '../../settings/settings.provider';
|
||||||
import {ScheduleSyncService} from '../../background/schedule/schedule-sync.service';
|
import {ScheduleSyncService} from '../../background/schedule/schedule-sync.service';
|
||||||
|
|||||||
@@ -15,7 +15,6 @@
|
|||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {MomentModule} from 'ngx-moment';
|
import {MomentModule} from 'ngx-moment';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
@@ -28,7 +27,30 @@ import {ChipFilterComponent} from '../data/chips/filter/chip-filter.component';
|
|||||||
import {SettingsModule} from '../settings/settings.module';
|
import {SettingsModule} from '../settings/settings.module';
|
||||||
import {NewsSettingsFilterComponent} from './elements/news-filter-settings/news-settings-filter.component';
|
import {NewsSettingsFilterComponent} from './elements/news-filter-settings/news-settings-filter.component';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonBackButton,
|
||||||
|
IonButtons,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCardSubtitle,
|
||||||
|
IonCardTitle,
|
||||||
|
IonChip,
|
||||||
|
IonCol,
|
||||||
|
IonGrid,
|
||||||
|
IonHeader,
|
||||||
|
IonInfiniteScroll,
|
||||||
|
IonInfiniteScrollContent,
|
||||||
|
IonLabel,
|
||||||
|
IonRefresher,
|
||||||
|
IonRefresherContent,
|
||||||
|
IonRouterLink,
|
||||||
|
IonRow,
|
||||||
|
IonSkeletonText,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const newsRoutes: Routes = [{path: 'news', component: NewsPageComponent}];
|
const newsRoutes: Routes = [{path: 'news', component: NewsPageComponent}];
|
||||||
|
|
||||||
@@ -44,17 +66,37 @@ const newsRoutes: Routes = [{path: 'news', component: NewsPageComponent}];
|
|||||||
NewsSettingsFilterComponent,
|
NewsSettingsFilterComponent,
|
||||||
],
|
],
|
||||||
imports: [
|
imports: [
|
||||||
IonicModule.forRoot(),
|
|
||||||
ThingTranslateModule.forChild(),
|
ThingTranslateModule.forChild(),
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
RouterModule.forChild(newsRoutes),
|
RouterModule.forChild(newsRoutes),
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
CommonModule,
|
CommonModule,
|
||||||
MomentModule,
|
MomentModule,
|
||||||
DataModule,
|
DataModule,
|
||||||
ThingTranslateModule,
|
ThingTranslateModule,
|
||||||
SettingsModule,
|
SettingsModule,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonRouterLink,
|
||||||
|
IonBackButton,
|
||||||
|
IonChip,
|
||||||
|
IonLabel,
|
||||||
|
IonInfiniteScroll,
|
||||||
|
IonInfiniteScrollContent,
|
||||||
|
IonGrid,
|
||||||
|
IonCol,
|
||||||
|
IonRow,
|
||||||
|
IonRefresher,
|
||||||
|
IonRefresherContent,
|
||||||
|
IonHeader,
|
||||||
|
IonToolbar,
|
||||||
|
IonButtons,
|
||||||
|
IonTitle,
|
||||||
|
IonSkeletonText,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardTitle,
|
||||||
|
IonCardSubtitle,
|
||||||
|
IonCardHeader,
|
||||||
],
|
],
|
||||||
providers: [SettingsProvider],
|
providers: [SettingsProvider],
|
||||||
exports: [NewsItemComponent],
|
exports: [NewsItemComponent],
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Component, OnInit} from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
import {IonRefresher} from '@ionic/angular';
|
import {IonRefresher} from '@ionic/angular/standalone';
|
||||||
import {SCMessage, SCSearchFilter, SCSearchValueFilter, SCSetting} from '@openstapps/core';
|
import {SCMessage, SCSearchFilter, SCSearchValueFilter, SCSetting} from '@openstapps/core';
|
||||||
import {NewsProvider} from '../news.provider';
|
import {NewsProvider} from '../news.provider';
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* You should have received a copy of the GNU General Public License along with
|
* You should have received a copy of the GNU General Public License along with
|
||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
@import 'src/theme/util/mixins';
|
@import '../../../../theme/util/mixins';
|
||||||
|
|
||||||
.news-grid {
|
.news-grid {
|
||||||
@include auto-grid(300px);
|
@include auto-grid(300px);
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
|||||||
import {AsyncPipe, TitleCasePipe} from '@angular/common';
|
import {AsyncPipe, TitleCasePipe} from '@angular/common';
|
||||||
import {IntervalIsNowPipe, ToDateIntervalPipe} from '../../util/in-range.pipe';
|
import {IntervalIsNowPipe, ToDateIntervalPipe} from '../../util/in-range.pipe';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {AnimationController, ModalController} from '@ionic/angular';
|
import {AnimationController, ModalController} from '@ionic/angular/standalone';
|
||||||
import {ScreenBrightness} from '@capacitor-community/screen-brightness';
|
import {ScreenBrightness} from '@capacitor-community/screen-brightness';
|
||||||
import {ScreenOrientation} from '@capacitor/screen-orientation';
|
import {ScreenOrientation} from '@capacitor/screen-orientation';
|
||||||
import {Capacitor} from '@capacitor/core';
|
import {Capacitor} from '@capacitor/core';
|
||||||
|
|||||||
@@ -15,13 +15,13 @@
|
|||||||
import {ChangeDetectionStrategy, Component} from '@angular/core';
|
import {ChangeDetectionStrategy, Component} from '@angular/core';
|
||||||
import {IdCardsProvider} from './id-cards.provider';
|
import {IdCardsProvider} from './id-cards.provider';
|
||||||
import {SCIdCard} from '@openstapps/core';
|
import {SCIdCard} from '@openstapps/core';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {AsyncPipe, TitleCasePipe} from '@angular/common';
|
import {AsyncPipe, TitleCasePipe} from '@angular/common';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IdCardComponent} from './id-card.component';
|
import {IdCardComponent} from './id-card.component';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {Observable} from 'rxjs';
|
import {Observable} from 'rxjs';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'stapps-id-cards',
|
selector: 'stapps-id-cards',
|
||||||
@@ -31,13 +31,13 @@ import {Observable} from 'rxjs';
|
|||||||
changeDetection: ChangeDetectionStrategy.OnPush,
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
||||||
standalone: true,
|
standalone: true,
|
||||||
imports: [
|
imports: [
|
||||||
IonicModule,
|
|
||||||
AsyncPipe,
|
AsyncPipe,
|
||||||
ThingTranslateModule,
|
ThingTranslateModule,
|
||||||
UtilModule,
|
UtilModule,
|
||||||
IdCardComponent,
|
IdCardComponent,
|
||||||
TranslateModule,
|
TranslateModule,
|
||||||
TitleCasePipe,
|
TitleCasePipe,
|
||||||
|
IonIconDirective,
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
export class IdCardsComponent {
|
export class IdCardsComponent {
|
||||||
|
|||||||
@@ -16,18 +16,38 @@ import {NgModule} from '@angular/core';
|
|||||||
import {CommonModule} from '@angular/common';
|
import {CommonModule} from '@angular/common';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {ProfilePageComponent} from './page/profile-page.component';
|
import {ProfilePageComponent} from './page/profile-page.component';
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {SwiperModule} from 'swiper/angular';
|
import {SwiperModule} from 'swiper/angular';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {ProfilePageSectionComponent} from './page/profile-page-section.component';
|
import {ProfilePageSectionComponent} from './page/profile-page-section.component';
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {DataModule} from '../data/data.module';
|
import {DataModule} from '../data/data.module';
|
||||||
import {MyCoursesComponent} from './page/my-courses.component';
|
import {MyCoursesComponent} from './page/my-courses.component';
|
||||||
import {MomentModule} from 'ngx-moment';
|
import {MomentModule} from 'ngx-moment';
|
||||||
import {IdCardsComponent} from './id-cards.component';
|
import {IdCardsComponent} from './id-cards.component';
|
||||||
|
import {
|
||||||
|
IonAccordion,
|
||||||
|
IonAccordionGroup,
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCol,
|
||||||
|
IonGrid,
|
||||||
|
IonHeader,
|
||||||
|
IonItem,
|
||||||
|
IonItemDivider,
|
||||||
|
IonItemGroup,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonRouterLink,
|
||||||
|
IonRow,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const routes: Routes = [
|
const routes: Routes = [
|
||||||
{
|
{
|
||||||
@@ -41,8 +61,7 @@ const routes: Routes = [
|
|||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
IonicModule,
|
|
||||||
RouterModule.forChild(routes),
|
RouterModule.forChild(routes),
|
||||||
TranslateModule,
|
TranslateModule,
|
||||||
SwiperModule,
|
SwiperModule,
|
||||||
@@ -51,6 +70,25 @@ const routes: Routes = [
|
|||||||
DataModule,
|
DataModule,
|
||||||
MomentModule,
|
MomentModule,
|
||||||
IdCardsComponent,
|
IdCardsComponent,
|
||||||
|
IonRouterLink,
|
||||||
|
IonBackButton,
|
||||||
|
IonTitle,
|
||||||
|
IonButtons,
|
||||||
|
IonToolbar,
|
||||||
|
IonHeader,
|
||||||
|
IonLabel,
|
||||||
|
IonGrid,
|
||||||
|
IonRow,
|
||||||
|
IonCol,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonItem,
|
||||||
|
IonButton,
|
||||||
|
IonItemGroup,
|
||||||
|
IonItemDivider,
|
||||||
|
IonList,
|
||||||
|
IonAccordion,
|
||||||
|
IonAccordionGroup,
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
export class ProfilePageModule {}
|
export class ProfilePageModule {}
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ import {ScheduleProvider} from '../../calendar/schedule.provider';
|
|||||||
import {CalendarComponent} from './components/calendar.component';
|
import {CalendarComponent} from './components/calendar.component';
|
||||||
import {CalendarService} from '../../calendar/calendar.service';
|
import {CalendarService} from '../../calendar/calendar.service';
|
||||||
import {InfiniteSwiperComponent} from './grid/infinite-swiper.component';
|
import {InfiniteSwiperComponent} from './grid/infinite-swiper.component';
|
||||||
import {IonContent} from '@ionic/angular';
|
import {IonContent} from '@ionic/angular/standalone';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ import {ScheduleProvider} from '../../../calendar/schedule.provider';
|
|||||||
import {ScheduleEvent, ScheduleResponsiveBreakpoint} from '../schema/schema';
|
import {ScheduleEvent, ScheduleResponsiveBreakpoint} from '../schema/schema';
|
||||||
import {SwiperComponent} from 'swiper/angular';
|
import {SwiperComponent} from 'swiper/angular';
|
||||||
import {InfiniteSwiperComponent} from '../grid/infinite-swiper.component';
|
import {InfiniteSwiperComponent} from '../grid/infinite-swiper.component';
|
||||||
import {IonContent, IonDatetime} from '@ionic/angular';
|
import {IonContent, IonDatetime} from '@ionic/angular/standalone';
|
||||||
import {CalendarService} from '../../../calendar/calendar.service';
|
import {CalendarService} from '../../../calendar/calendar.service';
|
||||||
import {getScheduleCursorOffset} from '../grid/schedule-cursor-offset';
|
import {getScheduleCursorOffset} from '../grid/schedule-cursor-offset';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
import {AfterViewInit, Component, HostListener, Input, OnInit, ViewChild} from '@angular/core';
|
import {AfterViewInit, Component, HostListener, Input, OnInit, ViewChild} from '@angular/core';
|
||||||
import {Location} from '@angular/common';
|
import {Location} from '@angular/common';
|
||||||
import {ActivatedRoute, Router} from '@angular/router';
|
import {ActivatedRoute, Router} from '@angular/router';
|
||||||
import {AnimationController, IonRouterOutlet} from '@ionic/angular';
|
import {AnimationController, IonRouterOutlet} from '@ionic/angular/standalone';
|
||||||
import {SharedAxisChoreographer} from '../../../animation/animation-choreographer';
|
import {SharedAxisChoreographer} from '../../../animation/animation-choreographer';
|
||||||
import {materialSharedAxisX} from '../../../animation/material-motion';
|
import {materialSharedAxisX} from '../../../animation/material-motion';
|
||||||
import {ScheduleResponsiveBreakpoint} from './schema/schema';
|
import {ScheduleResponsiveBreakpoint} from './schema/schema';
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ ion-header {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ion-segment-button[aria-selected='true'] ion-icon ::ng-deep stapps-icon {
|
ion-segment-button.segment-button-checked ion-icon {
|
||||||
--fill: 1;
|
--fill: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ import {SCISO8601Date, SCUuid} from '@openstapps/core';
|
|||||||
import {ScheduleEvent, ScheduleResponsiveBreakpoint} from './schema/schema';
|
import {ScheduleEvent, ScheduleResponsiveBreakpoint} from './schema/schema';
|
||||||
import {CalendarService} from '../../calendar/calendar.service';
|
import {CalendarService} from '../../calendar/calendar.service';
|
||||||
import {CalendarComponent} from './components/calendar.component';
|
import {CalendarComponent} from './components/calendar.component';
|
||||||
import {IonContent, IonDatetime} from '@ionic/angular';
|
import {IonContent, IonDatetime} from '@ionic/angular/standalone';
|
||||||
import {SwiperComponent} from 'swiper/angular';
|
import {SwiperComponent} from 'swiper/angular';
|
||||||
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
|
||||||
|
|
||||||
|
|||||||
@@ -16,7 +16,6 @@ import {CommonModule} from '@angular/common';
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
import {ScheduleCardComponent} from './page/grid/schedule-card.component';
|
import {ScheduleCardComponent} from './page/grid/schedule-card.component';
|
||||||
|
|
||||||
@@ -35,8 +34,34 @@ import {ScheduleDayComponent} from './page/grid/schedule-day.component';
|
|||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
import {InfiniteSwiperComponent} from './page/grid/infinite-swiper.component';
|
import {InfiniteSwiperComponent} from './page/grid/infinite-swiper.component';
|
||||||
import {CalendarComponent} from './page/components/calendar.component';
|
import {CalendarComponent} from './page/components/calendar.component';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
|
||||||
import {ChooseEventsPageComponent} from './page/choose-events-page.component';
|
import {ChooseEventsPageComponent} from './page/choose-events-page.component';
|
||||||
|
import {
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCardTitle,
|
||||||
|
IonContent,
|
||||||
|
IonDatetime,
|
||||||
|
IonFab,
|
||||||
|
IonFabButton,
|
||||||
|
IonHeader,
|
||||||
|
IonItem,
|
||||||
|
IonItemGroup,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonNote,
|
||||||
|
IonPopover,
|
||||||
|
IonRouterLink,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonText,
|
||||||
|
IonTitle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const settingsRoutes: Routes = [
|
const settingsRoutes: Routes = [
|
||||||
{path: 'schedule', redirectTo: 'schedule/calendar/now'},
|
{path: 'schedule', redirectTo: 'schedule/calendar/now'},
|
||||||
@@ -69,14 +94,37 @@ const settingsRoutes: Routes = [
|
|||||||
CommonModule,
|
CommonModule,
|
||||||
DataModule,
|
DataModule,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
IonicModule.forRoot(),
|
IonIconDirective,
|
||||||
IonIconModule,
|
|
||||||
MomentModule,
|
MomentModule,
|
||||||
RouterModule.forChild(settingsRoutes),
|
RouterModule.forChild(settingsRoutes),
|
||||||
SwiperModule,
|
SwiperModule,
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
UtilModule,
|
UtilModule,
|
||||||
ThingTranslateModule,
|
ThingTranslateModule,
|
||||||
|
IonBackButton,
|
||||||
|
IonContent,
|
||||||
|
IonDatetime,
|
||||||
|
IonButton,
|
||||||
|
IonPopover,
|
||||||
|
IonText,
|
||||||
|
IonItem,
|
||||||
|
IonLabel,
|
||||||
|
IonFabButton,
|
||||||
|
IonList,
|
||||||
|
IonItemGroup,
|
||||||
|
IonFab,
|
||||||
|
IonSegment,
|
||||||
|
IonSegmentButton,
|
||||||
|
IonRouterLink,
|
||||||
|
IonToolbar,
|
||||||
|
IonButtons,
|
||||||
|
IonTitle,
|
||||||
|
IonNote,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonHeader,
|
||||||
|
IonCardTitle,
|
||||||
|
IonCardHeader,
|
||||||
],
|
],
|
||||||
providers: [ScheduleProvider, DataProvider, DateFormatPipe],
|
providers: [ScheduleProvider, DataProvider, DateFormatPipe],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Component, Input} from '@angular/core';
|
import {Component, Input} from '@angular/core';
|
||||||
import {AlertController} from '@ionic/angular';
|
import {AlertController} from '@ionic/angular/standalone';
|
||||||
import {LangChangeEvent, TranslateService} from '@ngx-translate/core';
|
import {LangChangeEvent, TranslateService} from '@ngx-translate/core';
|
||||||
import {SCLanguageCode, SCSetting, SCSettingValue, SCSettingValues} from '@openstapps/core';
|
import {SCLanguageCode, SCSetting, SCSettingValue, SCSettingValues} from '@openstapps/core';
|
||||||
import {SettingsProvider} from '../settings.provider';
|
import {SettingsProvider} from '../settings.provider';
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
|
|
||||||
import {Component, OnInit} from '@angular/core';
|
import {Component, OnInit} from '@angular/core';
|
||||||
import {AddEventReviewModalComponent} from '../../calendar/add-event-review-modal.component';
|
import {AddEventReviewModalComponent} from '../../calendar/add-event-review-modal.component';
|
||||||
import {ModalController} from '@ionic/angular';
|
import {ModalController} from '@ionic/angular/standalone';
|
||||||
import {ScheduleProvider} from '../../calendar/schedule.provider';
|
import {ScheduleProvider} from '../../calendar/schedule.provider';
|
||||||
import {Directory, Encoding, Filesystem} from '@capacitor/filesystem';
|
import {Directory, Encoding, Filesystem} from '@capacitor/filesystem';
|
||||||
import {Share} from '@capacitor/share';
|
import {Share} from '@capacitor/share';
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {ChangeDetectorRef, Component, OnInit} from '@angular/core';
|
import {ChangeDetectorRef, Component, OnInit} from '@angular/core';
|
||||||
import {AlertController, ToastController} from '@ionic/angular';
|
import {AlertController, ToastController} from '@ionic/angular/standalone';
|
||||||
import {TranslateService} from '@ngx-translate/core';
|
import {TranslateService} from '@ngx-translate/core';
|
||||||
import {SCSettingMeta} from '@openstapps/core';
|
import {SCSettingMeta} from '@openstapps/core';
|
||||||
import {SettingsCache, SettingsProvider} from '../settings.provider';
|
import {SettingsCache, SettingsProvider} from '../settings.provider';
|
||||||
|
|||||||
@@ -16,7 +16,6 @@ import {CommonModule} from '@angular/common';
|
|||||||
import {NgModule} from '@angular/core';
|
import {NgModule} from '@angular/core';
|
||||||
import {FormsModule} from '@angular/forms';
|
import {FormsModule} from '@angular/forms';
|
||||||
import {RouterModule, Routes} from '@angular/router';
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
import {IonicModule} from '@ionic/angular';
|
|
||||||
import {TranslateModule} from '@ngx-translate/core';
|
import {TranslateModule} from '@ngx-translate/core';
|
||||||
|
|
||||||
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
import {ThingTranslateModule} from '../../translation/thing-translate.module';
|
||||||
@@ -32,7 +31,30 @@ import {CalendarService} from '../calendar/calendar.service';
|
|||||||
import {CalendarModule} from '../calendar/calendar.module';
|
import {CalendarModule} from '../calendar/calendar.module';
|
||||||
import {BackgroundModule} from '../background/background.module';
|
import {BackgroundModule} from '../background/background.module';
|
||||||
import {UtilModule} from '../../util/util.module';
|
import {UtilModule} from '../../util/util.module';
|
||||||
import {IonIconModule} from '../../util/ion-icon/ion-icon.module';
|
import {
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonButtons,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardHeader,
|
||||||
|
IonCardSubtitle,
|
||||||
|
IonHeader,
|
||||||
|
IonInput,
|
||||||
|
IonItem,
|
||||||
|
IonItemDivider,
|
||||||
|
IonItemGroup,
|
||||||
|
IonLabel,
|
||||||
|
IonList,
|
||||||
|
IonNote,
|
||||||
|
IonRouterLink,
|
||||||
|
IonSelect,
|
||||||
|
IonSelectOption,
|
||||||
|
IonTitle,
|
||||||
|
IonToggle,
|
||||||
|
IonToolbar,
|
||||||
|
} from '@ionic/angular/standalone';
|
||||||
|
import {IonIconDirective} from 'src/app/util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
const settingsRoutes: Routes = [{path: 'settings', component: SettingsPageComponent}];
|
const settingsRoutes: Routes = [{path: 'settings', component: SettingsPageComponent}];
|
||||||
|
|
||||||
@@ -51,13 +73,33 @@ const settingsRoutes: Routes = [{path: 'settings', component: SettingsPageCompon
|
|||||||
CommonModule,
|
CommonModule,
|
||||||
FormsModule,
|
FormsModule,
|
||||||
CalendarModule,
|
CalendarModule,
|
||||||
IonIconModule,
|
IonIconDirective,
|
||||||
BackgroundModule,
|
BackgroundModule,
|
||||||
IonicModule.forRoot(),
|
|
||||||
TranslateModule.forChild(),
|
TranslateModule.forChild(),
|
||||||
ThingTranslateModule.forChild(),
|
ThingTranslateModule.forChild(),
|
||||||
RouterModule.forChild(settingsRoutes),
|
RouterModule.forChild(settingsRoutes),
|
||||||
UtilModule,
|
UtilModule,
|
||||||
|
IonRouterLink,
|
||||||
|
IonBackButton,
|
||||||
|
IonButton,
|
||||||
|
IonList,
|
||||||
|
IonTitle,
|
||||||
|
IonButtons,
|
||||||
|
IonToolbar,
|
||||||
|
IonHeader,
|
||||||
|
IonLabel,
|
||||||
|
IonItem,
|
||||||
|
IonItemDivider,
|
||||||
|
IonItemGroup,
|
||||||
|
IonToggle,
|
||||||
|
IonCard,
|
||||||
|
IonCardContent,
|
||||||
|
IonCardSubtitle,
|
||||||
|
IonCardHeader,
|
||||||
|
IonSelect,
|
||||||
|
IonSelectOption,
|
||||||
|
IonInput,
|
||||||
|
IonNote,
|
||||||
],
|
],
|
||||||
providers: [ScheduleSyncService, SettingsProvider, CalendarService, ScheduleProvider, ThingTranslatePipe],
|
providers: [ScheduleSyncService, SettingsProvider, CalendarService, ScheduleProvider, ThingTranslatePipe],
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -29,16 +29,16 @@ import {
|
|||||||
import {ThingTranslateDefaultParser, ThingTranslateParser} from './thing-translate.parser';
|
import {ThingTranslateDefaultParser, ThingTranslateParser} from './thing-translate.parser';
|
||||||
import {ThingTranslatePipe} from './thing-translate.pipe';
|
import {ThingTranslatePipe} from './thing-translate.pipe';
|
||||||
import {ThingTranslateService} from './thing-translate.service';
|
import {ThingTranslateService} from './thing-translate.service';
|
||||||
import {IonIconModule} from '../util/ion-icon/ion-icon.module';
|
|
||||||
import {TranslateSimplePipe} from './translate-simple.pipe';
|
import {TranslateSimplePipe} from './translate-simple.pipe';
|
||||||
import {PropertyNameTranslatePipe} from './property-name-translate.pipe';
|
import {PropertyNameTranslatePipe} from './property-name-translate.pipe';
|
||||||
|
import {IonIconDirective} from '../util/ion-icon/ion-icon.directive';
|
||||||
|
|
||||||
export interface ThingTranslateModuleConfig {
|
export interface ThingTranslateModuleConfig {
|
||||||
parser?: Provider;
|
parser?: Provider;
|
||||||
}
|
}
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [IonIconModule],
|
imports: [IonIconDirective],
|
||||||
declarations: [
|
declarations: [
|
||||||
ArrayJoinPipe,
|
ArrayJoinPipe,
|
||||||
DurationLocalizedPipe,
|
DurationLocalizedPipe,
|
||||||
@@ -56,7 +56,6 @@ export interface ThingTranslateModuleConfig {
|
|||||||
IsNumericPipe,
|
IsNumericPipe,
|
||||||
],
|
],
|
||||||
exports: [
|
exports: [
|
||||||
IonIconModule,
|
|
||||||
ArrayJoinPipe,
|
ArrayJoinPipe,
|
||||||
DurationLocalizedPipe,
|
DurationLocalizedPipe,
|
||||||
NumberLocalizedPipe,
|
NumberLocalizedPipe,
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
* You should have received a copy of the GNU General Public License along with
|
* You should have received a copy of the GNU General Public License along with
|
||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
* this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
import {Platform} from '@ionic/angular';
|
import {Platform} from '@ionic/angular/standalone';
|
||||||
import {Browser as BrowserPlugin} from '@capacitor/browser';
|
import {Browser as BrowserPlugin} from '@capacitor/browser';
|
||||||
|
|
||||||
export abstract class SimpleBrowser {
|
export abstract class SimpleBrowser {
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ import {
|
|||||||
IonModal,
|
IonModal,
|
||||||
IonRouterOutlet,
|
IonRouterOutlet,
|
||||||
ModalController,
|
ModalController,
|
||||||
} from '@ionic/angular';
|
} from '@ionic/angular/standalone';
|
||||||
import {pendingChangesActionSheet, PendingChangesRole} from './pending-changes-action-sheet';
|
import {pendingChangesActionSheet, PendingChangesRole} from './pending-changes-action-sheet';
|
||||||
import {TranslatePipe} from '@ngx-translate/core';
|
import {TranslatePipe} from '@ngx-translate/core';
|
||||||
|
|
||||||
|
|||||||
@@ -1,46 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2023 StApps
|
|
||||||
* This program is free software: you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License as published by the Free
|
|
||||||
* Software Foundation, version 3.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
||||||
* more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License along with
|
|
||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import {ChangeDetectionStrategy, Component, HostBinding, Input} from '@angular/core';
|
|
||||||
|
|
||||||
@Component({
|
|
||||||
selector: 'stapps-icon',
|
|
||||||
templateUrl: 'icon.html',
|
|
||||||
styleUrls: ['icon.scss'],
|
|
||||||
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
||||||
})
|
|
||||||
export class IconComponent {
|
|
||||||
@HostBinding('style.--size')
|
|
||||||
@Input()
|
|
||||||
size?: number;
|
|
||||||
|
|
||||||
@HostBinding('style.--weight')
|
|
||||||
@Input()
|
|
||||||
weight?: number;
|
|
||||||
|
|
||||||
@HostBinding('style.--grade')
|
|
||||||
@Input()
|
|
||||||
grade?: number;
|
|
||||||
|
|
||||||
@HostBinding('style.--fill')
|
|
||||||
@Input()
|
|
||||||
fill?: number;
|
|
||||||
|
|
||||||
@HostBinding('innerHtml')
|
|
||||||
@Input()
|
|
||||||
name: string;
|
|
||||||
|
|
||||||
@HostBinding('class.material-symbols-rounded') hostClass = true;
|
|
||||||
}
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
<!--
|
|
||||||
~ Copyright (C) 2022 StApps
|
|
||||||
~ This program is free software: you can redistribute it and/or modify it
|
|
||||||
~ under the terms of the GNU General Public License as published by the Free
|
|
||||||
~ Software Foundation, version 3.
|
|
||||||
~
|
|
||||||
~ This program is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
~ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
~ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
||||||
~ more details.
|
|
||||||
~
|
|
||||||
~ You should have received a copy of the GNU General Public License along with
|
|
||||||
~ this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
-->
|
|
||||||
<ng-content></ng-content>
|
|
||||||
@@ -1,31 +0,0 @@
|
|||||||
/*!
|
|
||||||
* Copyright (C) 2022 StApps
|
|
||||||
* This program is free software: you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License as published by the Free
|
|
||||||
* Software Foundation, version 3.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
||||||
* more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License along with
|
|
||||||
* this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
:host {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: center;
|
|
||||||
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
|
|
||||||
font-size: inherit;
|
|
||||||
font-variation-settings:
|
|
||||||
'wght' var(--weight),
|
|
||||||
'GRAD' var(--grade),
|
|
||||||
'FILL' var(--fill);
|
|
||||||
|
|
||||||
transition: all 0.2s ease-in-out;
|
|
||||||
}
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user