taon 18.0.22 → 18.0.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/shared/shared_folder_info.txt +1 -1
- package/browser/esm2022/lib/create-context.mjs +8 -3
- package/browser/esm2022/lib/endpoint-context.mjs +12 -2
- package/browser/esm2022/lib/models.mjs +1 -1
- package/browser/esm2022/lib/orm.mjs +1 -1
- package/browser/esm2022/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.mjs +24 -26
- package/browser/esm2022/lib/ui/taon-admin-mode-configuration/taon-admin.service.mjs +4 -9
- package/browser/fesm2022/taon.mjs +46 -35
- package/browser/fesm2022/taon.mjs.map +1 -1
- package/browser/lib/endpoint-context.d.ts +1 -0
- package/browser/lib/models.d.ts +1 -0
- package/browser/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.d.ts +1 -2
- package/browser/lib/ui/taon-admin-mode-configuration/taon-admin.service.d.ts +0 -3
- package/client/esm2022/lib/create-context.mjs +8 -3
- package/client/esm2022/lib/endpoint-context.mjs +12 -2
- package/client/esm2022/lib/models.mjs +1 -1
- package/client/esm2022/lib/orm.mjs +1 -1
- package/client/esm2022/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.mjs +24 -26
- package/client/esm2022/lib/ui/taon-admin-mode-configuration/taon-admin.service.mjs +4 -9
- package/client/fesm2022/taon.mjs +46 -35
- package/client/fesm2022/taon.mjs.map +1 -1
- package/client/lib/endpoint-context.d.ts +1 -0
- package/client/lib/models.d.ts +1 -0
- package/client/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.d.ts +1 -2
- package/client/lib/ui/taon-admin-mode-configuration/taon-admin.service.d.ts +0 -3
- package/lib/base-classes/base-migration.d.ts +2 -2
- package/lib/base-classes/base-repository.d.ts +4 -4
- package/lib/base-classes/base-subscriber-for-entity.d.ts +2 -2
- package/lib/context-db-migrations.d.ts +2 -2
- package/lib/create-context.js +8 -2
- package/lib/create-context.js.map +1 -1
- package/lib/decorators/classes/entity-decorator.d.ts +2 -2
- package/lib/decorators/http/http-decorators.d.ts +2 -2
- package/lib/decorators/http/http-methods-decorators.d.ts +3 -3
- package/lib/endpoint-context.d.ts +2 -1
- package/lib/endpoint-context.js +93 -83
- package/lib/endpoint-context.js.map +1 -1
- package/lib/formly/fromly.d.ts +2 -2
- package/lib/models.d.ts +4 -3
- package/lib/models.js.map +1 -1
- package/lib/orm.d.ts +7 -3
- package/lib/orm.js +11 -2
- package/lib/orm.js.map +1 -1
- package/lib/ui/directives/index.js +2 -2
- package/lib/ui/directives/taon-long-press.directive.d.ts +1 -1
- package/lib/ui/index.js +2 -2
- package/lib/ui/taon-admin-mode-configuration/index.js +2 -2
- package/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.d.ts +2 -3
- package/lib/ui/taon-github-fork-me-corner/index.js +2 -2
- package/lib/ui/taon-github-fork-me-ribbon/index.js +2 -2
- package/lib/ui/taon-notifications/taon-notifications.models.js +2 -2
- package/lib/ui/taon-progress-bar/index.js +2 -2
- package/lib/ui/taon-session-passcode/index.js +2 -2
- package/lib/ui/taon-table/index.js +2 -2
- package/lib/ui/taon-table/taon-table.component.d.ts +1 -1
- package/lib/ui/taon.models.d.ts +2 -2
- package/package.json +7 -7
- package/tmp-environment.json +30 -29
- package/websql/esm2022/lib/create-context.mjs +8 -3
- package/websql/esm2022/lib/endpoint-context.mjs +24 -15
- package/websql/esm2022/lib/models.mjs +1 -1
- package/websql/esm2022/lib/orm.mjs +7 -2
- package/websql/esm2022/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.mjs +24 -26
- package/websql/esm2022/lib/ui/taon-admin-mode-configuration/taon-admin.service.mjs +4 -9
- package/websql/fesm2022/taon.mjs +62 -48
- package/websql/fesm2022/taon.mjs.map +1 -1
- package/websql/lib/endpoint-context.d.ts +1 -0
- package/websql/lib/models.d.ts +1 -0
- package/websql/lib/orm.d.ts +5 -1
- package/websql/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.d.ts +1 -2
- package/websql/lib/ui/taon-admin-mode-configuration/taon-admin.service.d.ts +0 -3
|
@@ -94,4 +94,4 @@ export var Models;
|
|
|
94
94
|
})(Models || (Models = {}));
|
|
95
95
|
;
|
|
96
96
|
({}); // @--end-of-file-for-module=taon lib/models.ts
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../../tmp-libs-for-dist-websql/taon/projects/taon/src/lib/models.ts"],"names":[],"mappings":"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","sourcesContent":["\n\nimport { CoreModels } from 'tnp-core/websql';\nimport { Response, RequestHandler } from 'express';\nimport {   Response as ExpressResponse,   Request as ExpressRequest, } from 'express';/* */\n/* */\n/* */\n\nimport { _ } from 'tnp-core/websql';\nimport { Models as ModelsNg2Rest } from 'ng2-rest/websql';\nimport { ClassHelpers } from './helpers/class-helpers';\nimport type { TaonControllerOptions } from './decorators/classes/controller-decorator';\nimport type { TaonEntityOptions } from './decorators/classes/entity-decorator';\n\nexport namespace Models {\n  export type FrameworkMode =\n    | 'backend-frontend(tcp+udp)'\n    | 'remote-backend(tcp+udp)'\n    | 'backend-frontend(ipc-electron)'\n    | 'backend-frontend(websql-electron)'\n    | 'backend-frontend(websql)';\n\n\n  export enum ClassType {\n    ENTITY = 'ENTITY',\n    CONTROLLER = 'CONTROLLER',\n    REPOSITORY = 'REPOSITORY',\n    PROVIDER = 'PROVIDER',\n    SUBSCRIBER = 'SUBSCRIBER',\n    MIGRATION = 'MIGRATION',\n  }\n\n  export const ClassTypeKey = {\n    [ClassType.ENTITY]: 'entities',\n    [ClassType.CONTROLLER]: 'controllers',\n    [ClassType.REPOSITORY]: 'repositories',\n    [ClassType.PROVIDER]: 'providers',\n    [ClassType.SUBSCRIBER]: 'subscribers',\n    [ClassType.MIGRATION]: 'migrations',\n  } as {\n    [key in ClassType]: keyof ContextOptions<any, any, any, any, any, any, any>;\n  };\n\n\n\n\n  export type MiddlewareType = [Function, any[]];\n\n\n\n  /**\n   * DROP_DB+MIGRATIONS (default for development)\n   * Drop all tables + recreate them + run migrations\n   * synchronize: true , dropSchema: true\n   * use migrations: true\n   *\n   * MIGRATIONS (default for production)\n   * Do not drop tables, only run migrations\n   * synchronize: false, dropSchema: false\n   * use migrations: true\n   */\n  export type DBRecreateMode =\n    | 'DROP_DB+MIGRATIONS'\n    | 'PRESERVE_DATA+MIGRATIONS';\n\n\n\n  export class DatabaseConfigTypeOrm {\n    /**\n     * database name\n     */\n    database?: string;\n    /**\n     * only for file base db: sqlite, sqljs\n     */\n    location?: string;\n    synchronize: boolean;\n    dropSchema: boolean;\n    type?: CoreModels.DatabaseType;\n    /**\n     * Persists db on disk/local-storage if serverless db\n     */\n    autoSave?: boolean;\n    /**\n     * for websql db mode\n     * true by default\n     */\n    useLocalForage?: boolean;\n    logging: boolean;\n    databasePort?: number;\n    databaseHost?: string;\n    databaseUsername?: string;\n    databasePassword?: string;\n  }\n\n\n\n  export class DatabaseConfig extends DatabaseConfigTypeOrm {\n    /**\n     * Default value 'DROP_ALL'.\n     *\n     * Tell framework what is happening with db\n     * when context is starting.\n     */\n    public recreateMode?: DBRecreateMode;\n\n    static from(\n      databasePartialConfig: Partial<\n        Omit<\n          DatabaseConfig,\n          'synchronize' | 'dropSchema' | 'databaseConfigTypeORM'\n        >\n      >,\n    ): DatabaseConfig {\n      return _.merge(new DatabaseConfig(), databasePartialConfig);\n    }\n\n    get databaseConfigTypeORM(): DatabaseConfigTypeOrm {\n\n      const result = _.cloneDeep(this) as DatabaseConfig;\n      if (result.recreateMode) {\n        if (result.recreateMode === 'DROP_DB+MIGRATIONS') {\n          result.synchronize = true;\n          result.dropSchema = true;\n        } else if (result.recreateMode === 'PRESERVE_DATA+MIGRATIONS') {\n          result.synchronize = false;\n          result.dropSchema = false;\n        }\n      }\n      delete result.recreateMode;\n\n      return result as any;\n\n    }\n  }\n\n\n\n\n  export type ISession = {\n    secret?: string;\n    saveUninitialized?: boolean;\n    /**\n     * max age of session\n     */\n    cookieMaxAge?: number;\n    secure?: boolean;\n    resave?: boolean;\n  };\n\n\n\n  export type ConnectionOptionsLogs = {\n    http?: boolean;\n    realtime?: boolean;\n    framework?: boolean;\n    db?: boolean;\n    migrations?: boolean;\n  };\n  export interface ContextOptions<\n    CONTEXTS,\n    CONTROLLERS,\n    ENTITIES,\n    REPOSITORIES,\n    PROVIDERS,\n    SUBSCRIBERS,\n    MIGRATIONS,\n  > {\n    contextName: string;\n    /**\n     * host/port for initing backend server\n     */\n    host?: string;\n    /**\n     * frontend host only needed when we are\n     * using withCredentials for axios\n     * and session cookie\n     * or realtime communication\n     */\n    frontendHost?: string;\n    /**\n     * backend way of communication\n     * between taon backends/processes\n     */\n    remoteHost?: string;\n    useIpcWhenElectron?: boolean;\n    contexts?: CONTEXTS;\n    controllers?: CONTROLLERS;\n    entities?: ENTITIES;\n    repositories?: REPOSITORIES;\n    providers?: PROVIDERS;\n    subscribers?: SUBSCRIBERS;\n    migrations?: MIGRATIONS;\n    session?: ISession;\n    productionMode?: boolean;\n    abstract?: boolean;\n    logs?: boolean | ConnectionOptionsLogs;\n    database?: boolean | Partial<DatabaseConfig>;\n    disabledRealtime?: boolean;\n    https?: {\n      key: string;\n      cert: string;\n    };\n    publicAssets?: { serverPath: string; locationOnDisk: string }[];\n    middlewares?: MiddlewareType[];\n  }\n\n\n\n  export class DecoratorAbstractOpt {\n    className: string;\n  }\n\n\n\n  export class ParamConfig {\n    paramName: string;\n    paramType: CoreModels.ParamType;\n    index: number;\n    defaultType: any;\n    expireInSeconds?: number;\n  }\n\n\n\n  export class MethodConfig {\n    methodName: string;\n    /**\n     * path is global in express app\n     */\n    global?: boolean;\n    /**\n     * override default content type\n     */\n    contentType?: any;\n    /**\n     * override default axiso response type\n     */\n    responseType?: any;\n    path: string;\n    descriptor: PropertyDescriptor;\n    type: CoreModels.HttpMethod;\n\n    requestHandler: any;\n\n    parameters: { [paramName: string]: ParamConfig } = {};\n  }\n\n\n\n  export class ControllerConfig extends DecoratorAbstractOpt {\n    realtime?: boolean;\n    path: string;\n    uniqueKey?: string;\n    methods: { [methodName: string]: MethodConfig } = {};\n  }\n\n\n\n  export class RuntimeControllerConfig extends ControllerConfig {\n    calculatedPath?: string;\n    browserTransformFn?: (entity: any) => any;\n  }\n\n\n\n  export namespace Http {\n    export import Rest = ModelsNg2Rest;\n\n    export type ContextENDPOINT = { target: Function; initFN: Function };\n\n    export type FormlyFromType = 'material' | 'bootstrap';\n\n    export type ExpressContext<T> = (\n      req: ExpressRequest,\n      res: ExpressResponse,\n    ) => T;\n\n    export type SyncResponse<T> = string | T;\n\n    export type ResponseFuncOpt<T> = {\n      limitSize?: (\n        enties: Function | Function[],\n        include: string[],\n        exclude: string[],\n      ) => void;\n    };\n\n    export type SyncResponseFunc<T> = (\n      options?: ResponseFuncOpt<T>,\n    ) => SyncResponse<T>;\n    export type MixResponse<T> = SyncResponse<T> | ExpressContext<T>;\n\n    export interface ClientAction<T> {\n      received?: Rest.PromiseObservableMix<Rest.HttpResponse<T>>;\n    }\n\n    export interface AsyncResponse<T> {\n      (\n        req?: ExpressRequest,\n        res?: ExpressResponse,\n      ): Promise<SyncResponse<T> | SyncResponseFunc<T>>;\n    }\n\n    export type Response<T = string> = AsyncResponse<T> & ClientAction<T>;\n\n    export class Errors {\n      public toString = (): string => {\n        return this.message;\n      };\n\n      private constructor(\n        public message: string,\n        private code: ModelsNg2Rest.HttpCode = 400,\n      ) {}\n\n      private static create(\n        message: string,\n        code: ModelsNg2Rest.HttpCode = 400,\n      ) {\n        return new Errors(message, code);\n      }\n\n      public static entityNotFound(entity?: Function) {\n        return Errors.create(\n          `Entity ${ClassHelpers.getName(entity)} not found`,\n        );\n      }\n\n      public static custom(\n        message: string,\n        code: ModelsNg2Rest.HttpCode = 400,\n      ) {\n        return Errors.create(message, code);\n      }\n    }\n\n\n    export interface AuthCallBack {\n      (methodReference: Function): RequestHandler;\n    }\n\n\n  }\n\n\n\n  export interface StartParams {\n    port: number;\n    args: string[];\n    onlyMigrationRun?: boolean;\n    onlyMigrationRevertToTimestamp?: number;\n  }\n\n\n}\n\n ;({}); // @--end-of-file-for-module=taon lib/models.ts"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../../tmp-libs-for-dist-websql/taon/projects/taon/src/lib/models.ts"],"names":[],"mappings":"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","sourcesContent":["\n\nimport { CoreModels } from 'tnp-core/websql';\nimport { Response, RequestHandler } from 'express';\nimport {   Response as ExpressResponse,   Request as ExpressRequest, } from 'express';/* */\n/* */\n/* */\n\nimport { _ } from 'tnp-core/websql';\nimport { Models as ModelsNg2Rest } from 'ng2-rest/websql';\nimport { ClassHelpers } from './helpers/class-helpers';\nimport type { TaonControllerOptions } from './decorators/classes/controller-decorator';\nimport type { TaonEntityOptions } from './decorators/classes/entity-decorator';\n\nexport namespace Models {\n  export type FrameworkMode =\n    | 'backend-frontend(tcp+udp)'\n    | 'remote-backend(tcp+udp)'\n    | 'backend-frontend(ipc-electron)'\n    | 'backend-frontend(websql-electron)'\n    | 'backend-frontend(websql)';\n\n\n  export enum ClassType {\n    ENTITY = 'ENTITY',\n    CONTROLLER = 'CONTROLLER',\n    REPOSITORY = 'REPOSITORY',\n    PROVIDER = 'PROVIDER',\n    SUBSCRIBER = 'SUBSCRIBER',\n    MIGRATION = 'MIGRATION',\n  }\n\n  export const ClassTypeKey = {\n    [ClassType.ENTITY]: 'entities',\n    [ClassType.CONTROLLER]: 'controllers',\n    [ClassType.REPOSITORY]: 'repositories',\n    [ClassType.PROVIDER]: 'providers',\n    [ClassType.SUBSCRIBER]: 'subscribers',\n    [ClassType.MIGRATION]: 'migrations',\n  } as {\n    [key in ClassType]: keyof ContextOptions<any, any, any, any, any, any, any>;\n  };\n\n\n\n\n  export type MiddlewareType = [Function, any[]];\n\n\n\n  /**\n   * DROP_DB+MIGRATIONS (default for development)\n   * Drop all tables + recreate them + run migrations\n   * synchronize: true , dropSchema: true\n   * use migrations: true\n   *\n   * MIGRATIONS (default for production)\n   * Do not drop tables, only run migrations\n   * synchronize: false, dropSchema: false\n   * use migrations: true\n   */\n  export type DBRecreateMode =\n    | 'DROP_DB+MIGRATIONS'\n    | 'PRESERVE_DATA+MIGRATIONS';\n\n\n\n  export class DatabaseConfigTypeOrm {\n    /**\n     * database name\n     */\n    database?: string;\n    /**\n     * only for file base db: sqlite, sqljs\n     */\n    location?: string;\n    synchronize: boolean;\n    dropSchema: boolean;\n    type?: CoreModels.DatabaseType;\n    /**\n     * Persists db on disk/local-storage if serverless db\n     */\n    autoSave?: boolean;\n    /**\n     * for websql db mode\n     * true by default\n     */\n    useLocalForage?: boolean;\n    logging: boolean;\n    databasePort?: number;\n    databaseHost?: string;\n    databaseUsername?: string;\n    databasePassword?: string;\n  }\n\n\n\n  export class DatabaseConfig extends DatabaseConfigTypeOrm {\n    /**\n     * Default value 'DROP_ALL'.\n     *\n     * Tell framework what is happening with db\n     * when context is starting.\n     */\n    public recreateMode?: DBRecreateMode;\n\n    static from(\n      databasePartialConfig: Partial<\n        Omit<\n          DatabaseConfig,\n          'synchronize' | 'dropSchema' | 'databaseConfigTypeORM'\n        >\n      >,\n    ): DatabaseConfig {\n      return _.merge(new DatabaseConfig(), databasePartialConfig);\n    }\n\n    get databaseConfigTypeORM(): DatabaseConfigTypeOrm {\n\n      const result = _.cloneDeep(this) as DatabaseConfig;\n      if (result.recreateMode) {\n        if (result.recreateMode === 'DROP_DB+MIGRATIONS') {\n          result.synchronize = true;\n          result.dropSchema = true;\n        } else if (result.recreateMode === 'PRESERVE_DATA+MIGRATIONS') {\n          result.synchronize = false;\n          result.dropSchema = false;\n        }\n      }\n      delete result.recreateMode;\n\n      return result as any;\n\n    }\n  }\n\n\n\n\n  export type ISession = {\n    secret?: string;\n    saveUninitialized?: boolean;\n    /**\n     * max age of session\n     */\n    cookieMaxAge?: number;\n    secure?: boolean;\n    resave?: boolean;\n  };\n\n\n\n  export type ConnectionOptionsLogs = {\n    http?: boolean;\n    realtime?: boolean;\n    framework?: boolean;\n    db?: boolean;\n    migrations?: boolean;\n  };\n  export interface ContextOptions<\n    CONTEXTS,\n    CONTROLLERS,\n    ENTITIES,\n    REPOSITORIES,\n    PROVIDERS,\n    SUBSCRIBERS,\n    MIGRATIONS,\n  > {\n    contextName: string;\n    /**\n     * host/port for initing backend server\n     */\n    host?: string;\n    /**\n     * frontend host only needed when we are\n     * using withCredentials for axios\n     * and session cookie\n     * or realtime communication\n     */\n    frontendHost?: string;\n    /**\n     * backend way of communication\n     * between taon backends/processes\n     */\n    remoteHost?: string;\n    useIpcWhenElectron?: boolean;\n    contexts?: CONTEXTS;\n    controllers?: CONTROLLERS;\n    entities?: ENTITIES;\n    repositories?: REPOSITORIES;\n    providers?: PROVIDERS;\n    subscribers?: SUBSCRIBERS;\n    migrations?: MIGRATIONS;\n    session?: ISession;\n    skipWritingServerRoutes?: boolean;\n    productionMode?: boolean;\n    abstract?: boolean;\n    logs?: boolean | ConnectionOptionsLogs;\n    database?: boolean | Partial<DatabaseConfig>;\n    disabledRealtime?: boolean;\n    https?: {\n      key: string;\n      cert: string;\n    };\n    publicAssets?: { serverPath: string; locationOnDisk: string }[];\n    middlewares?: MiddlewareType[];\n  }\n\n\n\n  export class DecoratorAbstractOpt {\n    className: string;\n  }\n\n\n\n  export class ParamConfig {\n    paramName: string;\n    paramType: CoreModels.ParamType;\n    index: number;\n    defaultType: any;\n    expireInSeconds?: number;\n  }\n\n\n\n  export class MethodConfig {\n    methodName: string;\n    /**\n     * path is global in express app\n     */\n    global?: boolean;\n    /**\n     * override default content type\n     */\n    contentType?: any;\n    /**\n     * override default axiso response type\n     */\n    responseType?: any;\n    path: string;\n    descriptor: PropertyDescriptor;\n    type: CoreModels.HttpMethod;\n\n    requestHandler: any;\n\n    parameters: { [paramName: string]: ParamConfig } = {};\n  }\n\n\n\n  export class ControllerConfig extends DecoratorAbstractOpt {\n    realtime?: boolean;\n    path: string;\n    uniqueKey?: string;\n    methods: { [methodName: string]: MethodConfig } = {};\n  }\n\n\n\n  export class RuntimeControllerConfig extends ControllerConfig {\n    calculatedPath?: string;\n    browserTransformFn?: (entity: any) => any;\n  }\n\n\n\n  export namespace Http {\n    export import Rest = ModelsNg2Rest;\n\n    export type ContextENDPOINT = { target: Function; initFN: Function };\n\n    export type FormlyFromType = 'material' | 'bootstrap';\n\n    export type ExpressContext<T> = (\n      req: ExpressRequest,\n      res: ExpressResponse,\n    ) => T;\n\n    export type SyncResponse<T> = string | T;\n\n    export type ResponseFuncOpt<T> = {\n      limitSize?: (\n        enties: Function | Function[],\n        include: string[],\n        exclude: string[],\n      ) => void;\n    };\n\n    export type SyncResponseFunc<T> = (\n      options?: ResponseFuncOpt<T>,\n    ) => SyncResponse<T>;\n    export type MixResponse<T> = SyncResponse<T> | ExpressContext<T>;\n\n    export interface ClientAction<T> {\n      received?: Rest.PromiseObservableMix<Rest.HttpResponse<T>>;\n    }\n\n    export interface AsyncResponse<T> {\n      (\n        req?: ExpressRequest,\n        res?: ExpressResponse,\n      ): Promise<SyncResponse<T> | SyncResponseFunc<T>>;\n    }\n\n    export type Response<T = string> = AsyncResponse<T> & ClientAction<T>;\n\n    export class Errors {\n      public toString = (): string => {\n        return this.message;\n      };\n\n      private constructor(\n        public message: string,\n        private code: ModelsNg2Rest.HttpCode = 400,\n      ) {}\n\n      private static create(\n        message: string,\n        code: ModelsNg2Rest.HttpCode = 400,\n      ) {\n        return new Errors(message, code);\n      }\n\n      public static entityNotFound(entity?: Function) {\n        return Errors.create(\n          `Entity ${ClassHelpers.getName(entity)} not found`,\n        );\n      }\n\n      public static custom(\n        message: string,\n        code: ModelsNg2Rest.HttpCode = 400,\n      ) {\n        return Errors.create(message, code);\n      }\n    }\n\n\n    export interface AuthCallBack {\n      (methodReference: Function): RequestHandler;\n    }\n\n\n  }\n\n\n\n  export interface StartParams {\n    port: number;\n    args: string[];\n    onlyMigrationRun?: boolean;\n    onlyMigrationRevertToTimestamp?: number;\n  }\n\n\n}\n\n ;({}); // @--end-of-file-for-module=taon lib/models.ts"]}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import * as tsorm from 'taon-typeorm/websql';
|
|
2
|
+
import { _ } from 'tnp-core/websql';
|
|
2
3
|
export var Orm;
|
|
3
4
|
(function (Orm) {
|
|
4
5
|
Orm.Repository = tsorm.Repository;
|
|
@@ -34,7 +35,11 @@ export var Orm;
|
|
|
34
35
|
/**
|
|
35
36
|
* 100 characters varchar
|
|
36
37
|
*/
|
|
37
|
-
Column.String = () => tsorm.Column({ type: 'varchar', length: 100, nullable:
|
|
38
|
+
Column.String = (defaultValue = null) => tsorm.Column({ type: 'varchar', length: 100, nullable: _.isNil(defaultValue), default: defaultValue });
|
|
39
|
+
/**
|
|
40
|
+
* 500 characters varchar
|
|
41
|
+
*/
|
|
42
|
+
Column.String500 = (defaultValue = null) => tsorm.Column({ type: 'varchar', length: 500, nullable: _.isNil(defaultValue), default: defaultValue });
|
|
38
43
|
Column.Number = () => tsorm.Column({ type: 'int', nullable: true });
|
|
39
44
|
Column.DecimalNumber = () => tsorm.Column({ type: 'float', nullable: true });
|
|
40
45
|
Column.SimpleJson = () => tsorm.Column({ type: 'simple-json', nullable: true });
|
|
@@ -57,4 +62,4 @@ export var Orm;
|
|
|
57
62
|
})(Orm || (Orm = {}));
|
|
58
63
|
;
|
|
59
64
|
({}); // @--end-of-file-for-module=taon lib/orm.ts
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWRpc3Qtd2Vic3FsL3Rhb24vcHJvamVjdHMvdGFvbi9zcmMvbGliL29ybS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEtBQUssS0FBSyxNQUFNLHFCQUFxQixDQUFDO0FBRTdDLE9BQU8sRUFBRSxDQUFDLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUdwQyxNQUFNLEtBQVcsR0FBRyxDQXlFbkI7QUF6RUQsV0FBaUIsR0FBRztJQUVMLGNBQVUsR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDO0lBQzdCLGNBQVUsR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDO0lBQzVDLElBQWlCLFdBQVcsQ0FZM0I7SUFaRCxXQUFpQixXQUFXO1FBQ1osdUJBQVcsR0FBRyxLQUFLLENBQUMsV0FBVyxDQUFDO1FBQ2hDLHFCQUFTLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQztRQUM1Qix3QkFBWSxHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUM7UUFDbEMsdUJBQVcsR0FBRyxLQUFLLENBQUMsV0FBVyxDQUFDO1FBQ2hDLDJCQUFlLEdBQUcsS0FBSyxDQUFDLGVBQWUsQ0FBQztRQUN4Qyx1QkFBVyxHQUFHLEtBQUssQ0FBQyxXQUFXLENBQUM7UUFDaEMsd0JBQVksR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDO1FBQ2xDLHlCQUFhLEdBQUcsS0FBSyxDQUFDLGFBQWEsQ0FBQztRQUNwQyx3QkFBWSxHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUM7UUFDbEMsNEJBQWdCLEdBQUcsS0FBSyxDQUFDLGdCQUFnQixDQUFDO1FBQzFDLHdCQUFZLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQztJQUNsRCxDQUFDLEVBWmdCLFdBQVcsR0FBWCxlQUFXLEtBQVgsZUFBVyxRQVkzQjtJQUVELElBQWlCLElBQUksQ0FHcEI7SUFIRCxXQUFpQixJQUFJO1FBQ0wsYUFBUSxHQUFHLEtB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LENBQUM7QUFBQSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsNENBQTRDIiwic291cmNlc0NvbnRlbnQiOlsiXG5cblxuaW1wb3J0ICogYXMgdHNvcm0gZnJvbSAndGFvbi10eXBlb3JtL3dlYnNxbCc7XG5cbmltcG9ydCB7IF8gfSBmcm9tICd0bnAtY29yZS93ZWJzcWwnO1xuXG5cbmV4cG9ydCBuYW1lc3BhY2UgT3JtIHtcblxuICBleHBvcnQgY29uc3QgUmVwb3NpdG9yeSA9IHRzb3JtLlJlcG9zaXRvcnk7XG4gIGV4cG9ydCBpbXBvcnQgQ29ubmVjdGlvbiA9IHRzb3JtLkNvbm5lY3Rpb247XG4gIGV4cG9ydCBuYW1lc3BhY2UgTGlzdGVuRXZlbnQge1xuICAgIGV4cG9ydCBpbXBvcnQgQWZ0ZXJJbnNlcnQgPSB0c29ybS5BZnRlckluc2VydDtcbiAgICBleHBvcnQgaW1wb3J0IEFmdGVyTG9hZCA9IHRzb3JtLkFmdGVyTG9hZDtcbiAgICBleHBvcnQgaW1wb3J0IEFmdGVyUmVjb3ZlciA9IHRzb3JtLkFmdGVyUmVjb3ZlcjtcbiAgICBleHBvcnQgaW1wb3J0IEFmdGVyUmVtb3ZlID0gdHNvcm0uQWZ0ZXJSZW1vdmU7XG4gICAgZXhwb3J0IGltcG9ydCBBZnRlclNvZnRSZW1vdmUgPSB0c29ybS5BZnRlclNvZnRSZW1vdmU7XG4gICAgZXhwb3J0IGltcG9ydCBBZnRlclVwZGF0ZSA9IHRzb3JtLkFmdGVyVXBkYXRlO1xuICAgIGV4cG9ydCBpbXBvcnQgQmVmb3JlSW5zZXJ0ID0gdHNvcm0uQmVmb3JlSW5zZXJ0O1xuICAgIGV4cG9ydCBpbXBvcnQgQmVmb3JlUmVjb3ZlciA9IHRzb3JtLkJlZm9yZVJlY292ZXI7XG4gICAgZXhwb3J0IGltcG9ydCBCZWZvcmVSZW1vdmUgPSB0c29ybS5CZWZvcmVSZW1vdmU7XG4gICAgZXhwb3J0IGltcG9ydCBCZWZvcmVTb2Z0UmVtb3ZlID0gdHNvcm0uQmVmb3JlU29mdFJlbW92ZTtcbiAgICBleHBvcnQgaW1wb3J0IEJlZm9yZVVwZGF0ZSA9IHRzb3JtLkJlZm9yZVVwZGF0ZTtcbiAgfVxuXG4gIGV4cG9ydCBuYW1lc3BhY2UgVHJlZSB7XG4gICAgZXhwb3J0IGltcG9ydCBDaGlsZHJlbiA9IHRzb3JtLlRyZWVDaGlsZHJlbjtcbiAgICBleHBvcnQgaW1wb3J0IFBhcmVudCA9IHRzb3JtLlRyZWVQYXJlbnQ7XG4gIH1cbiAgZXhwb3J0IG5hbWVzcGFjZSBDb2x1bW4ge1xuICAgIGV4cG9ydCBpbXBvcnQgR2VuZXJhdGVkID0gdHNvcm0uUHJpbWFyeUdlbmVyYXRlZENvbHVtbjtcbiAgICBleHBvcnQgaW1wb3J0IFByaW1hcnkgPSB0c29ybS5QcmltYXJ5Q29sdW1uO1xuICAgIGV4cG9ydCBpbXBvcnQgSW5kZXggPSB0c29ybS5JbmRleDtcbiAgICBleHBvcnQgaW1wb3J0IENyZWF0ZURhdGUgPSB0c29ybS5DcmVhdGVEYXRlQ29sdW1uO1xuICAgIGV4cG9ydCBpbXBvcnQgVXBkYXRlRGF0ZSA9IHRzb3JtLlVwZGF0ZURhdGVDb2x1bW47XG4gICAgZXhwb3J0IGltcG9ydCBEZWxldGVEYXRlID0gdHNvcm0uRGVsZXRlRGF0ZUNvbHVtbjtcbiAgICBleHBvcnQgaW1wb3J0IEN1c3RvbSA9IHRzb3JtLkNvbHVtbjtcblxuICAgIC8qKlxuICAgICAqIDEwMCBjaGFyYWN0ZXJzIHZhcmNoYXJcbiAgICAgKi9cbiAgICBleHBvcnQgY29uc3QgU3RyaW5nID0gPFQgPSBzdHJpbmc+KGRlZmF1bHRWYWx1ZTpUID0gbnVsbCkgPT5cbiAgICAgIHRzb3JtLkNvbHVtbih7IHR5cGU6ICd2YXJjaGFyJywgbGVuZ3RoOiAxMDAsIG51bGxhYmxlOiBfLmlzTmlsKGRlZmF1bHRWYWx1ZSkgICAsIGRlZmF1bHQ6IGRlZmF1bHRWYWx1ZSB9KTtcblxuICAgIC8qKlxuICAgICAqIDUwMCBjaGFyYWN0ZXJzIHZhcmNoYXJcbiAgICAgKi9cbiAgICBleHBvcnQgY29uc3QgU3RyaW5nNTAwID0gPFQgPSBzdHJpbmc+KGRlZmF1bHRWYWx1ZTpUID0gbnVsbCkgPT5cbiAgICAgIHRzb3JtLkNvbHVtbih7IHR5cGU6ICd2YXJjaGFyJywgbGVuZ3RoOiA1MDAsIG51bGxhYmxlOiBfLmlzTmlsKGRlZmF1bHRWYWx1ZSkgICAsIGRlZmF1bHQ6IGRlZmF1bHRWYWx1ZSB9KTtcblxuICAgIGV4cG9ydCBjb25zdCBOdW1iZXIgPSAoKSA9PlxuICAgICAgdHNvcm0uQ29sdW1uKHsgdHlwZTogJ2ludCcsICBudWxsYWJsZTogdHJ1ZSB9KTtcblxuICAgIGV4cG9ydCBjb25zdCBEZWNpbWFsTnVtYmVyID0gKCkgPT5cbiAgICAgIHRzb3JtLkNvbHVtbih7IHR5cGU6ICdmbG9hdCcsICBudWxsYWJsZTogdHJ1ZSB9KTtcblxuXG4gICAgZXhwb3J0IGNvbnN0IFNpbXBsZUpzb24gPSAoKSA9PlxuICAgICAgdHNvcm0uQ29sdW1uKHsgdHlwZTogJ3NpbXBsZS1qc29uJywgbnVsbGFibGU6IHRydWUgfSk7XG5cbiAgICBleHBvcnQgY29uc3QgQm9vbGVhbiA9IChkZWZhdWx0VmFsdWU6IGJvb2xlYW4pID0+XG4gICAgICB0c29ybS5Db2x1bW4oeyB0eXBlOiAnYm9vbGVhbicsIGRlZmF1bHQ6IGRlZmF1bHRWYWx1ZSB9KTtcblxuXG5cbiAgICBleHBvcnQgaW1wb3J0IFZlcnNpb24gPSB0c29ybS5WZXJzaW9uQ29sdW1uO1xuICAgIGV4cG9ydCBpbXBvcnQgVmlydHVhbCA9IHRzb3JtLlZpcnR1YWxDb2x1bW47XG4gIH1cblxuICBleHBvcnQgbmFtZXNwYWNlIEpvaW4ge1xuICAgIGV4cG9ydCBpbXBvcnQgVGFibGUgPSB0c29ybS5Kb2luVGFibGU7XG4gICAgZXhwb3J0IGltcG9ydCBDb2x1bW4gPSB0c29ybS5Kb2luQ29sdW1uO1xuICB9XG4gIGV4cG9ydCBuYW1lc3BhY2UgUmVsYXRpb24ge1xuICAgIGV4cG9ydCBpbXBvcnQgT25lVG9NYW55ID0gdHNvcm0uT25lVG9NYW55O1xuICAgIGV4cG9ydCBpbXBvcnQgT25lVG9PbmUgPSB0c29ybS5PbmVUb09uZTtcbiAgICBleHBvcnQgaW1wb3J0IE1hbnlUb01hbnkgPSB0c29ybS5NYW55VG9NYW55O1xuICAgIGV4cG9ydCBpbXBvcnQgTWFueVRvT25lID0gdHNvcm0uTWFueVRvT25lO1xuICB9XG5cbn1cblxuXG5cbiA7KHt9KTsgLy8gQC0tZW5kLW9mLWZpbGUtZm9yLW1vZHVsZT10YW9uIGxpYi9vcm0udHMiXX0=
|
|
@@ -30,20 +30,19 @@ import { TaonNotificationsModule } from '../taon-notifications';
|
|
|
30
30
|
import { TaonSessionPasscodeComponent } from '../taon-session-passcode';
|
|
31
31
|
import * as i0 from "@angular/core";
|
|
32
32
|
import * as i1 from "static-columns/websql";
|
|
33
|
-
import * as i2 from "
|
|
34
|
-
import * as i3 from "@angular/
|
|
35
|
-
import * as i4 from "
|
|
36
|
-
import * as i5 from "
|
|
37
|
-
import * as i6 from "@angular/
|
|
38
|
-
import * as i7 from "@angular/material/
|
|
39
|
-
import * as i8 from "@angular/material/
|
|
40
|
-
import * as i9 from "@angular/material/
|
|
41
|
-
import * as i10 from "@angular/material/
|
|
42
|
-
import * as i11 from "@angular/material/
|
|
43
|
-
import * as i12 from "@angular/material/tabs";
|
|
33
|
+
import * as i2 from "@angular/common";
|
|
34
|
+
import * as i3 from "@angular/forms";
|
|
35
|
+
import * as i4 from "ngx-scrollbar";
|
|
36
|
+
import * as i5 from "@angular/cdk/drag-drop";
|
|
37
|
+
import * as i6 from "@angular/material/button";
|
|
38
|
+
import * as i7 from "@angular/material/card";
|
|
39
|
+
import * as i8 from "@angular/material/checkbox";
|
|
40
|
+
import * as i9 from "@angular/material/icon";
|
|
41
|
+
import * as i10 from "@angular/material/sidenav";
|
|
42
|
+
import * as i11 from "@angular/material/tabs";
|
|
44
43
|
export class TaonAdminModeConfigurationComponent {
|
|
45
44
|
get opened() {
|
|
46
|
-
return !this.isIframe && this.
|
|
45
|
+
return !this.isIframe && this.taonAdminService.adminPanelIsOpen;
|
|
47
46
|
}
|
|
48
47
|
set opened(v) {
|
|
49
48
|
if (v && !this.openedOnce) {
|
|
@@ -51,16 +50,15 @@ export class TaonAdminModeConfigurationComponent {
|
|
|
51
50
|
}
|
|
52
51
|
if (this.wasOpenDraggablePopup) {
|
|
53
52
|
this.wasOpenDraggablePopup = false;
|
|
54
|
-
this.
|
|
53
|
+
this.taonAdminService.draggablePopupMode = true;
|
|
55
54
|
}
|
|
56
|
-
this.
|
|
55
|
+
this.taonAdminService.adminPanelIsOpen = v;
|
|
57
56
|
}
|
|
58
|
-
constructor(breakpointsService
|
|
57
|
+
constructor(breakpointsService) {
|
|
59
58
|
this.breakpointsService = breakpointsService;
|
|
60
|
-
this.admin = admin;
|
|
61
59
|
this.$destroy = new Subject();
|
|
62
60
|
this.cdr = inject(ChangeDetectorRef);
|
|
63
|
-
this.taonAdminService =
|
|
61
|
+
this.taonAdminService = TaonAdminService.Instance;
|
|
64
62
|
this.isWebSQLMode = Helpers.isWebSQL;
|
|
65
63
|
this.hideTaonToolsInProduction = ENV.hideTaonToolsInProduction && ENV.angularProd;
|
|
66
64
|
this.isIframe = window.location !== window.parent.location;
|
|
@@ -97,7 +95,7 @@ export class TaonAdminModeConfigurationComponent {
|
|
|
97
95
|
//Add 'implements AfterViewInit' to the class.
|
|
98
96
|
setTimeout(() => {
|
|
99
97
|
this.height = window.innerHeight;
|
|
100
|
-
if (this.
|
|
98
|
+
if (this.taonAdminService.draggablePopupMode) {
|
|
101
99
|
this.reloadTabs();
|
|
102
100
|
}
|
|
103
101
|
});
|
|
@@ -123,9 +121,9 @@ export class TaonAdminModeConfigurationComponent {
|
|
|
123
121
|
this.opened = !this.opened;
|
|
124
122
|
}
|
|
125
123
|
async toogleFullScreen() {
|
|
126
|
-
this.
|
|
127
|
-
this.
|
|
128
|
-
!this.
|
|
124
|
+
this.taonAdminService.draggablePopupMode = true;
|
|
125
|
+
this.taonAdminService.draggablePopupModeFullScreen =
|
|
126
|
+
!this.taonAdminService.draggablePopupModeFullScreen;
|
|
129
127
|
this.resetDrag();
|
|
130
128
|
}
|
|
131
129
|
resetDrag() {
|
|
@@ -140,8 +138,8 @@ export class TaonAdminModeConfigurationComponent {
|
|
|
140
138
|
scrollTabs(event) {
|
|
141
139
|
return;
|
|
142
140
|
}
|
|
143
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: TaonAdminModeConfigurationComponent, deps: [{ token: i1.BreakpointsService }
|
|
144
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: TaonAdminModeConfigurationComponent, isStandalone: true, selector: "taon-admin-mode-configuration", inputs: { taonAdminModeConfigurationData: "taonAdminModeConfigurationData" }, outputs: { taonAdminModeConfigurationDataChanged: "taonAdminModeConfigurationDataChanged" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "tabGroup", first: true, predicate: ["tabGroup"], descendants: true }], ngImport: i0, template: "<!-- #region basic global components -->\n<taon-session-passcode\n *ngIf=\"showPasscode\"\n [passcode]=\"passcode\"\n [message]=\"message\" />\n<!-- <taon-progress-bar [isDesktop]=\"isDesktop\"></taon-progress-bar> -->\n<!-- <taon-notifications></taon-notifications> -->\n<button\n mat-fab\n class=\"fab-button\"\n color=\"accent\"\n aria-label=\"Taon Admin Mode\"\n *ngIf=\"\n !admin.draggablePopupMode &&\n isDesktop &&\n !isIframe &&\n !hideTaonToolsInProduction\n \"\n (click)=\"toogle()\">\n <mat-icon>build</mat-icon>\n</button>\n<!-- #endregion -->\n\n<!-- #region small hidden button -->\n<!-- <button class=\"admin-show-button\"\n *ngIf=\"!admin.draggablePopupMode && isDesktop\"\n (click)=\"toogle()\"> Admin </button> -->\n<!-- #endregion -->\n\n<ng-template #contentNoScroll>\n <ng-content> </ng-content>\n</ng-template>\n\n<ng-template #content>\n <ng-scrollbar>\n <ng-container [ngTemplateOutlet]=\"contentNoScroll\"></ng-container>\n </ng-scrollbar>\n</ng-template>\n\n<!-- #region admin tabs -->\n<ng-template #adminTabs>\n <!-- #region admin tabs / header -->\n <div class=\"taon-header-admin-wrapper\">\n <columns-container\n class=\"taon-header-admin\"\n [ngClass]=\"{ 'draggable-column': admin.draggablePopupMode }\">\n <column\n width=\"200\"\n class=\"logo-header\">\n <img\n *ngIf=\"openedOnce\"\n src=\"assets/assets-for/taon/shared/logo-header-admin-mode.png\" />\n </column>\n\n <column grow>\n <!-- <span>Super Admin Mode</span> -->\n </column>\n\n <column\n width=\"40\"\n *ngIf=\"\n !admin.draggablePopupModeFullScreen && !admin.draggablePopupMode\n \">\n <button\n mat-icon-button\n *ngIf=\"admin.draggablePopupMode\"\n (click)=\"\n admin.draggablePopupMode = false;\n opened = false;\n wasOpenDraggablePopup = true\n \"\n class=\"admin-close-button\">\n <mat-icon>close </mat-icon>\n </button>\n\n <button\n mat-icon-button\n *ngIf=\"!admin.draggablePopupMode\"\n (click)=\"toogle()\"\n class=\"admin-close-button\">\n <mat-icon>close</mat-icon>\n </button>\n </column>\n\n <column width=\"40\">\n <button\n mat-icon-button\n *ngIf=\"!admin.draggablePopupModeFullScreen\"\n class=\"admin-close-button\"\n (click)=\"toogleFullScreen()\">\n <mat-icon>fullscreen</mat-icon>\n </button>\n <button\n mat-icon-button\n *ngIf=\"admin.draggablePopupModeFullScreen\"\n class=\"admin-close-button\"\n (click)=\"toogleFullScreen()\">\n <mat-icon>close_fullscreen</mat-icon>\n </button>\n </column>\n\n <column\n width=\"40\"\n *ngIf=\"!admin.draggablePopupModeFullScreen\">\n <button\n mat-icon-button\n *ngIf=\"!admin.draggablePopupMode\"\n (click)=\"admin.draggablePopupMode = true\"\n class=\"admin-close-button\">\n <mat-icon>launch</mat-icon>\n </button>\n\n <button\n mat-icon-button\n *ngIf=\"admin.draggablePopupMode\"\n (click)=\"admin.draggablePopupMode = false; resetDrag()\"\n class=\"admin-close-button\">\n <mat-icon style=\"transform: rotate(180deg)\">login</mat-icon>\n </button>\n </column>\n </columns-container>\n </div>\n <!-- #endregion -->\n\n <columns-container\n [ngClass]=\"{ 'draggable-column': admin.draggablePopupMode }\">\n <column grow>\n <mat-tab-group\n dynamicHeight\n (wheel)=\"scrollTabs($event)\"\n #tabGroup\n [selectedIndex]=\"selectedIndex\"\n (selectedIndexChange)=\"selectedIndex = $event\">\n <mat-tab label=\"DB/Cache\">\n <section>\n <mat-card>\n <mat-card-header>\n <mat-card-subtitle>WEBSQL MODE</mat-card-subtitle>\n </mat-card-header>\n <mat-card-content>\n <mat-checkbox\n [disabled]=\"!isWebSQLMode\"\n [ngModel]=\"admin.keepWebsqlDbDataAfterReload\"\n (change)=\"\n admin.setKeepWebsqlDbDataAfterReload($event.checked)\n \">\n Don't remove data when reloading\n </mat-checkbox>\n </mat-card-content>\n </mat-card>\n </section>\n <br />\n <taon-db-admin />\n </mat-tab>\n </mat-tab-group>\n </column>\n </columns-container>\n</ng-template>\n<!-- #endregion -->\n\n<!-- #region small/mobile draggable popup windows -->\n<div\n class=\"draggable-popup-mode-window\"\n *ngIf=\"\n admin.draggablePopupMode && !admin.draggablePopupModeFullScreen && !isIframe\n \"\n cdkDrag\n [cdkDragFreeDragPosition]=\"dragPosition\"\n (cdkDragEnded)=\"moved($event)\">\n <ng-scrollbar>\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n </ng-scrollbar>\n</div>\n<!-- #endregion -->\n\n<!-- #region fullscreen draggable popup window -->\n<div\n class=\"draggable-popup-mode-window-full\"\n *ngIf=\"\n admin.draggablePopupMode &&\n admin.draggablePopupModeFullScreen &&\n !isIframe &&\n !reloading\n \"\n cdkDrag\n [cdkDragFreeDragPosition]=\"dragPositionZero\">\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region content when not in draggable (or fullscreen draggable) popup -->\n<div\n [style.height.px]=\"height\"\n *ngIf=\"\n (isIframe ||\n !isDesktop ||\n admin.draggablePopupMode ||\n admin.draggablePopupModeFullScreen) &&\n !reloading\n \"\n style=\"width: 100%; display: block\"\n class=\"content\">\n <ng-container\n [ngTemplateOutlet]=\"\n admin.scrollableEnabled ? content : contentNoScroll\n \"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region draggable popup window -->\n<mat-drawer-container\n *ngIf=\"!admin.draggablePopupMode && isDesktop && !isIframe\"\n class=\"example-container\"\n [style.height.px]=\"height\"\n style=\"background-color: transparent\"\n (backdropClick)=\"opened = false\"\n [hasBackdrop]=\"false\">\n <mat-drawer\n #drawer\n style=\"width: 580px\"\n [opened]=\"opened\"\n [mode]=\"'side'\">\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n </mat-drawer>\n <mat-drawer-content style=\"overflow: hidden\">\n <ng-container\n *ngIf=\"!admin.draggablePopupMode && !reloading\"\n [ngTemplateOutlet]=\"\n admin.scrollableEnabled ? content : contentNoScroll\n \"></ng-container>\n </mat-drawer-content>\n</mat-drawer-container>\n<!-- #endregion -->\n", styles: ["section{display:block;padding:10px}section>*{margin-top:0!important;margin-bottom:10px!important}section>*:last-child{margin-bottom:0!important}:host{display:block}.draggable-column{display:block!important;width:100%!important}.admin-show-button{position:fixed;bottom:100px;left:-15px;z-index:2147483647;transform:rotate(90deg);border:0px;color:#fff;background:gray;opacity:.1;cursor:pointer}.admin-show-button:hover{opacity:1}.taon-ui-super-admin-mode{font-family:JosefinSans-Bold;text-align:right;margin-right:10px}mat-drawer{margin:0;background-color:#dcdcdc!important}.taon-header-admin-wrapper{overflow:hidden;width:100%;display:block}.taon-header-admin{background:#fff;box-shadow:0 -9px 6px 6px #000;height:47px}.taon-header-admin .logo-header img{height:18px;padding:8px;position:relative;float:left;top:7px;box-sizing:content-box;transform:scale(1.5);left:49px}.draggable-popup-mode-window{width:600px;height:500px;border:solid 1px #ccc;color:#000000de;cursor:move;justify-content:center;align-items:center;background:#fff;border-radius:4px;position:fixed;z-index:105;background-color:#dcdcdc!important;transition:box-shadow .2s cubic-bezier(0,0,.2,1);box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.draggable-popup-mode-window:active{box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.draggable-popup-mode-window-full{width:100%;height:100%;overflow:scroll;color:#000000de;justify-content:center;align-items:center;background:#fff;border-radius:4px;position:fixed;z-index:105;background-color:#dcdcdc!important}.admin-close-button{float:right}.fab-button{position:fixed;right:110px;bottom:100px;z-index:10;background-color:#dcdcdc;color:#8f8f8f}.full-tabs{padding:10px}.mat-drawer-container-full-screen{background-color:red}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: StaticColumnsModule }, { kind: "component", type: i1.ColumnsComponent, selector: "columns-container" }, { kind: "component", type: i1.ColumnComponent, selector: "column", inputs: ["width"] }, { kind: "directive", type: i1.DirectiveGrow, selector: "[grow]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: NgScrollbarModule }, { kind: "component", type: i5.NgScrollbar, selector: "ng-scrollbar:not([externalViewport])", exportAs: ["ngScrollbar"] }, { kind: "ngmodule", type: TaonProgressBarModule }, { kind: "ngmodule", type: TaonNotificationsModule }, { kind: "ngmodule", type: TaonFullMaterialModule }, { kind: "directive", type: i6.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i7.MatFabButton, selector: "button[mat-fab]", inputs: ["extended"], exportAs: ["matButton"] }, { kind: "component", type: i8.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i8.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i8.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i8.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { kind: "component", type: i9.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i11.MatDrawer, selector: "mat-drawer", inputs: ["position", "mode", "disableClose", "autoFocus", "opened"], outputs: ["openedChange", "opened", "openedStart", "closed", "closedStart", "positionChanged"], exportAs: ["matDrawer"] }, { kind: "component", type: i11.MatDrawerContainer, selector: "mat-drawer-container", inputs: ["autosize", "hasBackdrop"], outputs: ["backdropClick"], exportAs: ["matDrawerContainer"] }, { kind: "component", type: i11.MatDrawerContent, selector: "mat-drawer-content" }, { kind: "component", type: i12.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i12.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor", "aria-label", "aria-labelledby"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "component", type: // TODO import only partial things
|
|
141
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: TaonAdminModeConfigurationComponent, deps: [{ token: i1.BreakpointsService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
142
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: TaonAdminModeConfigurationComponent, isStandalone: true, selector: "taon-admin-mode-configuration", inputs: { taonAdminModeConfigurationData: "taonAdminModeConfigurationData" }, outputs: { taonAdminModeConfigurationDataChanged: "taonAdminModeConfigurationDataChanged" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "tabGroup", first: true, predicate: ["tabGroup"], descendants: true }], ngImport: i0, template: "<!-- #region basic global components -->\n<taon-session-passcode\n *ngIf=\"showPasscode\"\n [passcode]=\"passcode\"\n [message]=\"message\" />\n<!-- <taon-progress-bar [isDesktop]=\"isDesktop\"></taon-progress-bar> -->\n<!-- <taon-notifications></taon-notifications> -->\n<button\n mat-fab\n class=\"fab-button\"\n color=\"accent\"\n aria-label=\"Taon Admin Mode\"\n *ngIf=\"\n !taonAdminService.draggablePopupMode &&\n isDesktop &&\n !isIframe &&\n !hideTaonToolsInProduction\n \"\n (click)=\"toogle()\">\n <mat-icon>build</mat-icon>\n</button>\n<!-- #endregion -->\n\n<!-- #region small hidden button -->\n<!-- <button class=\"admin-show-button\"\n *ngIf=\"!taonAdminService.draggablePopupMode && isDesktop\"\n (click)=\"toogle()\"> Admin </button> -->\n<!-- #endregion -->\n\n<ng-template #contentNoScroll>\n <ng-content> </ng-content>\n</ng-template>\n\n<ng-template #content>\n <ng-scrollbar>\n <ng-container [ngTemplateOutlet]=\"contentNoScroll\"></ng-container>\n </ng-scrollbar>\n</ng-template>\n\n<!-- #region admin tabs -->\n<ng-template #adminTabs>\n <!-- #region admin tabs / header -->\n <div class=\"taon-header-admin-wrapper\">\n <columns-container\n class=\"taon-header-admin\"\n [ngClass]=\"{ 'draggable-column': taonAdminService.draggablePopupMode }\">\n <column\n width=\"200\"\n class=\"logo-header\">\n <img\n *ngIf=\"openedOnce\"\n src=\"assets/assets-for/taon/shared/logo-header-admin-mode.png\" />\n </column>\n\n <column grow>\n <!-- <span>Super Admin Mode</span> -->\n </column>\n\n <column\n width=\"40\"\n *ngIf=\"\n !taonAdminService.draggablePopupModeFullScreen &&\n !taonAdminService.draggablePopupMode\n \">\n <button\n mat-icon-button\n *ngIf=\"taonAdminService.draggablePopupMode\"\n (click)=\"\n taonAdminService.draggablePopupMode = false;\n opened = false;\n wasOpenDraggablePopup = true\n \"\n class=\"admin-close-button\">\n <mat-icon>close </mat-icon>\n </button>\n\n <button\n mat-icon-button\n *ngIf=\"!taonAdminService.draggablePopupMode\"\n (click)=\"toogle()\"\n class=\"admin-close-button\">\n <mat-icon>close</mat-icon>\n </button>\n </column>\n\n <column width=\"40\">\n <button\n mat-icon-button\n *ngIf=\"!taonAdminService.draggablePopupModeFullScreen\"\n class=\"admin-close-button\"\n (click)=\"toogleFullScreen()\">\n <mat-icon>fullscreen</mat-icon>\n </button>\n <button\n mat-icon-button\n *ngIf=\"taonAdminService.draggablePopupModeFullScreen\"\n class=\"admin-close-button\"\n (click)=\"toogleFullScreen()\">\n <mat-icon>close_fullscreen</mat-icon>\n </button>\n </column>\n\n <column\n width=\"40\"\n *ngIf=\"!taonAdminService.draggablePopupModeFullScreen\">\n <button\n mat-icon-button\n *ngIf=\"!taonAdminService.draggablePopupMode\"\n (click)=\"taonAdminService.draggablePopupMode = true\"\n class=\"admin-close-button\">\n <mat-icon>launch</mat-icon>\n </button>\n\n <button\n mat-icon-button\n *ngIf=\"taonAdminService.draggablePopupMode\"\n (click)=\"taonAdminService.draggablePopupMode = false; resetDrag()\"\n class=\"admin-close-button\">\n <mat-icon style=\"transform: rotate(180deg)\">login</mat-icon>\n </button>\n </column>\n </columns-container>\n </div>\n <!-- #endregion -->\n\n <columns-container\n [ngClass]=\"{ 'draggable-column': taonAdminService.draggablePopupMode }\">\n <column grow>\n <mat-tab-group\n dynamicHeight\n (wheel)=\"scrollTabs($event)\"\n #tabGroup\n [selectedIndex]=\"selectedIndex\"\n (selectedIndexChange)=\"selectedIndex = $event\">\n <mat-tab label=\"DB/Cache\">\n <section>\n <mat-card>\n <mat-card-header>\n <mat-card-subtitle>WEBSQL MODE</mat-card-subtitle>\n </mat-card-header>\n <mat-card-content>\n <mat-checkbox\n [disabled]=\"!isWebSQLMode\"\n [ngModel]=\"taonAdminService.keepWebsqlDbDataAfterReload\"\n (change)=\"\n taonAdminService.setKeepWebsqlDbDataAfterReload(\n $event.checked\n )\n \">\n Don't remove data when reloading\n </mat-checkbox>\n </mat-card-content>\n </mat-card>\n </section>\n <br />\n <taon-db-admin />\n </mat-tab>\n </mat-tab-group>\n </column>\n </columns-container>\n</ng-template>\n<!-- #endregion -->\n\n<!-- #region small/mobile draggable popup windows -->\n<div\n class=\"draggable-popup-mode-window\"\n *ngIf=\"\n taonAdminService.draggablePopupMode &&\n !taonAdminService.draggablePopupModeFullScreen &&\n !isIframe\n \"\n cdkDrag\n [cdkDragFreeDragPosition]=\"dragPosition\"\n (cdkDragEnded)=\"moved($event)\">\n <ng-scrollbar>\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n </ng-scrollbar>\n</div>\n<!-- #endregion -->\n\n<!-- #region fullscreen draggable popup window -->\n<div\n class=\"draggable-popup-mode-window-full\"\n *ngIf=\"\n taonAdminService.draggablePopupMode &&\n taonAdminService.draggablePopupModeFullScreen &&\n !isIframe &&\n !reloading\n \"\n cdkDrag\n [cdkDragFreeDragPosition]=\"dragPositionZero\">\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region content when not in draggable (or fullscreen draggable) popup -->\n<div\n [style.height.px]=\"height\"\n *ngIf=\"\n (isIframe ||\n !isDesktop ||\n taonAdminService.draggablePopupMode ||\n taonAdminService.draggablePopupModeFullScreen) &&\n !reloading\n \"\n style=\"width: 100%; display: block\"\n class=\"content\">\n <ng-container\n [ngTemplateOutlet]=\"\n taonAdminService.scrollableEnabled ? content : contentNoScroll\n \"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region draggable popup window -->\n<mat-drawer-container\n *ngIf=\"!taonAdminService.draggablePopupMode && isDesktop && !isIframe\"\n class=\"example-container\"\n [style.height.px]=\"height\"\n style=\"background-color: transparent\"\n (backdropClick)=\"opened = false\"\n [hasBackdrop]=\"false\">\n <mat-drawer\n #drawer\n style=\"width: 580px\"\n [opened]=\"opened\"\n [mode]=\"'side'\">\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n </mat-drawer>\n <mat-drawer-content style=\"overflow: hidden\">\n <ng-container\n *ngIf=\"!taonAdminService.draggablePopupMode && !reloading\"\n [ngTemplateOutlet]=\"\n taonAdminService.scrollableEnabled ? content : contentNoScroll\n \"></ng-container>\n </mat-drawer-content>\n</mat-drawer-container>\n<!-- #endregion -->\n", styles: ["section{display:block;padding:10px}section>*{margin-top:0!important;margin-bottom:10px!important}section>*:last-child{margin-bottom:0!important}:host{display:block}.draggable-column{display:block!important;width:100%!important}.admin-show-button{position:fixed;bottom:100px;left:-15px;z-index:2147483647;transform:rotate(90deg);border:0px;color:#fff;background:gray;opacity:.1;cursor:pointer}.admin-show-button:hover{opacity:1}.taon-ui-super-admin-mode{font-family:JosefinSans-Bold;text-align:right;margin-right:10px}mat-drawer{margin:0;background-color:#dcdcdc!important}.taon-header-admin-wrapper{overflow:hidden;width:100%;display:block}.taon-header-admin{background:#fff;box-shadow:0 -9px 6px 6px #000;height:47px}.taon-header-admin .logo-header img{height:18px;padding:8px;position:relative;float:left;top:7px;box-sizing:content-box;transform:scale(1.5);left:49px}.draggable-popup-mode-window{width:600px;height:500px;border:solid 1px #ccc;color:#000000de;cursor:move;justify-content:center;align-items:center;background:#fff;border-radius:4px;position:fixed;z-index:105;background-color:#dcdcdc!important;transition:box-shadow .2s cubic-bezier(0,0,.2,1);box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.draggable-popup-mode-window:active{box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.draggable-popup-mode-window-full{width:100%;height:100%;overflow:scroll;color:#000000de;justify-content:center;align-items:center;background:#fff;border-radius:4px;position:fixed;z-index:105;background-color:#dcdcdc!important}.admin-close-button{float:right}.fab-button{position:fixed;right:110px;bottom:100px;z-index:10;background-color:#dcdcdc;color:#8f8f8f}.full-tabs{padding:10px}.mat-drawer-container-full-screen{background-color:red}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: StaticColumnsModule }, { kind: "component", type: i1.ColumnsComponent, selector: "columns-container" }, { kind: "component", type: i1.ColumnComponent, selector: "column", inputs: ["width"] }, { kind: "directive", type: i1.DirectiveGrow, selector: "[grow]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: NgScrollbarModule }, { kind: "component", type: i4.NgScrollbar, selector: "ng-scrollbar:not([externalViewport])", exportAs: ["ngScrollbar"] }, { kind: "ngmodule", type: TaonProgressBarModule }, { kind: "ngmodule", type: TaonNotificationsModule }, { kind: "ngmodule", type: TaonFullMaterialModule }, { kind: "directive", type: i5.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i6.MatFabButton, selector: "button[mat-fab]", inputs: ["extended"], exportAs: ["matButton"] }, { kind: "component", type: i7.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i7.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i7.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i7.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { kind: "component", type: i8.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i10.MatDrawer, selector: "mat-drawer", inputs: ["position", "mode", "disableClose", "autoFocus", "opened"], outputs: ["openedChange", "opened", "openedStart", "closed", "closedStart", "positionChanged"], exportAs: ["matDrawer"] }, { kind: "component", type: i10.MatDrawerContainer, selector: "mat-drawer-container", inputs: ["autosize", "hasBackdrop"], outputs: ["backdropClick"], exportAs: ["matDrawerContainer"] }, { kind: "component", type: i10.MatDrawerContent, selector: "mat-drawer-content" }, { kind: "component", type: i11.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i11.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor", "aria-label", "aria-labelledby"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "component", type: // TODO import only partial things
|
|
145
143
|
TaonSessionPasscodeComponent, selector: "taon-session-passcode", inputs: ["passcode", "message"] }] }); }
|
|
146
144
|
}
|
|
147
145
|
__decorate([
|
|
@@ -179,8 +177,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
179
177
|
TaonNotificationsModule,
|
|
180
178
|
TaonFullMaterialModule, // TODO import only partial things
|
|
181
179
|
TaonSessionPasscodeComponent,
|
|
182
|
-
], template: "<!-- #region basic global components -->\n<taon-session-passcode\n *ngIf=\"showPasscode\"\n [passcode]=\"passcode\"\n [message]=\"message\" />\n<!-- <taon-progress-bar [isDesktop]=\"isDesktop\"></taon-progress-bar> -->\n<!-- <taon-notifications></taon-notifications> -->\n<button\n mat-fab\n class=\"fab-button\"\n color=\"accent\"\n aria-label=\"Taon Admin Mode\"\n *ngIf=\"\n !
|
|
183
|
-
}], ctorParameters: () => [{ type: i1.BreakpointsService }
|
|
180
|
+
], template: "<!-- #region basic global components -->\n<taon-session-passcode\n *ngIf=\"showPasscode\"\n [passcode]=\"passcode\"\n [message]=\"message\" />\n<!-- <taon-progress-bar [isDesktop]=\"isDesktop\"></taon-progress-bar> -->\n<!-- <taon-notifications></taon-notifications> -->\n<button\n mat-fab\n class=\"fab-button\"\n color=\"accent\"\n aria-label=\"Taon Admin Mode\"\n *ngIf=\"\n !taonAdminService.draggablePopupMode &&\n isDesktop &&\n !isIframe &&\n !hideTaonToolsInProduction\n \"\n (click)=\"toogle()\">\n <mat-icon>build</mat-icon>\n</button>\n<!-- #endregion -->\n\n<!-- #region small hidden button -->\n<!-- <button class=\"admin-show-button\"\n *ngIf=\"!taonAdminService.draggablePopupMode && isDesktop\"\n (click)=\"toogle()\"> Admin </button> -->\n<!-- #endregion -->\n\n<ng-template #contentNoScroll>\n <ng-content> </ng-content>\n</ng-template>\n\n<ng-template #content>\n <ng-scrollbar>\n <ng-container [ngTemplateOutlet]=\"contentNoScroll\"></ng-container>\n </ng-scrollbar>\n</ng-template>\n\n<!-- #region admin tabs -->\n<ng-template #adminTabs>\n <!-- #region admin tabs / header -->\n <div class=\"taon-header-admin-wrapper\">\n <columns-container\n class=\"taon-header-admin\"\n [ngClass]=\"{ 'draggable-column': taonAdminService.draggablePopupMode }\">\n <column\n width=\"200\"\n class=\"logo-header\">\n <img\n *ngIf=\"openedOnce\"\n src=\"assets/assets-for/taon/shared/logo-header-admin-mode.png\" />\n </column>\n\n <column grow>\n <!-- <span>Super Admin Mode</span> -->\n </column>\n\n <column\n width=\"40\"\n *ngIf=\"\n !taonAdminService.draggablePopupModeFullScreen &&\n !taonAdminService.draggablePopupMode\n \">\n <button\n mat-icon-button\n *ngIf=\"taonAdminService.draggablePopupMode\"\n (click)=\"\n taonAdminService.draggablePopupMode = false;\n opened = false;\n wasOpenDraggablePopup = true\n \"\n class=\"admin-close-button\">\n <mat-icon>close </mat-icon>\n </button>\n\n <button\n mat-icon-button\n *ngIf=\"!taonAdminService.draggablePopupMode\"\n (click)=\"toogle()\"\n class=\"admin-close-button\">\n <mat-icon>close</mat-icon>\n </button>\n </column>\n\n <column width=\"40\">\n <button\n mat-icon-button\n *ngIf=\"!taonAdminService.draggablePopupModeFullScreen\"\n class=\"admin-close-button\"\n (click)=\"toogleFullScreen()\">\n <mat-icon>fullscreen</mat-icon>\n </button>\n <button\n mat-icon-button\n *ngIf=\"taonAdminService.draggablePopupModeFullScreen\"\n class=\"admin-close-button\"\n (click)=\"toogleFullScreen()\">\n <mat-icon>close_fullscreen</mat-icon>\n </button>\n </column>\n\n <column\n width=\"40\"\n *ngIf=\"!taonAdminService.draggablePopupModeFullScreen\">\n <button\n mat-icon-button\n *ngIf=\"!taonAdminService.draggablePopupMode\"\n (click)=\"taonAdminService.draggablePopupMode = true\"\n class=\"admin-close-button\">\n <mat-icon>launch</mat-icon>\n </button>\n\n <button\n mat-icon-button\n *ngIf=\"taonAdminService.draggablePopupMode\"\n (click)=\"taonAdminService.draggablePopupMode = false; resetDrag()\"\n class=\"admin-close-button\">\n <mat-icon style=\"transform: rotate(180deg)\">login</mat-icon>\n </button>\n </column>\n </columns-container>\n </div>\n <!-- #endregion -->\n\n <columns-container\n [ngClass]=\"{ 'draggable-column': taonAdminService.draggablePopupMode }\">\n <column grow>\n <mat-tab-group\n dynamicHeight\n (wheel)=\"scrollTabs($event)\"\n #tabGroup\n [selectedIndex]=\"selectedIndex\"\n (selectedIndexChange)=\"selectedIndex = $event\">\n <mat-tab label=\"DB/Cache\">\n <section>\n <mat-card>\n <mat-card-header>\n <mat-card-subtitle>WEBSQL MODE</mat-card-subtitle>\n </mat-card-header>\n <mat-card-content>\n <mat-checkbox\n [disabled]=\"!isWebSQLMode\"\n [ngModel]=\"taonAdminService.keepWebsqlDbDataAfterReload\"\n (change)=\"\n taonAdminService.setKeepWebsqlDbDataAfterReload(\n $event.checked\n )\n \">\n Don't remove data when reloading\n </mat-checkbox>\n </mat-card-content>\n </mat-card>\n </section>\n <br />\n <taon-db-admin />\n </mat-tab>\n </mat-tab-group>\n </column>\n </columns-container>\n</ng-template>\n<!-- #endregion -->\n\n<!-- #region small/mobile draggable popup windows -->\n<div\n class=\"draggable-popup-mode-window\"\n *ngIf=\"\n taonAdminService.draggablePopupMode &&\n !taonAdminService.draggablePopupModeFullScreen &&\n !isIframe\n \"\n cdkDrag\n [cdkDragFreeDragPosition]=\"dragPosition\"\n (cdkDragEnded)=\"moved($event)\">\n <ng-scrollbar>\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n </ng-scrollbar>\n</div>\n<!-- #endregion -->\n\n<!-- #region fullscreen draggable popup window -->\n<div\n class=\"draggable-popup-mode-window-full\"\n *ngIf=\"\n taonAdminService.draggablePopupMode &&\n taonAdminService.draggablePopupModeFullScreen &&\n !isIframe &&\n !reloading\n \"\n cdkDrag\n [cdkDragFreeDragPosition]=\"dragPositionZero\">\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region content when not in draggable (or fullscreen draggable) popup -->\n<div\n [style.height.px]=\"height\"\n *ngIf=\"\n (isIframe ||\n !isDesktop ||\n taonAdminService.draggablePopupMode ||\n taonAdminService.draggablePopupModeFullScreen) &&\n !reloading\n \"\n style=\"width: 100%; display: block\"\n class=\"content\">\n <ng-container\n [ngTemplateOutlet]=\"\n taonAdminService.scrollableEnabled ? content : contentNoScroll\n \"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region draggable popup window -->\n<mat-drawer-container\n *ngIf=\"!taonAdminService.draggablePopupMode && isDesktop && !isIframe\"\n class=\"example-container\"\n [style.height.px]=\"height\"\n style=\"background-color: transparent\"\n (backdropClick)=\"opened = false\"\n [hasBackdrop]=\"false\">\n <mat-drawer\n #drawer\n style=\"width: 580px\"\n [opened]=\"opened\"\n [mode]=\"'side'\">\n <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n </mat-drawer>\n <mat-drawer-content style=\"overflow: hidden\">\n <ng-container\n *ngIf=\"!taonAdminService.draggablePopupMode && !reloading\"\n [ngTemplateOutlet]=\"\n taonAdminService.scrollableEnabled ? content : contentNoScroll\n \"></ng-container>\n </mat-drawer-content>\n</mat-drawer-container>\n<!-- #endregion -->\n", styles: ["section{display:block;padding:10px}section>*{margin-top:0!important;margin-bottom:10px!important}section>*:last-child{margin-bottom:0!important}:host{display:block}.draggable-column{display:block!important;width:100%!important}.admin-show-button{position:fixed;bottom:100px;left:-15px;z-index:2147483647;transform:rotate(90deg);border:0px;color:#fff;background:gray;opacity:.1;cursor:pointer}.admin-show-button:hover{opacity:1}.taon-ui-super-admin-mode{font-family:JosefinSans-Bold;text-align:right;margin-right:10px}mat-drawer{margin:0;background-color:#dcdcdc!important}.taon-header-admin-wrapper{overflow:hidden;width:100%;display:block}.taon-header-admin{background:#fff;box-shadow:0 -9px 6px 6px #000;height:47px}.taon-header-admin .logo-header img{height:18px;padding:8px;position:relative;float:left;top:7px;box-sizing:content-box;transform:scale(1.5);left:49px}.draggable-popup-mode-window{width:600px;height:500px;border:solid 1px #ccc;color:#000000de;cursor:move;justify-content:center;align-items:center;background:#fff;border-radius:4px;position:fixed;z-index:105;background-color:#dcdcdc!important;transition:box-shadow .2s cubic-bezier(0,0,.2,1);box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.draggable-popup-mode-window:active{box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.draggable-popup-mode-window-full{width:100%;height:100%;overflow:scroll;color:#000000de;justify-content:center;align-items:center;background:#fff;border-radius:4px;position:fixed;z-index:105;background-color:#dcdcdc!important}.admin-close-button{float:right}.fab-button{position:fixed;right:110px;bottom:100px;z-index:10;background-color:#dcdcdc;color:#8f8f8f}.full-tabs{padding:10px}.mat-drawer-container-full-screen{background-color:red}\n"] }]
|
|
181
|
+
}], ctorParameters: () => [{ type: i1.BreakpointsService }], propDecorators: { tabGroup: [{
|
|
184
182
|
type: ViewChild,
|
|
185
183
|
args: ['tabGroup']
|
|
186
184
|
}], taonAdminModeConfigurationDataChanged: [{
|
|
@@ -193,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
193
191
|
}] } });
|
|
194
192
|
;
|
|
195
193
|
({}); // @--end-of-file-for-module=taon lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.ts
|
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"taon-admin-mode-configuration.component.js","sourceRoot":"","sources":["../../../../../../tmp-libs-for-dist-websql/taon/projects/taon/src/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.ts","../../../../../../tmp-libs-for-dist-websql/taon/projects/taon/src/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport {   ChangeDetectorRef,   Component,   EventEmitter,   HostListener,   Injector,   Input,   OnInit,   Output,   ViewChild,   inject, } from '@angular/core';/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n\nimport { Helpers, _ } from 'tnp-core/websql';\nimport { TaonAdminService } from './taon-admin.service';\nimport { Stor } from 'taon-storage/websql';\nimport {   CdkDrag,   CdkDragEnd,   CdkDragMove,   CdkDragRelease,   Point, } from '@angular/cdk/drag-drop';/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n\nimport { BreakpointsService } from 'static-columns/websql';\nimport { Subject, takeUntil, tap } from 'rxjs';\n\nimport { CommonModule } from '@angular/common';\nimport { TaonFullMaterialModule } from '../taon-full-material.module';\nimport { StaticColumnsModule } from 'static-columns/websql';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { NgScrollbarModule } from 'ngx-scrollbar';\nimport { TaonProgressBarModule } from '../taon-progress-bar';\nimport { TaonNotificationsModule } from '../taon-notifications';\nimport { TaonSessionPasscodeComponent } from '../taon-session-passcode';\n\n\n\ndeclare const ENV: any;\n@Component({\n\n  selector: 'taon-admin-mode-configuration',\n  templateUrl: './taon-admin-mode-configuration.component.html',\n  styleUrls: ['./taon-admin-mode-configuration.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    StaticColumnsModule,\n    FormsModule,\n    NgScrollbarModule,\n    TaonProgressBarModule,\n    TaonNotificationsModule,\n    TaonFullMaterialModule, // TODO import only partial things\n\n    TaonSessionPasscodeComponent,\n  ],\n\n})\nexport class TaonAdminModeConfigurationComponent implements OnInit {\n\n  $destroy = new Subject();\n  public readonly cdr = inject(ChangeDetectorRef);\n  public readonly taonAdminService = inject(TaonAdminService);\n  public readonly isDesktop: boolean;\n  public isWebSQLMode: boolean = Helpers.isWebSQL;\n  public hideTaonToolsInProduction: boolean =\n    ENV.hideTaonToolsInProduction && ENV.angularProd;\n  public isIframe: boolean = window.location !== window.parent.location;\n  public height: number = 100;\n  public openedOnce = false;\n  public reloading: boolean = false;\n  public showPasscode: boolean =\n    _.isString(ENV.passcode) || _.isObject(ENV.passcode);\n  public passcode: string = _.isString(ENV.passcode)\n    ? ENV.passcode\n    : _.isObject(ENV.passcode)\n      ? ENV.passcode.code\n      : '';\n  public message: string = _.isObject(ENV.passcode)\n    ? ENV.passcode.message\n    : void 0;\n\n  // @ts-ignore\n  @(Stor.property.in.localstorage\n    .for(TaonAdminModeConfigurationComponent)\n    .withDefaultValue(0))\n  dragPositionX: number;\n\n  // @ts-ignore\n  @(Stor.property.in.localstorage\n    .for(TaonAdminModeConfigurationComponent)\n    .withDefaultValue(0))\n  dragPositionY: number;\n\n  dragPositionZero = { x: 0, y: 0 } as Point;\n  dragPosition: Point;\n\n  // @ts-ignore\n  @(Stor.property.in.localstorage\n    .for(TaonAdminModeConfigurationComponent)\n    .withDefaultValue(0))\n  selectedIndex: number;\n\n  @ViewChild('tabGroup') tabGroup;\n\n  // @ts-ignore\n  @(Stor.property.in.localstorage\n    .for(TaonAdminModeConfigurationComponent)\n    .withDefaultValue(false))\n  wasOpenDraggablePopup: boolean;\n\n  @Output() taonAdminModeConfigurationDataChanged = new EventEmitter();\n  @Input() taonAdminModeConfigurationData: any = {};\n  public get opened() {\n    return !this.isIframe && this.admin.adminPanelIsOpen;\n  }\n  public set opened(v) {\n    if (v && !this.openedOnce) {\n      this.openedOnce = true;\n    }\n    if (this.wasOpenDraggablePopup) {\n      this.wasOpenDraggablePopup = false;\n      this.admin.draggablePopupMode = true;\n    }\n    this.admin.adminPanelIsOpen = v;\n  }\n\n\n\n  constructor(\n    private breakpointsService: BreakpointsService,\n    public admin: TaonAdminService,\n  ) {\n    this.breakpointsService\n      .listenTo()\n      .pipe(takeUntil(this.$destroy))\n      .subscribe(breakpoint => {\n        // @ts-ignore\n        this.isDesktop = breakpoint === 'desktop';\n      });\n  }\n\n\n\n  async ngOnInit() {\n    await Stor.awaitPendingOperatios();\n\n\n\n    this.dragPosition = { x: this.dragPositionX, y: this.dragPositionY };\n    this.openedOnce = this.opened;\n\n\n\n\n\n  }\n\n  ngAfterViewInit(): void {\n    //Called after ngAfterContentInit when the component's view has been initialized. Applies to components only.\n    //Add 'implements AfterViewInit' to the class.\n    setTimeout(() => {\n      this.height = window.innerHeight;\n\n\n      if (this.admin.draggablePopupMode) {\n        this.reloadTabs();\n      }\n\n\n\n\n\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.$destroy.next(void 0);\n    this.$destroy.complete();\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onResize(event: Event) {\n    this.height = window.innerHeight;\n  }\n\n\n\n\n  async reloadTabs(): Promise<void> {\n    return new Promise<void>(resolve => {\n      this.reloading = true;\n      setTimeout(() => {\n        this.reloading = false;\n        console.log('reloading done');\n        resolve();\n      });\n    });\n  }\n\n  async toogle() {\n\n    this.opened = !this.opened;\n  }\n\n  async toogleFullScreen() {\n    this.admin.draggablePopupMode = true;\n    this.admin.draggablePopupModeFullScreen =\n      !this.admin.draggablePopupModeFullScreen;\n    this.resetDrag();\n  }\n\n  resetDrag() {\n    this.dragPositionX = 0;\n    this.dragPositionY = 0;\n    this.dragPosition = { x: this.dragPositionX, y: this.dragPositionY };\n  }\n\n  moved(c: CdkDragEnd) {\n    this.dragPositionX += c.distance.x;\n    this.dragPositionY += c.distance.y;\n  }\n\n  scrollTabs(event) {\n    return;\n\n\n\n\n\n\n\n\n\n\n  }\n\n\n}\n\n ;({}); // @--end-of-file-for-module=taon lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.ts","<!-- #region basic global components  -->\n<taon-session-passcode\n  *ngIf=\"showPasscode\"\n  [passcode]=\"passcode\"\n  [message]=\"message\" />\n<!-- <taon-progress-bar [isDesktop]=\"isDesktop\"></taon-progress-bar> -->\n<!-- <taon-notifications></taon-notifications> -->\n<button\n  mat-fab\n  class=\"fab-button\"\n  color=\"accent\"\n  aria-label=\"Taon Admin Mode\"\n  *ngIf=\"\n    !admin.draggablePopupMode &&\n    isDesktop &&\n    !isIframe &&\n    !hideTaonToolsInProduction\n  \"\n  (click)=\"toogle()\">\n  <mat-icon>build</mat-icon>\n</button>\n<!-- #endregion -->\n\n<!-- #region small hidden button -->\n<!-- <button class=\"admin-show-button\"\n        *ngIf=\"!admin.draggablePopupMode && isDesktop\"\n        (click)=\"toogle()\"> Admin </button> -->\n<!-- #endregion -->\n\n<ng-template #contentNoScroll>\n  <ng-content> </ng-content>\n</ng-template>\n\n<ng-template #content>\n  <ng-scrollbar>\n    <ng-container [ngTemplateOutlet]=\"contentNoScroll\"></ng-container>\n  </ng-scrollbar>\n</ng-template>\n\n<!-- #region admin tabs -->\n<ng-template #adminTabs>\n  <!-- #region admin tabs / header -->\n  <div class=\"taon-header-admin-wrapper\">\n    <columns-container\n      class=\"taon-header-admin\"\n      [ngClass]=\"{ 'draggable-column': admin.draggablePopupMode }\">\n      <column\n        width=\"200\"\n        class=\"logo-header\">\n        <img\n          *ngIf=\"openedOnce\"\n          src=\"/TTTTTTTTOOOOOOOO________RRRRRRRREEEEEEEEMMMMMMMMOOOOOOOOVVVVVVVVEEEEEEEEassets/assets-for/taon/shared/logo-header-admin-mode.png\" />\n      </column>\n\n      <column grow>\n        <!-- <span>Super Admin Mode</span> -->\n      </column>\n\n      <column\n        width=\"40\"\n        *ngIf=\"\n          !admin.draggablePopupModeFullScreen && !admin.draggablePopupMode\n        \">\n        <button\n          mat-icon-button\n          *ngIf=\"admin.draggablePopupMode\"\n          (click)=\"\n            admin.draggablePopupMode = false;\n            opened = false;\n            wasOpenDraggablePopup = true\n          \"\n          class=\"admin-close-button\">\n          <mat-icon>close </mat-icon>\n        </button>\n\n        <button\n          mat-icon-button\n          *ngIf=\"!admin.draggablePopupMode\"\n          (click)=\"toogle()\"\n          class=\"admin-close-button\">\n          <mat-icon>close</mat-icon>\n        </button>\n      </column>\n\n      <column width=\"40\">\n        <button\n          mat-icon-button\n          *ngIf=\"!admin.draggablePopupModeFullScreen\"\n          class=\"admin-close-button\"\n          (click)=\"toogleFullScreen()\">\n          <mat-icon>fullscreen</mat-icon>\n        </button>\n        <button\n          mat-icon-button\n          *ngIf=\"admin.draggablePopupModeFullScreen\"\n          class=\"admin-close-button\"\n          (click)=\"toogleFullScreen()\">\n          <mat-icon>close_fullscreen</mat-icon>\n        </button>\n      </column>\n\n      <column\n        width=\"40\"\n        *ngIf=\"!admin.draggablePopupModeFullScreen\">\n        <button\n          mat-icon-button\n          *ngIf=\"!admin.draggablePopupMode\"\n          (click)=\"admin.draggablePopupMode = true\"\n          class=\"admin-close-button\">\n          <mat-icon>launch</mat-icon>\n        </button>\n\n        <button\n          mat-icon-button\n          *ngIf=\"admin.draggablePopupMode\"\n          (click)=\"admin.draggablePopupMode = false; resetDrag()\"\n          class=\"admin-close-button\">\n          <mat-icon style=\"transform: rotate(180deg)\">login</mat-icon>\n        </button>\n      </column>\n    </columns-container>\n  </div>\n  <!-- #endregion -->\n\n  <columns-container\n    [ngClass]=\"{ 'draggable-column': admin.draggablePopupMode }\">\n    <column grow>\n      <mat-tab-group\n        dynamicHeight\n        (wheel)=\"scrollTabs($event)\"\n        #tabGroup\n        [selectedIndex]=\"selectedIndex\"\n        (selectedIndexChange)=\"selectedIndex = $event\">\n        <mat-tab label=\"DB/Cache\">\n          <section>\n            <mat-card>\n              <mat-card-header>\n                <mat-card-subtitle>WEBSQL MODE</mat-card-subtitle>\n              </mat-card-header>\n              <mat-card-content>\n                <mat-checkbox\n                  [disabled]=\"!isWebSQLMode\"\n                  [ngModel]=\"admin.keepWebsqlDbDataAfterReload\"\n                  (change)=\"\n                    admin.setKeepWebsqlDbDataAfterReload($event.checked)\n                  \">\n                  Don't remove data when reloading\n                </mat-checkbox>\n              </mat-card-content>\n            </mat-card>\n          </section>\n          <br />\n          <taon-db-admin />\n        </mat-tab>\n      </mat-tab-group>\n    </column>\n  </columns-container>\n</ng-template>\n<!-- #endregion -->\n\n<!-- #region small/mobile draggable popup windows -->\n<div\n  class=\"draggable-popup-mode-window\"\n  *ngIf=\"\n    admin.draggablePopupMode && !admin.draggablePopupModeFullScreen && !isIframe\n  \"\n  cdkDrag\n  [cdkDragFreeDragPosition]=\"dragPosition\"\n  (cdkDragEnded)=\"moved($event)\">\n  <ng-scrollbar>\n    <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n  </ng-scrollbar>\n</div>\n<!-- #endregion -->\n\n<!-- #region fullscreen draggable popup window -->\n<div\n  class=\"draggable-popup-mode-window-full\"\n  *ngIf=\"\n    admin.draggablePopupMode &&\n    admin.draggablePopupModeFullScreen &&\n    !isIframe &&\n    !reloading\n  \"\n  cdkDrag\n  [cdkDragFreeDragPosition]=\"dragPositionZero\">\n  <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region content when not in draggable (or fullscreen draggable) popup -->\n<div\n  [style.height.px]=\"height\"\n  *ngIf=\"\n    (isIframe ||\n      !isDesktop ||\n      admin.draggablePopupMode ||\n      admin.draggablePopupModeFullScreen) &&\n    !reloading\n  \"\n  style=\"width: 100%; display: block\"\n  class=\"content\">\n  <ng-container\n    [ngTemplateOutlet]=\"\n      admin.scrollableEnabled ? content : contentNoScroll\n    \"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region draggable popup window -->\n<mat-drawer-container\n  *ngIf=\"!admin.draggablePopupMode && isDesktop && !isIframe\"\n  class=\"example-container\"\n  [style.height.px]=\"height\"\n  style=\"background-color: transparent\"\n  (backdropClick)=\"opened = false\"\n  [hasBackdrop]=\"false\">\n  <mat-drawer\n    #drawer\n    style=\"width: 580px\"\n    [opened]=\"opened\"\n    [mode]=\"'side'\">\n    <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n  </mat-drawer>\n  <mat-drawer-content style=\"overflow: hidden\">\n    <ng-container\n      *ngIf=\"!admin.draggablePopupMode && !reloading\"\n      [ngTemplateOutlet]=\"\n        admin.scrollableEnabled ? content : contentNoScroll\n      \"></ng-container>\n  </mat-drawer-content>\n</mat-drawer-container>\n<!-- #endregion -->\n"]}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"taon-admin-mode-configuration.component.js","sourceRoot":"","sources":["../../../../../../tmp-libs-for-dist-websql/taon/projects/taon/src/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.ts","../../../../../../tmp-libs-for-dist-websql/taon/projects/taon/src/lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport {   ChangeDetectorRef,   Component,   EventEmitter,   HostListener,   Injector,   Input,   OnInit,   Output,   ViewChild,   inject, } from '@angular/core';/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n\nimport { Helpers, _ } from 'tnp-core/websql';\nimport { TaonAdminService } from './taon-admin.service';\nimport { Stor } from 'taon-storage/websql';\nimport {   CdkDrag,   CdkDragEnd,   CdkDragMove,   CdkDragRelease,   Point, } from '@angular/cdk/drag-drop';/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n\nimport { BreakpointsService } from 'static-columns/websql';\nimport { Subject, takeUntil, tap } from 'rxjs';\n\nimport { CommonModule } from '@angular/common';\nimport { TaonFullMaterialModule } from '../taon-full-material.module';\nimport { StaticColumnsModule } from 'static-columns/websql';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { NgScrollbarModule } from 'ngx-scrollbar';\nimport { TaonProgressBarModule } from '../taon-progress-bar';\nimport { TaonNotificationsModule } from '../taon-notifications';\nimport { TaonSessionPasscodeComponent } from '../taon-session-passcode';\n\n\n\ndeclare const ENV: any;\n@Component({\n\n  selector: 'taon-admin-mode-configuration',\n  templateUrl: './taon-admin-mode-configuration.component.html',\n  styleUrls: ['./taon-admin-mode-configuration.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    StaticColumnsModule,\n    FormsModule,\n    NgScrollbarModule,\n    TaonProgressBarModule,\n    TaonNotificationsModule,\n    TaonFullMaterialModule, // TODO import only partial things\n\n    TaonSessionPasscodeComponent,\n  ],\n\n})\nexport class TaonAdminModeConfigurationComponent implements OnInit {\n\n  $destroy = new Subject();\n  public readonly cdr = inject(ChangeDetectorRef);\n  public readonly taonAdminService: TaonAdminService =\n    TaonAdminService.Instance;\n  public readonly isDesktop: boolean;\n  public isWebSQLMode: boolean = Helpers.isWebSQL;\n  public hideTaonToolsInProduction: boolean =\n    ENV.hideTaonToolsInProduction && ENV.angularProd;\n  public isIframe: boolean = window.location !== window.parent.location;\n  public height: number = 100;\n  public openedOnce = false;\n  public reloading: boolean = false;\n  public showPasscode: boolean =\n    _.isString(ENV.passcode) || _.isObject(ENV.passcode);\n  public passcode: string = _.isString(ENV.passcode)\n    ? ENV.passcode\n    : _.isObject(ENV.passcode)\n      ? ENV.passcode.code\n      : '';\n  public message: string = _.isObject(ENV.passcode)\n    ? ENV.passcode.message\n    : void 0;\n\n  // @ts-ignore\n  @(Stor.property.in.localstorage\n    .for(TaonAdminModeConfigurationComponent)\n    .withDefaultValue(0))\n  dragPositionX: number;\n\n  // @ts-ignore\n  @(Stor.property.in.localstorage\n    .for(TaonAdminModeConfigurationComponent)\n    .withDefaultValue(0))\n  dragPositionY: number;\n\n  dragPositionZero = { x: 0, y: 0 } as Point;\n  dragPosition: Point;\n\n  // @ts-ignore\n  @(Stor.property.in.localstorage\n    .for(TaonAdminModeConfigurationComponent)\n    .withDefaultValue(0))\n  selectedIndex: number;\n\n  @ViewChild('tabGroup') tabGroup;\n\n  // @ts-ignore\n  @(Stor.property.in.localstorage\n    .for(TaonAdminModeConfigurationComponent)\n    .withDefaultValue(false))\n  wasOpenDraggablePopup: boolean;\n\n  @Output() taonAdminModeConfigurationDataChanged = new EventEmitter();\n  @Input() taonAdminModeConfigurationData: any = {};\n  public get opened() {\n    return !this.isIframe && this.taonAdminService.adminPanelIsOpen;\n  }\n  public set opened(v) {\n    if (v && !this.openedOnce) {\n      this.openedOnce = true;\n    }\n    if (this.wasOpenDraggablePopup) {\n      this.wasOpenDraggablePopup = false;\n      this.taonAdminService.draggablePopupMode = true;\n    }\n    this.taonAdminService.adminPanelIsOpen = v;\n  }\n\n\n\n  constructor(private breakpointsService: BreakpointsService) {\n    this.breakpointsService\n      .listenTo()\n      .pipe(takeUntil(this.$destroy))\n      .subscribe(breakpoint => {\n        // @ts-ignore\n        this.isDesktop = breakpoint === 'desktop';\n      });\n  }\n\n\n\n  async ngOnInit() {\n    await Stor.awaitPendingOperatios();\n\n\n\n    this.dragPosition = { x: this.dragPositionX, y: this.dragPositionY };\n    this.openedOnce = this.opened;\n\n\n\n\n\n  }\n\n  ngAfterViewInit(): void {\n    //Called after ngAfterContentInit when the component's view has been initialized. Applies to components only.\n    //Add 'implements AfterViewInit' to the class.\n    setTimeout(() => {\n      this.height = window.innerHeight;\n\n\n      if (this.taonAdminService.draggablePopupMode) {\n        this.reloadTabs();\n      }\n\n\n\n\n\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.$destroy.next(void 0);\n    this.$destroy.complete();\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onResize(event: Event) {\n    this.height = window.innerHeight;\n  }\n\n\n\n\n  async reloadTabs(): Promise<void> {\n    return new Promise<void>(resolve => {\n      this.reloading = true;\n      setTimeout(() => {\n        this.reloading = false;\n        console.log('reloading done');\n        resolve();\n      });\n    });\n  }\n\n  async toogle() {\n\n    this.opened = !this.opened;\n  }\n\n  async toogleFullScreen() {\n    this.taonAdminService.draggablePopupMode = true;\n    this.taonAdminService.draggablePopupModeFullScreen =\n      !this.taonAdminService.draggablePopupModeFullScreen;\n    this.resetDrag();\n  }\n\n  resetDrag() {\n    this.dragPositionX = 0;\n    this.dragPositionY = 0;\n    this.dragPosition = { x: this.dragPositionX, y: this.dragPositionY };\n  }\n\n  moved(c: CdkDragEnd) {\n    this.dragPositionX += c.distance.x;\n    this.dragPositionY += c.distance.y;\n  }\n\n  scrollTabs(event) {\n    return;\n\n\n\n\n\n\n\n\n\n\n  }\n\n\n}\n\n ;({}); // @--end-of-file-for-module=taon lib/ui/taon-admin-mode-configuration/taon-admin-mode-configuration.component.ts","<!-- #region basic global components  -->\n<taon-session-passcode\n  *ngIf=\"showPasscode\"\n  [passcode]=\"passcode\"\n  [message]=\"message\" />\n<!-- <taon-progress-bar [isDesktop]=\"isDesktop\"></taon-progress-bar> -->\n<!-- <taon-notifications></taon-notifications> -->\n<button\n  mat-fab\n  class=\"fab-button\"\n  color=\"accent\"\n  aria-label=\"Taon Admin Mode\"\n  *ngIf=\"\n    !taonAdminService.draggablePopupMode &&\n    isDesktop &&\n    !isIframe &&\n    !hideTaonToolsInProduction\n  \"\n  (click)=\"toogle()\">\n  <mat-icon>build</mat-icon>\n</button>\n<!-- #endregion -->\n\n<!-- #region small hidden button -->\n<!-- <button class=\"admin-show-button\"\n        *ngIf=\"!taonAdminService.draggablePopupMode && isDesktop\"\n        (click)=\"toogle()\"> Admin </button> -->\n<!-- #endregion -->\n\n<ng-template #contentNoScroll>\n  <ng-content> </ng-content>\n</ng-template>\n\n<ng-template #content>\n  <ng-scrollbar>\n    <ng-container [ngTemplateOutlet]=\"contentNoScroll\"></ng-container>\n  </ng-scrollbar>\n</ng-template>\n\n<!-- #region admin tabs -->\n<ng-template #adminTabs>\n  <!-- #region admin tabs / header -->\n  <div class=\"taon-header-admin-wrapper\">\n    <columns-container\n      class=\"taon-header-admin\"\n      [ngClass]=\"{ 'draggable-column': taonAdminService.draggablePopupMode }\">\n      <column\n        width=\"200\"\n        class=\"logo-header\">\n        <img\n          *ngIf=\"openedOnce\"\n          src=\"/TTTTTTTTOOOOOOOO________RRRRRRRREEEEEEEEMMMMMMMMOOOOOOOOVVVVVVVVEEEEEEEEassets/assets-for/taon/shared/logo-header-admin-mode.png\" />\n      </column>\n\n      <column grow>\n        <!-- <span>Super Admin Mode</span> -->\n      </column>\n\n      <column\n        width=\"40\"\n        *ngIf=\"\n          !taonAdminService.draggablePopupModeFullScreen &&\n          !taonAdminService.draggablePopupMode\n        \">\n        <button\n          mat-icon-button\n          *ngIf=\"taonAdminService.draggablePopupMode\"\n          (click)=\"\n            taonAdminService.draggablePopupMode = false;\n            opened = false;\n            wasOpenDraggablePopup = true\n          \"\n          class=\"admin-close-button\">\n          <mat-icon>close </mat-icon>\n        </button>\n\n        <button\n          mat-icon-button\n          *ngIf=\"!taonAdminService.draggablePopupMode\"\n          (click)=\"toogle()\"\n          class=\"admin-close-button\">\n          <mat-icon>close</mat-icon>\n        </button>\n      </column>\n\n      <column width=\"40\">\n        <button\n          mat-icon-button\n          *ngIf=\"!taonAdminService.draggablePopupModeFullScreen\"\n          class=\"admin-close-button\"\n          (click)=\"toogleFullScreen()\">\n          <mat-icon>fullscreen</mat-icon>\n        </button>\n        <button\n          mat-icon-button\n          *ngIf=\"taonAdminService.draggablePopupModeFullScreen\"\n          class=\"admin-close-button\"\n          (click)=\"toogleFullScreen()\">\n          <mat-icon>close_fullscreen</mat-icon>\n        </button>\n      </column>\n\n      <column\n        width=\"40\"\n        *ngIf=\"!taonAdminService.draggablePopupModeFullScreen\">\n        <button\n          mat-icon-button\n          *ngIf=\"!taonAdminService.draggablePopupMode\"\n          (click)=\"taonAdminService.draggablePopupMode = true\"\n          class=\"admin-close-button\">\n          <mat-icon>launch</mat-icon>\n        </button>\n\n        <button\n          mat-icon-button\n          *ngIf=\"taonAdminService.draggablePopupMode\"\n          (click)=\"taonAdminService.draggablePopupMode = false; resetDrag()\"\n          class=\"admin-close-button\">\n          <mat-icon style=\"transform: rotate(180deg)\">login</mat-icon>\n        </button>\n      </column>\n    </columns-container>\n  </div>\n  <!-- #endregion -->\n\n  <columns-container\n    [ngClass]=\"{ 'draggable-column': taonAdminService.draggablePopupMode }\">\n    <column grow>\n      <mat-tab-group\n        dynamicHeight\n        (wheel)=\"scrollTabs($event)\"\n        #tabGroup\n        [selectedIndex]=\"selectedIndex\"\n        (selectedIndexChange)=\"selectedIndex = $event\">\n        <mat-tab label=\"DB/Cache\">\n          <section>\n            <mat-card>\n              <mat-card-header>\n                <mat-card-subtitle>WEBSQL MODE</mat-card-subtitle>\n              </mat-card-header>\n              <mat-card-content>\n                <mat-checkbox\n                  [disabled]=\"!isWebSQLMode\"\n                  [ngModel]=\"taonAdminService.keepWebsqlDbDataAfterReload\"\n                  (change)=\"\n                    taonAdminService.setKeepWebsqlDbDataAfterReload(\n                      $event.checked\n                    )\n                  \">\n                  Don't remove data when reloading\n                </mat-checkbox>\n              </mat-card-content>\n            </mat-card>\n          </section>\n          <br />\n          <taon-db-admin />\n        </mat-tab>\n      </mat-tab-group>\n    </column>\n  </columns-container>\n</ng-template>\n<!-- #endregion -->\n\n<!-- #region small/mobile draggable popup windows -->\n<div\n  class=\"draggable-popup-mode-window\"\n  *ngIf=\"\n    taonAdminService.draggablePopupMode &&\n    !taonAdminService.draggablePopupModeFullScreen &&\n    !isIframe\n  \"\n  cdkDrag\n  [cdkDragFreeDragPosition]=\"dragPosition\"\n  (cdkDragEnded)=\"moved($event)\">\n  <ng-scrollbar>\n    <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n  </ng-scrollbar>\n</div>\n<!-- #endregion -->\n\n<!-- #region fullscreen draggable popup window -->\n<div\n  class=\"draggable-popup-mode-window-full\"\n  *ngIf=\"\n    taonAdminService.draggablePopupMode &&\n    taonAdminService.draggablePopupModeFullScreen &&\n    !isIframe &&\n    !reloading\n  \"\n  cdkDrag\n  [cdkDragFreeDragPosition]=\"dragPositionZero\">\n  <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region content when not in draggable (or fullscreen draggable) popup -->\n<div\n  [style.height.px]=\"height\"\n  *ngIf=\"\n    (isIframe ||\n      !isDesktop ||\n      taonAdminService.draggablePopupMode ||\n      taonAdminService.draggablePopupModeFullScreen) &&\n    !reloading\n  \"\n  style=\"width: 100%; display: block\"\n  class=\"content\">\n  <ng-container\n    [ngTemplateOutlet]=\"\n      taonAdminService.scrollableEnabled ? content : contentNoScroll\n    \"></ng-container>\n</div>\n<!-- #endregion -->\n\n<!-- #region draggable popup window -->\n<mat-drawer-container\n  *ngIf=\"!taonAdminService.draggablePopupMode && isDesktop && !isIframe\"\n  class=\"example-container\"\n  [style.height.px]=\"height\"\n  style=\"background-color: transparent\"\n  (backdropClick)=\"opened = false\"\n  [hasBackdrop]=\"false\">\n  <mat-drawer\n    #drawer\n    style=\"width: 580px\"\n    [opened]=\"opened\"\n    [mode]=\"'side'\">\n    <ng-container [ngTemplateOutlet]=\"adminTabs\"></ng-container>\n  </mat-drawer>\n  <mat-drawer-content style=\"overflow: hidden\">\n    <ng-container\n      *ngIf=\"!taonAdminService.draggablePopupMode && !reloading\"\n      [ngTemplateOutlet]=\"\n        taonAdminService.scrollableEnabled ? content : contentNoScroll\n      \"></ng-container>\n  </mat-drawer-content>\n</mat-drawer-container>\n<!-- #endregion -->\n"]}
|
|
@@ -2,11 +2,12 @@ import { __decorate, __metadata } from "tslib";
|
|
|
2
2
|
import { Stor } from 'taon-storage/websql';
|
|
3
3
|
import { Helpers } from 'tnp-core/websql';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
|
-
import { Injectable } from '@angular/core';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
5
|
const ENV = Helpers.isBrowser ? window['ENV'] : global['ENV'];
|
|
8
6
|
export class TaonAdminService {
|
|
9
7
|
static get Instance() {
|
|
8
|
+
if (!this._instance) {
|
|
9
|
+
this._instance = new TaonAdminService();
|
|
10
|
+
}
|
|
10
11
|
return this._instance;
|
|
11
12
|
}
|
|
12
13
|
constructor() {
|
|
@@ -32,8 +33,6 @@ export class TaonAdminService {
|
|
|
32
33
|
this.adminPanelIsOpen = true;
|
|
33
34
|
}
|
|
34
35
|
logout() { }
|
|
35
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: TaonAdminService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
36
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: TaonAdminService, providedIn: 'root' }); }
|
|
37
36
|
}
|
|
38
37
|
__decorate([
|
|
39
38
|
(Stor.property.in.localstorage.for(TaonAdminService).withDefaultValue(false)),
|
|
@@ -51,10 +50,6 @@ __decorate([
|
|
|
51
50
|
(Stor.property.in.localstorage.for(TaonAdminService).withDefaultValue(false)),
|
|
52
51
|
__metadata("design:type", Boolean)
|
|
53
52
|
], TaonAdminService.prototype, "keepWebsqlDbDataAfterReload", void 0);
|
|
54
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: TaonAdminService, decorators: [{
|
|
55
|
-
type: Injectable,
|
|
56
|
-
args: [{ providedIn: 'root' }]
|
|
57
|
-
}], ctorParameters: () => [] });
|
|
58
53
|
;
|
|
59
54
|
({}); // @--end-of-file-for-module=taon lib/ui/taon-admin-mode-configuration/taon-admin.service.ts
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFvbi1hZG1pbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vdG1wLWxpYnMtZm9yLWRpc3Qtd2Vic3FsL3Rhb24vcHJvamVjdHMvdGFvbi9zcmMvbGliL3VpL3Rhb24tYWRtaW4tbW9kZS1jb25maWd1cmF0aW9uL3Rhb24tYWRtaW4uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBR0EsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxPQUFPLEVBQUssTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUUsT0FBTyxFQUF3QixNQUFNLE1BQU0sQ0FBQztBQU9yRCxNQUFNLEdBQUcsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUc5RCxNQUFNLE9BQU8sZ0JBQWdCO0lBR3BCLE1BQU0sS0FBSyxRQUFRO1FBQ3hCLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFFcEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLGdCQUFnQixFQUFFLENBQUM7UUFDMUMsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBcUNEO1FBakNPLHNCQUFpQixHQUFHLEtBQUssQ0FBQyxDQUFDLHdCQUF3QjtRQUNsRCxlQUFVLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUNuQyxnQkFBVyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxFQUFFLENBQUM7UUFpRDdDLGdCQUFXLEdBQUcsRUFBRSxDQUFDO1FBakJmLGdCQUFnQixDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7UUFDbEMsSUFBSSxDQUFDLGlCQUFpQixHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUscUJBQXFCLENBQUM7SUFDeEQsQ0FBQztJQUlELFdBQVcsQ0FBQyxLQUFjO1FBQ3hCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCw4QkFBOEIsQ0FBQyxLQUFjO1FBSTNDLElBQUksQ0FBQywyQkFBMkIsR0FBRyxLQUFLLENBQUM7SUFDM0MsQ0FBQztJQUlELElBQUk7UUFDRixJQUFJLENBQUMsa0JBQWtCLEdBQUcsS0FBSyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxLQUFLLENBQUM7SUFDaEMsQ0FBQztJQUVELElBQUk7UUFDRixJQUFJLENBQUMsa0JBQWtCLEdBQUcsS0FBSyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLENBQUM7SUFDL0IsQ0FBQztJQUVELE1BQU0sS0FBSSxDQUFDO0NBRVo7QUExRFE7SUFETixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQzs7MERBQzdDO0FBTTFCO0lBRE4sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLENBQUM7OzREQUMzQztBQU01QjtJQUROLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDOztzRUFDakM7QUFRdEM7SUFETixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQzs7cUVBQ2xDO0FBd0M3QyxDQUFDO0FBQUEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLDRGQUE0RiIsInNvdXJjZXNDb250ZW50IjpbIlxuXG5cbmltcG9ydCB7IFN0b3IgfSBmcm9tICd0YW9uLXN0b3JhZ2Uvd2Vic3FsJztcbmltcG9ydCB7IEhlbHBlcnMsIF8gfSBmcm9tICd0bnAtY29yZS93ZWJzcWwnO1xuaW1wb3J0IHsgU3ViamVjdCwgdGFrZSwgdGFrZVVudGlsLCB0YXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB0eXBlIHsgVGFvbkFkbWluTW9kZUNvbmZpZ3VyYXRpb25Db21wb25lbnQgfSBmcm9tICcuL3Rhb24tYWRtaW4tbW9kZS1jb25maWd1cmF0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBnbG9iYWxQdWJsaWNTdG9yYWdlIH0gZnJvbSAnLi4vLi4vc3RvcmFnZSc7XG5pbXBvcnQgeyBjb25maWcgfSBmcm9tICd0bnAtY29uZmlnL3dlYnNxbCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cblxuY29uc3QgRU5WID0gSGVscGVycy5pc0Jyb3dzZXIgPyB3aW5kb3dbJ0VOViddIDogZ2xvYmFsWydFTlYnXTtcblxuXG5leHBvcnQgY2xhc3MgVGFvbkFkbWluU2VydmljZSB7XG5cbiAgcHJpdmF0ZSBzdGF0aWMgX2luc3RhbmNlOiBUYW9uQWRtaW5TZXJ2aWNlO1xuICBwdWJsaWMgc3RhdGljIGdldCBJbnN0YW5jZSgpIHtcbiAgICBpZiAoIXRoaXMuX2luc3RhbmNlKSB7XG5cbiAgICAgIHRoaXMuX2luc3RhbmNlID0gbmV3IFRhb25BZG1pblNlcnZpY2UoKTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuX2luc3RhbmNlO1xuICB9XG5cblxuXG4gIHB1YmxpYyBzY3JvbGxhYmxlRW5hYmxlZCA9IGZhbHNlOyAvLyBUT09EIGZhbHNlIGJ5IGRlZmF1bHRcbiAgcHJpdmF0ZSBvbkVkaXRNb2RlID0gbmV3IFN1YmplY3QoKTtcbiAgb25FZGl0TW9kZSQgPSB0aGlzLm9uRWRpdE1vZGUuYXNPYnNlcnZhYmxlKCk7XG5cblxuXG4gIEAoU3Rvci5wcm9wZXJ0eS5pbi5sb2NhbHN0b3JhZ2UuZm9yKFRhb25BZG1pblNlcnZpY2UpLndpdGhEZWZhdWx0VmFsdWUoZmFsc2UpKVxuICBwdWJsaWMgYWRtaW5QYW5lbElzT3BlbjogYm9vbGVhbjtcblxuXG5cblxuICBAKFN0b3IucHJvcGVydHkuaW4ubG9jYWxzdG9yYWdlLmZvcihUYW9uQWRtaW5TZXJ2aWNlKS53aXRoRGVmYXVsdFZhbHVlKGZhbHNlKSlcbiAgcHVibGljIGRyYWdnYWJsZVBvcHVwTW9kZTogYm9vbGVhbjtcblxuXG5cblxuICBAKFN0b3IucHJvcGVydHkuaW4ubG9jYWxzdG9yYWdlLmZvcihUYW9uQWRtaW5TZXJ2aWNlKS53aXRoRGVmYXVsdFZhbHVlKGZhbHNlKSlcbiAgcHVibGljIGRyYWdnYWJsZVBvcHVwTW9kZUZ1bGxTY3JlZW46IGJvb2xlYW47XG5cblxuXG4gIC8qKlxuICAgKiBQcm9wZXJ0eSB1c2VkIGluIHRhb25cbiAgICovXG4gIEAoU3Rvci5wcm9wZXJ0eS5pbi5sb2NhbHN0b3JhZ2UuZm9yKFRhb25BZG1pblNlcnZpY2UpLndpdGhEZWZhdWx0VmFsdWUoZmFsc2UpKVxuICBwdWJsaWMga2VlcFdlYnNxbERiRGF0YUFmdGVyUmVsb2FkOiBib29sZWFuO1xuXG5cblxuXG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgVGFvbkFkbWluU2VydmljZS5faW5zdGFuY2UgPSB0aGlzO1xuICAgIHRoaXMuc2Nyb2xsYWJsZUVuYWJsZWQgPSAhIUVOVj8udXNlR2xvYmFsTmd4U2Nyb2xsYmFyO1xuICB9XG5cblxuXG4gIHNldEVkaXRNb2RlKHZhbHVlOiBib29sZWFuKSB7XG4gICAgdGhpcy5vbkVkaXRNb2RlLm5leHQodmFsdWUpO1xuICB9XG5cbiAgc2V0S2VlcFdlYnNxbERiRGF0YUFmdGVyUmVsb2FkKHZhbHVlOiBib29sZWFuKSB7XG5cblxuXG4gICAgdGhpcy5rZWVwV2Vic3FsRGJEYXRhQWZ0ZXJSZWxvYWQgPSB2YWx1ZTtcbiAgfVxuXG4gIGVuYWJsZWRUYWJzID0gW107XG5cbiAgaGlkZSgpIHtcbiAgICB0aGlzLmRyYWdnYWJsZVBvcHVwTW9kZSA9IGZhbHNlO1xuICAgIHRoaXMuYWRtaW5QYW5lbElzT3BlbiA9IGZhbHNlO1xuICB9XG5cbiAgc2hvdygpIHtcbiAgICB0aGlzLmRyYWdnYWJsZVBvcHVwTW9kZSA9IGZhbHNlO1xuICAgIHRoaXMuYWRtaW5QYW5lbElzT3BlbiA9IHRydWU7XG4gIH1cblxuICBsb2dvdXQoKSB7fVxuXG59XG5cbiA7KHt9KTsgLy8gQC0tZW5kLW9mLWZpbGUtZm9yLW1vZHVsZT10YW9uIGxpYi91aS90YW9uLWFkbWluLW1vZGUtY29uZmlndXJhdGlvbi90YW9uLWFkbWluLnNlcnZpY2UudHMiXX0=
|