@builder6/docs 0.15.7 → 0.16.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +9 -27
- package/dist/docs/docs.controller.d.ts +167 -208
- package/dist/docs/docs.controller.js +227 -150
- package/dist/docs/docs.controller.js.map +1 -1
- package/dist/docs/docs.gateway.d.ts +102 -6
- package/dist/docs/docs.gateway.js +334 -22
- package/dist/docs/docs.gateway.js.map +1 -1
- package/dist/docs/docs.module.js +2 -0
- package/dist/docs/docs.module.js.map +1 -1
- package/dist/docs/docs.service.d.ts +24 -8
- package/dist/docs/docs.service.js +79 -43
- package/dist/docs/docs.service.js.map +1 -1
- package/dist/docs/editor.controller.d.ts +4 -2
- package/dist/docs/editor.controller.js +43 -11
- package/dist/docs/editor.controller.js.map +1 -1
- package/dist/docs/folders.controller.d.ts +471 -0
- package/dist/docs/folders.controller.js +281 -0
- package/dist/docs/folders.controller.js.map +1 -0
- package/dist/docs/folders.service.d.ts +14 -3
- package/dist/docs/folders.service.js +47 -32
- package/dist/docs/folders.service.js.map +1 -1
- package/dist/docs/people.controller.d.ts +1 -1
- package/dist/docs/people.controller.js +14 -5
- package/dist/docs/people.controller.js.map +1 -1
- package/dist/docs/permission.service.d.ts +51 -6
- package/dist/docs/permission.service.js +94 -13
- package/dist/docs/permission.service.js.map +1 -1
- package/dist/docs/rooms.controller.d.ts +6 -4
- package/dist/docs/rooms.controller.js +16 -3
- package/dist/docs/rooms.controller.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +8 -8
- package/views/editor.ejs +1 -1
- package/dist/app.module.d.ts +0 -2
- package/dist/app.module.js +0 -44
- package/dist/app.module.js.map +0 -1
- package/dist/filters/all-exceptions.filter.d.ts +0 -5
- package/dist/filters/all-exceptions.filter.js +0 -61
- package/dist/filters/all-exceptions.filter.js.map +0 -1
- package/dist/filters/unauthorized.filter.d.ts +0 -7
- package/dist/filters/unauthorized.filter.js +0 -30
- package/dist/filters/unauthorized.filter.js.map +0 -1
- package/dist/main.d.ts +0 -1
- package/dist/main.js +0 -43
- package/dist/main.js.map +0 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@builder6/docs",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.16.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"author": "",
|
|
6
6
|
"private": false,
|
|
@@ -24,12 +24,12 @@
|
|
|
24
24
|
"test:e2e": "jest --config ./test/jest-e2e.json"
|
|
25
25
|
},
|
|
26
26
|
"dependencies": {
|
|
27
|
-
"@builder6/core": "0.
|
|
28
|
-
"@builder6/docs-client": "^3.0.4-beta.
|
|
29
|
-
"@builder6/files": "0.
|
|
30
|
-
"@builder6/moleculer": "0.
|
|
31
|
-
"@builder6/oidc": "0.
|
|
32
|
-
"@builder6/onlyoffice": "0.
|
|
27
|
+
"@builder6/core": "0.16.0",
|
|
28
|
+
"@builder6/docs-client": "^3.0.4-beta.8",
|
|
29
|
+
"@builder6/files": "0.16.0",
|
|
30
|
+
"@builder6/moleculer": "0.16.0",
|
|
31
|
+
"@builder6/oidc": "0.16.0",
|
|
32
|
+
"@builder6/onlyoffice": "0.16.0",
|
|
33
33
|
"@nestjs/common": "^11.0.0",
|
|
34
34
|
"@nestjs/config": "^4.0.1",
|
|
35
35
|
"@nestjs/core": "^11.0.0",
|
|
@@ -95,5 +95,5 @@
|
|
|
95
95
|
"publishConfig": {
|
|
96
96
|
"access": "public"
|
|
97
97
|
},
|
|
98
|
-
"gitHead": "
|
|
98
|
+
"gitHead": "40e18aeeac40ebee0a05d65699cfa6696e65fc56"
|
|
99
99
|
}
|
package/views/editor.ejs
CHANGED
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
<meta name="mobile-web-app-capable" content="yes" />
|
|
9
9
|
<title><%- file.name %></title>
|
|
10
10
|
<link rel="icon"
|
|
11
|
-
href="/
|
|
11
|
+
href="/docs/static/images/icons/32/<%- config.documentType %>.svg" />
|
|
12
12
|
<!-- <link rel="stylesheet" type="text/css" href="stylesheets/editor.css" /> -->
|
|
13
13
|
<style>
|
|
14
14
|
html {
|
package/dist/app.module.d.ts
DELETED
package/dist/app.module.js
DELETED
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
exports.AppModule = void 0;
|
|
10
|
-
const common_1 = require("@nestjs/common");
|
|
11
|
-
const config_1 = require("@nestjs/config");
|
|
12
|
-
const moleculer_1 = require("@builder6/moleculer");
|
|
13
|
-
const oidc_1 = require("@builder6/oidc");
|
|
14
|
-
const onlyoffice_1 = require("@builder6/onlyoffice");
|
|
15
|
-
const docs_module_1 = require("./docs/docs.module");
|
|
16
|
-
const steedos_1 = require("@builder6/steedos");
|
|
17
|
-
const core_1 = require("@builder6/core");
|
|
18
|
-
let AppModule = class AppModule {
|
|
19
|
-
};
|
|
20
|
-
exports.AppModule = AppModule;
|
|
21
|
-
exports.AppModule = AppModule = __decorate([
|
|
22
|
-
(0, common_1.Module)({
|
|
23
|
-
imports: [
|
|
24
|
-
core_1.AuthModule,
|
|
25
|
-
config_1.ConfigModule.forRoot({
|
|
26
|
-
load: [core_1.getConfigs],
|
|
27
|
-
isGlobal: true,
|
|
28
|
-
}),
|
|
29
|
-
moleculer_1.MoleculerModule.forRoot({
|
|
30
|
-
namespace: 'steedos',
|
|
31
|
-
transporter: process.env.B6_TRANSPORTER,
|
|
32
|
-
...(0, core_1.getMoleculerConfigs)(),
|
|
33
|
-
...(0, core_1.getEnvConfigs)(),
|
|
34
|
-
}),
|
|
35
|
-
oidc_1.OidcModule,
|
|
36
|
-
steedos_1.SteedosModule,
|
|
37
|
-
onlyoffice_1.OnlyOfficeModule,
|
|
38
|
-
docs_module_1.DocsModule,
|
|
39
|
-
],
|
|
40
|
-
controllers: [],
|
|
41
|
-
providers: [],
|
|
42
|
-
})
|
|
43
|
-
], AppModule);
|
|
44
|
-
//# sourceMappingURL=app.module.js.map
|
package/dist/app.module.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"app.module.js","sourceRoot":"","sources":["../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,2CAA8C;AAC9C,mDAAsD;AACtD,yCAA4C;AAE5C,qDAAwD;AACxD,oDAAgD;AAChD,+CAAkD;AAClD,yCAA4F;AA2BrF,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IAvBrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,iBAAU;YACV,qBAAY,CAAC,OAAO,CAAC;gBACnB,IAAI,EAAE,CAAC,iBAAU,CAAC;gBAClB,QAAQ,EAAE,IAAI;aACf,CAAC;YACF,2BAAe,CAAC,OAAO,CAAC;gBAEtB,SAAS,EAAE,SAAS;gBACpB,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,cAAc;gBAEvC,GAAG,IAAA,0BAAmB,GAAE;gBACxB,GAAG,IAAA,oBAAa,GAAE;aACnB,CAAC;YACF,iBAAU;YACV,uBAAa;YACb,6BAAgB;YAChB,wBAAU;SACX;QACD,WAAW,EAAE,EAAE;QACf,SAAS,EAAE,EAAE;KACd,CAAC;GACW,SAAS,CAAG"}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
var AllExceptionsFilter_1;
|
|
9
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
-
exports.AllExceptionsFilter = void 0;
|
|
11
|
-
const common_1 = require("@nestjs/common");
|
|
12
|
-
let AllExceptionsFilter = AllExceptionsFilter_1 = class AllExceptionsFilter {
|
|
13
|
-
constructor() {
|
|
14
|
-
this.logger = new common_1.Logger(AllExceptionsFilter_1.name);
|
|
15
|
-
}
|
|
16
|
-
catch(exception, host) {
|
|
17
|
-
try {
|
|
18
|
-
const ctx = host.switchToHttp();
|
|
19
|
-
const response = ctx.getResponse();
|
|
20
|
-
const request = ctx.getRequest();
|
|
21
|
-
this.logger.error({
|
|
22
|
-
method: request.method,
|
|
23
|
-
url: request.url,
|
|
24
|
-
headers: request.headers,
|
|
25
|
-
exception,
|
|
26
|
-
}, exception.stack);
|
|
27
|
-
let errorResponse;
|
|
28
|
-
const message = exception?.response?.error?.message ||
|
|
29
|
-
exception?.response?.message ||
|
|
30
|
-
exception.message;
|
|
31
|
-
const code = exception?.response?.error?.code || exception?.code;
|
|
32
|
-
if (exception instanceof common_1.HttpException) {
|
|
33
|
-
errorResponse = {
|
|
34
|
-
status: exception.getStatus(),
|
|
35
|
-
message,
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
errorResponse = {
|
|
40
|
-
message,
|
|
41
|
-
status: common_1.HttpStatus.INTERNAL_SERVER_ERROR,
|
|
42
|
-
};
|
|
43
|
-
}
|
|
44
|
-
response.status(errorResponse.status).json({
|
|
45
|
-
statusCode: errorResponse.status,
|
|
46
|
-
timestamp: new Date().toISOString(),
|
|
47
|
-
path: request.url,
|
|
48
|
-
message: errorResponse.message,
|
|
49
|
-
code: code,
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
catch (error) {
|
|
53
|
-
this.logger.error('Error while processing uncaught exception', error.stack);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
exports.AllExceptionsFilter = AllExceptionsFilter;
|
|
58
|
-
exports.AllExceptionsFilter = AllExceptionsFilter = AllExceptionsFilter_1 = __decorate([
|
|
59
|
-
(0, common_1.Catch)()
|
|
60
|
-
], AllExceptionsFilter);
|
|
61
|
-
//# sourceMappingURL=all-exceptions.filter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"all-exceptions.filter.js","sourceRoot":"","sources":["../../src/filters/all-exceptions.filter.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAOwB;AAQjB,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAAzB;QACG,WAAM,GAAW,IAAI,eAAM,CAAC,qBAAmB,CAAC,IAAI,CAAC,CAAC;IAkDhE,CAAC;IAjDC,KAAK,CAAC,SAAc,EAAE,IAAmB;QACvC,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YAChC,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;YACnC,MAAM,OAAO,GAAG,GAAG,CAAC,UAAU,EAAE,CAAC;YAEjC,IAAI,CAAC,MAAM,CAAC,KAAK,CACf;gBACE,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,SAAS;aACV,EACD,SAAS,CAAC,KAAK,CAChB,CAAC;YAEF,IAAI,aAA4B,CAAC;YACjC,MAAM,OAAO,GACX,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO;gBACnC,SAAS,EAAE,QAAQ,EAAE,OAAO;gBAC5B,SAAS,CAAC,OAAO,CAAC;YACpB,MAAM,IAAI,GAAG,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,IAAI,SAAS,EAAE,IAAI,CAAC;YAEjE,IAAI,SAAS,YAAY,sBAAa,EAAE,CAAC;gBACvC,aAAa,GAAG;oBACd,MAAM,EAAE,SAAS,CAAC,SAAS,EAAE;oBAC7B,OAAO;iBACR,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,aAAa,GAAG;oBACd,OAAO;oBACP,MAAM,EAAE,mBAAU,CAAC,qBAAqB;iBACzC,CAAC;YACJ,CAAC;YAED,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC;gBACzC,UAAU,EAAE,aAAa,CAAC,MAAM;gBAChC,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBACnC,IAAI,EAAE,OAAO,CAAC,GAAG;gBACjB,OAAO,EAAE,aAAa,CAAC,OAAO;gBAC9B,IAAI,EAAE,IAAI;aACX,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,2CAA2C,EAC3C,KAAK,CAAC,KAAK,CACZ,CAAC;QACJ,CAAC;IACH,CAAC;CACF,CAAA;AAnDY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,cAAK,GAAE;GACK,mBAAmB,CAmD/B"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { ExceptionFilter, ArgumentsHost, UnauthorizedException } from '@nestjs/common';
|
|
2
|
-
import { ConfigService } from '@nestjs/config';
|
|
3
|
-
export declare class AuthExceptionFilter implements ExceptionFilter {
|
|
4
|
-
private readonly configService;
|
|
5
|
-
constructor(configService: ConfigService);
|
|
6
|
-
catch(exception: UnauthorizedException, host: ArgumentsHost): void;
|
|
7
|
-
}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.AuthExceptionFilter = void 0;
|
|
13
|
-
const common_1 = require("@nestjs/common");
|
|
14
|
-
const config_1 = require("@nestjs/config");
|
|
15
|
-
let AuthExceptionFilter = class AuthExceptionFilter {
|
|
16
|
-
constructor(configService) {
|
|
17
|
-
this.configService = configService;
|
|
18
|
-
}
|
|
19
|
-
catch(exception, host) {
|
|
20
|
-
const ctx = host.switchToHttp();
|
|
21
|
-
const response = ctx.getResponse();
|
|
22
|
-
return response.redirect('/api/v6/oidc/default/login');
|
|
23
|
-
}
|
|
24
|
-
};
|
|
25
|
-
exports.AuthExceptionFilter = AuthExceptionFilter;
|
|
26
|
-
exports.AuthExceptionFilter = AuthExceptionFilter = __decorate([
|
|
27
|
-
(0, common_1.Catch)(common_1.UnauthorizedException),
|
|
28
|
-
__metadata("design:paramtypes", [config_1.ConfigService])
|
|
29
|
-
], AuthExceptionFilter);
|
|
30
|
-
//# sourceMappingURL=unauthorized.filter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"unauthorized.filter.js","sourceRoot":"","sources":["../../src/filters/unauthorized.filter.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AACxB,2CAA+C;AAIxC,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAC9B,YAA6B,aAA4B;QAA5B,kBAAa,GAAb,aAAa,CAAe;IAAG,CAAC;IAE7D,KAAK,CAAC,SAAgC,EAAE,IAAmB;QACzD,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAChC,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAY,CAAC;QAE7C,OAAO,QAAQ,CAAC,QAAQ,CAAC,4BAA4B,CAAC,CAAC;IACzD,CAAC;CACF,CAAA;AATY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,cAAK,EAAC,8BAAqB,CAAC;qCAEiB,sBAAa;GAD9C,mBAAmB,CAS/B"}
|
package/dist/main.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/dist/main.js
DELETED
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const core_1 = require("@nestjs/core");
|
|
7
|
-
const app_module_1 = require("./app.module");
|
|
8
|
-
const all_exceptions_filter_1 = require("./filters/all-exceptions.filter");
|
|
9
|
-
const express_session_1 = __importDefault(require("express-session"));
|
|
10
|
-
const cookie_parser_1 = __importDefault(require("cookie-parser"));
|
|
11
|
-
const swagger_1 = require("@nestjs/swagger");
|
|
12
|
-
const project = require('../package.json');
|
|
13
|
-
async function bootstrap() {
|
|
14
|
-
const app = await core_1.NestFactory.create(app_module_1.AppModule);
|
|
15
|
-
app.enableCors({
|
|
16
|
-
origin: function (origin, callback) {
|
|
17
|
-
callback(null, true);
|
|
18
|
-
},
|
|
19
|
-
methods: 'GET,PUT,POST,DELETE,UPDATE,OPTIONS',
|
|
20
|
-
credentials: true,
|
|
21
|
-
});
|
|
22
|
-
app.useGlobalFilters(new all_exceptions_filter_1.AllExceptionsFilter());
|
|
23
|
-
app.use((0, express_session_1.default)({
|
|
24
|
-
secret: 'your_session_secret',
|
|
25
|
-
resave: false,
|
|
26
|
-
saveUninitialized: false,
|
|
27
|
-
}));
|
|
28
|
-
app.use((0, cookie_parser_1.default)());
|
|
29
|
-
const swaggerConfig = new swagger_1.DocumentBuilder()
|
|
30
|
-
.setTitle('Docs API')
|
|
31
|
-
.setVersion(project.version)
|
|
32
|
-
.build();
|
|
33
|
-
const documentFactory = () => swagger_1.SwaggerModule.createDocument(app, swaggerConfig);
|
|
34
|
-
swagger_1.SwaggerModule.setup('api/v6', app, documentFactory, {
|
|
35
|
-
explorer: true,
|
|
36
|
-
swaggerOptions: {
|
|
37
|
-
docExpansion: 'none',
|
|
38
|
-
},
|
|
39
|
-
});
|
|
40
|
-
await app.listen(process.env.B6_PORT ?? 5200);
|
|
41
|
-
}
|
|
42
|
-
bootstrap();
|
|
43
|
-
//# sourceMappingURL=main.js.map
|
package/dist/main.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":";;;;;AAAA,uCAA2C;AAC3C,6CAAyC;AACzC,2EAAsE;AACtE,sEAAsC;AACtC,kEAAyC;AACzC,6CAAiE;AAGjE,MAAM,OAAO,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;AAE3C,KAAK,UAAU,SAAS;IACtB,MAAM,GAAG,GAAG,MAAM,kBAAW,CAAC,MAAM,CAAC,sBAAS,CAAC,CAAC;IAChD,GAAG,CAAC,UAAU,CAAC;QACb,MAAM,EAAE,UAAU,MAAM,EAAE,QAAQ;YAChC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACvB,CAAC;QACD,OAAO,EAAE,oCAAoC;QAC7C,WAAW,EAAE,IAAI;KAClB,CAAC,CAAC;IACH,GAAG,CAAC,gBAAgB,CAAC,IAAI,2CAAmB,EAAE,CAAC,CAAC;IAChD,GAAG,CAAC,GAAG,CACL,IAAA,yBAAO,EAAC;QACN,MAAM,EAAE,qBAAqB;QAC7B,MAAM,EAAE,KAAK;QACb,iBAAiB,EAAE,KAAK;KACzB,CAAC,CACH,CAAC;IACF,GAAG,CAAC,GAAG,CAAC,IAAA,uBAAY,GAAE,CAAC,CAAC;IAExB,MAAM,aAAa,GAAG,IAAI,yBAAe,EAAE;SACxC,QAAQ,CAAC,UAAU,CAAC;SACpB,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC;SAC3B,KAAK,EAAE,CAAC;IAEX,MAAM,eAAe,GAAG,GAAG,EAAE,CAC3B,uBAAa,CAAC,cAAc,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC;IACnD,uBAAa,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,eAAe,EAAE;QAClD,QAAQ,EAAE,IAAI;QACd,cAAc,EAAE;YACd,YAAY,EAAE,MAAM;SACrB;KACF,CAAC,CAAC;IACH,MAAM,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC;AAChD,CAAC;AACD,SAAS,EAAE,CAAC"}
|