sonamu 0.5.6 → 0.6.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.
Files changed (365) hide show
  1. package/dist/api/base-frame.js +12 -2
  2. package/dist/api/caster.js +66 -2
  3. package/dist/api/code-converters.js +489 -2
  4. package/dist/api/config.d.ts +76 -0
  5. package/dist/api/config.d.ts.map +1 -0
  6. package/dist/api/config.js +32 -0
  7. package/dist/api/context.d.ts +1 -0
  8. package/dist/api/context.d.ts.map +1 -1
  9. package/dist/api/context.js +3 -2
  10. package/dist/api/decorators.d.ts +1 -0
  11. package/dist/api/decorators.d.ts.map +1 -1
  12. package/dist/api/decorators.js +142 -2
  13. package/dist/api/index.js +9 -2
  14. package/dist/api/sonamu.d.ts +8 -22
  15. package/dist/api/sonamu.d.ts.map +1 -1
  16. package/dist/api/sonamu.js +482 -2
  17. package/dist/bin/build-config.d.ts +2 -1
  18. package/dist/bin/build-config.d.ts.map +1 -1
  19. package/dist/bin/build-config.js +12 -2
  20. package/dist/bin/cli-wrapper.js +71 -2
  21. package/dist/bin/cli.js +418 -2
  22. package/dist/bin/hot-hook-register.d.ts +11 -0
  23. package/dist/bin/hot-hook-register.d.ts.map +1 -0
  24. package/dist/bin/hot-hook-register.js +21 -0
  25. package/dist/database/_batch_update.js +78 -2
  26. package/dist/database/base-model.js +247 -2
  27. package/dist/database/code-generator.js +53 -2
  28. package/dist/database/db.d.ts +5 -16
  29. package/dist/database/db.d.ts.map +1 -1
  30. package/dist/database/db.js +132 -2
  31. package/dist/database/knex-plugins/knex-on-duplicate-update.js +39 -2
  32. package/dist/database/puri-wrapper.d.ts +22 -10
  33. package/dist/database/puri-wrapper.d.ts.map +1 -1
  34. package/dist/database/puri-wrapper.js +109 -2
  35. package/dist/database/puri.d.ts +105 -73
  36. package/dist/database/puri.d.ts.map +1 -1
  37. package/dist/database/puri.js +539 -2
  38. package/dist/database/puri.types.d.ts +33 -42
  39. package/dist/database/puri.types.d.ts.map +1 -1
  40. package/dist/database/puri.types.js +3 -2
  41. package/dist/database/transaction-context.d.ts +3 -3
  42. package/dist/database/transaction-context.d.ts.map +1 -1
  43. package/dist/database/transaction-context.js +14 -2
  44. package/dist/database/upsert-builder.js +215 -2
  45. package/dist/entity/entity-manager.d.ts +3 -1
  46. package/dist/entity/entity-manager.d.ts.map +1 -1
  47. package/dist/entity/entity-manager.js +114 -2
  48. package/dist/entity/entity-utils.js +210 -2
  49. package/dist/entity/entity.d.ts.map +1 -1
  50. package/dist/entity/entity.js +651 -2
  51. package/dist/exceptions/error-handler.js +29 -2
  52. package/dist/exceptions/so-exceptions.js +85 -2
  53. package/dist/file-storage/driver.js +79 -2
  54. package/dist/file-storage/file-storage.js +75 -2
  55. package/dist/index.d.ts +2 -0
  56. package/dist/index.d.ts.map +1 -1
  57. package/dist/index.js +28 -2
  58. package/dist/migration/code-generation.js +558 -2
  59. package/dist/migration/migration-set.js +364 -2
  60. package/dist/migration/migrator.d.ts +0 -9
  61. package/dist/migration/migrator.d.ts.map +1 -1
  62. package/dist/migration/migrator.js +510 -2
  63. package/dist/migration/types.js +3 -2
  64. package/dist/naite/naite.d.ts +12 -0
  65. package/dist/naite/naite.d.ts.map +1 -0
  66. package/dist/naite/naite.js +72 -0
  67. package/dist/stream/index.js +3 -2
  68. package/dist/stream/sse.js +38 -2
  69. package/dist/syncer/api-parser.d.ts +20 -0
  70. package/dist/syncer/api-parser.d.ts.map +1 -0
  71. package/dist/syncer/api-parser.js +229 -0
  72. package/dist/syncer/checksum.d.ts +21 -0
  73. package/dist/syncer/checksum.d.ts.map +1 -0
  74. package/dist/syncer/checksum.js +98 -0
  75. package/dist/syncer/code-generator.d.ts +20 -0
  76. package/dist/syncer/code-generator.d.ts.map +1 -0
  77. package/dist/syncer/code-generator.js +141 -0
  78. package/dist/syncer/entity-operations.d.ts +17 -0
  79. package/dist/syncer/entity-operations.d.ts.map +1 -0
  80. package/dist/syncer/entity-operations.js +58 -0
  81. package/dist/syncer/file-patterns.d.ts +29 -0
  82. package/dist/syncer/file-patterns.d.ts.map +1 -0
  83. package/dist/syncer/file-patterns.js +38 -0
  84. package/dist/syncer/index.d.ts +6 -0
  85. package/dist/syncer/index.d.ts.map +1 -1
  86. package/dist/syncer/index.js +9 -2
  87. package/dist/syncer/module-loader.d.ts +35 -0
  88. package/dist/syncer/module-loader.d.ts.map +1 -0
  89. package/dist/syncer/module-loader.js +82 -0
  90. package/dist/syncer/syncer.d.ts +93 -108
  91. package/dist/syncer/syncer.d.ts.map +1 -1
  92. package/dist/syncer/syncer.js +375 -2
  93. package/dist/template/entity-converter.d.ts +14 -0
  94. package/dist/template/entity-converter.d.ts.map +1 -0
  95. package/dist/template/entity-converter.js +101 -0
  96. package/dist/template/helpers.d.ts +23 -0
  97. package/dist/template/helpers.d.ts.map +1 -0
  98. package/dist/template/helpers.js +64 -0
  99. package/dist/{templates → template/implementations}/entity.template.d.ts +3 -3
  100. package/dist/template/implementations/entity.template.d.ts.map +1 -0
  101. package/dist/template/implementations/entity.template.js +87 -0
  102. package/dist/{templates → template/implementations}/generated.template.d.ts +3 -3
  103. package/dist/template/implementations/generated.template.d.ts.map +1 -0
  104. package/dist/template/implementations/generated.template.js +232 -0
  105. package/dist/{templates → template/implementations}/generated_http.template.d.ts +3 -3
  106. package/dist/template/implementations/generated_http.template.d.ts.map +1 -0
  107. package/dist/template/implementations/generated_http.template.js +131 -0
  108. package/dist/{templates → template/implementations}/generated_sso.template.d.ts +3 -3
  109. package/dist/template/implementations/generated_sso.template.d.ts.map +1 -0
  110. package/dist/template/implementations/generated_sso.template.js +105 -0
  111. package/dist/{templates → template/implementations}/init_types.template.d.ts +3 -3
  112. package/dist/template/implementations/init_types.template.d.ts.map +1 -0
  113. package/dist/template/implementations/init_types.template.js +38 -0
  114. package/dist/template/implementations/model.template.d.ts +17 -0
  115. package/dist/template/implementations/model.template.d.ts.map +1 -0
  116. package/dist/template/implementations/model.template.js +171 -0
  117. package/dist/{templates → template/implementations}/model_test.template.d.ts +3 -3
  118. package/dist/template/implementations/model_test.template.d.ts.map +1 -0
  119. package/dist/template/implementations/model_test.template.js +35 -0
  120. package/dist/{templates → template/implementations}/service.template.d.ts +6 -6
  121. package/dist/template/implementations/service.template.d.ts.map +1 -0
  122. package/dist/template/implementations/service.template.js +193 -0
  123. package/dist/{templates → template/implementations}/view_enums_buttonset.template.d.ts +3 -3
  124. package/dist/template/implementations/view_enums_buttonset.template.d.ts.map +1 -0
  125. package/dist/template/implementations/view_enums_buttonset.template.js +31 -0
  126. package/dist/{templates → template/implementations}/view_enums_dropdown.template.d.ts +3 -4
  127. package/dist/template/implementations/view_enums_dropdown.template.d.ts.map +1 -0
  128. package/dist/template/implementations/view_enums_dropdown.template.js +50 -0
  129. package/dist/{templates → template/implementations}/view_enums_select.template.d.ts +3 -3
  130. package/dist/template/implementations/view_enums_select.template.d.ts.map +1 -0
  131. package/dist/template/implementations/view_enums_select.template.js +55 -0
  132. package/dist/{templates → template/implementations}/view_form.template.d.ts +5 -5
  133. package/dist/template/implementations/view_form.template.d.ts.map +1 -0
  134. package/dist/template/implementations/view_form.template.js +337 -0
  135. package/dist/{templates → template/implementations}/view_id_all_select.template.d.ts +3 -3
  136. package/dist/template/implementations/view_id_all_select.template.d.ts.map +1 -0
  137. package/dist/template/implementations/view_id_all_select.template.js +31 -0
  138. package/dist/{templates → template/implementations}/view_id_async_select.template.d.ts +3 -3
  139. package/dist/template/implementations/view_id_async_select.template.d.ts.map +1 -0
  140. package/dist/template/implementations/view_id_async_select.template.js +105 -0
  141. package/dist/{templates → template/implementations}/view_list.template.d.ts +5 -13
  142. package/dist/template/implementations/view_list.template.d.ts.map +1 -0
  143. package/dist/template/implementations/view_list.template.js +465 -0
  144. package/dist/{templates → template/implementations}/view_list_columns.template.d.ts +3 -3
  145. package/dist/template/implementations/view_list_columns.template.d.ts.map +1 -0
  146. package/dist/template/implementations/view_list_columns.template.js +49 -0
  147. package/dist/{templates → template/implementations}/view_search_input.template.d.ts +3 -3
  148. package/dist/template/implementations/view_search_input.template.d.ts.map +1 -0
  149. package/dist/template/implementations/view_search_input.template.js +64 -0
  150. package/dist/template/index.d.ts +5 -0
  151. package/dist/template/index.d.ts.map +1 -0
  152. package/dist/template/index.js +6 -0
  153. package/dist/template/template.d.ts +39 -0
  154. package/dist/template/template.d.ts.map +1 -0
  155. package/dist/template/template.js +47 -0
  156. package/dist/template/zod-converter.d.ts +18 -0
  157. package/dist/template/zod-converter.d.ts.map +1 -0
  158. package/dist/template/zod-converter.js +166 -0
  159. package/dist/testing/_relation-graph.js +80 -2
  160. package/dist/testing/fixture-manager.d.ts.map +1 -1
  161. package/dist/testing/fixture-manager.js +521 -2
  162. package/dist/types/types.d.ts +39 -40
  163. package/dist/types/types.d.ts.map +1 -1
  164. package/dist/types/types.js +289 -2
  165. package/dist/typings/knex.d.js +3 -2
  166. package/dist/utils/async-utils.d.ts +7 -0
  167. package/dist/utils/async-utils.d.ts.map +1 -1
  168. package/dist/utils/async-utils.js +57 -2
  169. package/dist/utils/console-util.d.ts +2 -0
  170. package/dist/utils/console-util.d.ts.map +1 -0
  171. package/dist/utils/console-util.js +6 -0
  172. package/dist/utils/controller.js +26 -2
  173. package/dist/utils/esm-utils.d.ts +45 -0
  174. package/dist/utils/esm-utils.d.ts.map +1 -0
  175. package/dist/utils/esm-utils.js +56 -0
  176. package/dist/utils/fs-utils.js +17 -2
  177. package/dist/utils/lodash-able.js +6 -2
  178. package/dist/utils/model.js +22 -2
  179. package/dist/utils/path-utils.d.ts +89 -0
  180. package/dist/utils/path-utils.d.ts.map +1 -0
  181. package/dist/utils/path-utils.js +60 -0
  182. package/dist/utils/process-utils.d.ts +13 -0
  183. package/dist/utils/process-utils.d.ts.map +1 -0
  184. package/dist/utils/process-utils.js +36 -0
  185. package/dist/utils/sql-parser.js +35 -2
  186. package/dist/utils/utils.d.ts +4 -7
  187. package/dist/utils/utils.d.ts.map +1 -1
  188. package/dist/utils/utils.js +33 -2
  189. package/dist/utils/zod-error.d.ts.map +1 -1
  190. package/dist/utils/zod-error.js +19 -2
  191. package/package.json +21 -9
  192. package/src/api/code-converters.ts +2 -2
  193. package/src/api/config.ts +142 -0
  194. package/src/api/context.ts +1 -0
  195. package/src/api/decorators.ts +15 -5
  196. package/src/api/sonamu.ts +102 -87
  197. package/src/bin/build-config.ts +2 -1
  198. package/src/bin/cli-wrapper.ts +10 -3
  199. package/src/bin/cli.ts +108 -56
  200. package/src/bin/hot-hook-register.ts +22 -0
  201. package/src/database/base-model.ts +1 -1
  202. package/src/database/code-generator.ts +1 -1
  203. package/src/database/db.ts +53 -60
  204. package/src/database/puri-wrapper.ts +104 -26
  205. package/src/database/puri.ts +477 -580
  206. package/src/database/puri.types.ts +111 -201
  207. package/src/database/transaction-context.ts +4 -4
  208. package/src/database/upsert-builder.ts +1 -1
  209. package/src/entity/entity-manager.ts +19 -15
  210. package/src/entity/entity.ts +4 -3
  211. package/src/index.ts +2 -0
  212. package/src/migration/code-generation.ts +1 -1
  213. package/src/migration/migration-set.ts +1 -1
  214. package/src/migration/migrator.ts +23 -152
  215. package/src/naite/naite.ts +70 -0
  216. package/src/syncer/api-parser.ts +299 -0
  217. package/src/syncer/checksum.ts +152 -0
  218. package/src/syncer/code-generator.ts +202 -0
  219. package/src/syncer/entity-operations.ts +68 -0
  220. package/src/syncer/file-patterns.ts +56 -0
  221. package/src/syncer/index.ts +6 -0
  222. package/src/syncer/module-loader.ts +125 -0
  223. package/src/syncer/syncer.ts +363 -1420
  224. package/src/template/entity-converter.ts +123 -0
  225. package/src/template/helpers.ts +84 -0
  226. package/src/{templates → template/implementations}/entity.template.ts +4 -4
  227. package/src/{templates → template/implementations}/generated.template.ts +9 -9
  228. package/src/{templates → template/implementations}/generated_http.template.ts +9 -6
  229. package/src/{templates → template/implementations}/generated_sso.template.ts +7 -7
  230. package/src/{templates → template/implementations}/init_types.template.ts +4 -4
  231. package/src/{templates → template/implementations}/model.template.ts +9 -9
  232. package/src/{templates → template/implementations}/model_test.template.ts +5 -5
  233. package/src/{templates → template/implementations}/service.template.ts +29 -12
  234. package/src/{templates → template/implementations}/view_enums_buttonset.template.ts +3 -3
  235. package/src/{templates → template/implementations}/view_enums_dropdown.template.ts +5 -21
  236. package/src/{templates → template/implementations}/view_enums_select.template.ts +4 -4
  237. package/src/{templates → template/implementations}/view_form.template.ts +11 -13
  238. package/src/{templates → template/implementations}/view_id_all_select.template.ts +3 -3
  239. package/src/{templates → template/implementations}/view_id_async_select.template.ts +3 -3
  240. package/src/{templates → template/implementations}/view_list.template.ts +13 -64
  241. package/src/{templates → template/implementations}/view_list_columns.template.ts +3 -3
  242. package/src/{templates → template/implementations}/view_search_input.template.ts +3 -3
  243. package/src/template/index.ts +4 -0
  244. package/src/template/template.ts +86 -0
  245. package/src/template/zod-converter.ts +219 -0
  246. package/src/testing/fixture-manager.ts +8 -1
  247. package/src/types/types.ts +39 -62
  248. package/src/utils/async-utils.ts +17 -0
  249. package/src/utils/console-util.ts +4 -0
  250. package/src/utils/esm-utils.ts +69 -0
  251. package/src/utils/path-utils.ts +102 -0
  252. package/src/utils/process-utils.ts +46 -0
  253. package/src/utils/sql-parser.ts +1 -1
  254. package/src/utils/utils.ts +14 -40
  255. package/src/utils/zod-error.ts +0 -1
  256. package/dist/api/base-frame.js.map +0 -1
  257. package/dist/api/caster.js.map +0 -1
  258. package/dist/api/code-converters.js.map +0 -1
  259. package/dist/api/context.js.map +0 -1
  260. package/dist/api/decorators.js.map +0 -1
  261. package/dist/api/index.js.map +0 -1
  262. package/dist/api/sonamu.js.map +0 -1
  263. package/dist/bin/build-config.js.map +0 -1
  264. package/dist/bin/cli-wrapper.js.map +0 -1
  265. package/dist/bin/cli.js.map +0 -1
  266. package/dist/database/_batch_update.js.map +0 -1
  267. package/dist/database/base-model.js.map +0 -1
  268. package/dist/database/code-generator.js.map +0 -1
  269. package/dist/database/db.js.map +0 -1
  270. package/dist/database/knex-plugins/knex-on-duplicate-update.js.map +0 -1
  271. package/dist/database/puri-wrapper.js.map +0 -1
  272. package/dist/database/puri.js.map +0 -1
  273. package/dist/database/puri.types.js.map +0 -1
  274. package/dist/database/transaction-context.js.map +0 -1
  275. package/dist/database/upsert-builder.js.map +0 -1
  276. package/dist/entity/entity-manager.js.map +0 -1
  277. package/dist/entity/entity-utils.js.map +0 -1
  278. package/dist/entity/entity.js.map +0 -1
  279. package/dist/exceptions/error-handler.js.map +0 -1
  280. package/dist/exceptions/so-exceptions.js.map +0 -1
  281. package/dist/file-storage/driver.js.map +0 -1
  282. package/dist/file-storage/file-storage.js.map +0 -1
  283. package/dist/index.js.map +0 -1
  284. package/dist/migration/code-generation.js.map +0 -1
  285. package/dist/migration/migration-set.js.map +0 -1
  286. package/dist/migration/migrator.js.map +0 -1
  287. package/dist/migration/types.js.map +0 -1
  288. package/dist/stream/index.js.map +0 -1
  289. package/dist/stream/sse.js.map +0 -1
  290. package/dist/syncer/index.js.map +0 -1
  291. package/dist/syncer/syncer.js.map +0 -1
  292. package/dist/templates/base-template.d.ts +0 -13
  293. package/dist/templates/base-template.d.ts.map +0 -1
  294. package/dist/templates/base-template.js +0 -2
  295. package/dist/templates/base-template.js.map +0 -1
  296. package/dist/templates/entity.template.d.ts.map +0 -1
  297. package/dist/templates/entity.template.js +0 -2
  298. package/dist/templates/entity.template.js.map +0 -1
  299. package/dist/templates/generated.template.d.ts.map +0 -1
  300. package/dist/templates/generated.template.js +0 -2
  301. package/dist/templates/generated.template.js.map +0 -1
  302. package/dist/templates/generated_http.template.d.ts.map +0 -1
  303. package/dist/templates/generated_http.template.js +0 -2
  304. package/dist/templates/generated_http.template.js.map +0 -1
  305. package/dist/templates/generated_sso.template.d.ts.map +0 -1
  306. package/dist/templates/generated_sso.template.js +0 -2
  307. package/dist/templates/generated_sso.template.js.map +0 -1
  308. package/dist/templates/index.d.ts +0 -2
  309. package/dist/templates/index.d.ts.map +0 -1
  310. package/dist/templates/index.js +0 -2
  311. package/dist/templates/index.js.map +0 -1
  312. package/dist/templates/init_types.template.d.ts.map +0 -1
  313. package/dist/templates/init_types.template.js +0 -2
  314. package/dist/templates/init_types.template.js.map +0 -1
  315. package/dist/templates/model.template.d.ts +0 -17
  316. package/dist/templates/model.template.d.ts.map +0 -1
  317. package/dist/templates/model.template.js +0 -2
  318. package/dist/templates/model.template.js.map +0 -1
  319. package/dist/templates/model_test.template.d.ts.map +0 -1
  320. package/dist/templates/model_test.template.js +0 -2
  321. package/dist/templates/model_test.template.js.map +0 -1
  322. package/dist/templates/service.template.d.ts.map +0 -1
  323. package/dist/templates/service.template.js +0 -2
  324. package/dist/templates/service.template.js.map +0 -1
  325. package/dist/templates/view_enums_buttonset.template.d.ts.map +0 -1
  326. package/dist/templates/view_enums_buttonset.template.js +0 -2
  327. package/dist/templates/view_enums_buttonset.template.js.map +0 -1
  328. package/dist/templates/view_enums_dropdown.template.d.ts.map +0 -1
  329. package/dist/templates/view_enums_dropdown.template.js +0 -2
  330. package/dist/templates/view_enums_dropdown.template.js.map +0 -1
  331. package/dist/templates/view_enums_select.template.d.ts.map +0 -1
  332. package/dist/templates/view_enums_select.template.js +0 -2
  333. package/dist/templates/view_enums_select.template.js.map +0 -1
  334. package/dist/templates/view_form.template.d.ts.map +0 -1
  335. package/dist/templates/view_form.template.js +0 -2
  336. package/dist/templates/view_form.template.js.map +0 -1
  337. package/dist/templates/view_id_all_select.template.d.ts.map +0 -1
  338. package/dist/templates/view_id_all_select.template.js +0 -2
  339. package/dist/templates/view_id_all_select.template.js.map +0 -1
  340. package/dist/templates/view_id_async_select.template.d.ts.map +0 -1
  341. package/dist/templates/view_id_async_select.template.js +0 -2
  342. package/dist/templates/view_id_async_select.template.js.map +0 -1
  343. package/dist/templates/view_list.template.d.ts.map +0 -1
  344. package/dist/templates/view_list.template.js +0 -2
  345. package/dist/templates/view_list.template.js.map +0 -1
  346. package/dist/templates/view_list_columns.template.d.ts.map +0 -1
  347. package/dist/templates/view_list_columns.template.js +0 -2
  348. package/dist/templates/view_list_columns.template.js.map +0 -1
  349. package/dist/templates/view_search_input.template.d.ts.map +0 -1
  350. package/dist/templates/view_search_input.template.js +0 -2
  351. package/dist/templates/view_search_input.template.js.map +0 -1
  352. package/dist/testing/_relation-graph.js.map +0 -1
  353. package/dist/testing/fixture-manager.js.map +0 -1
  354. package/dist/types/types.js.map +0 -1
  355. package/dist/typings/knex.d.js.map +0 -1
  356. package/dist/utils/async-utils.js.map +0 -1
  357. package/dist/utils/controller.js.map +0 -1
  358. package/dist/utils/fs-utils.js.map +0 -1
  359. package/dist/utils/lodash-able.js.map +0 -1
  360. package/dist/utils/model.js.map +0 -1
  361. package/dist/utils/sql-parser.js.map +0 -1
  362. package/dist/utils/utils.js.map +0 -1
  363. package/dist/utils/zod-error.js.map +0 -1
  364. package/src/templates/base-template.ts +0 -19
  365. package/src/templates/index.ts +0 -1
@@ -0,0 +1,465 @@
1
+ import inflection from "inflection";
2
+ import * as _ from "lodash-es";
3
+ import { z } from "zod";
4
+ import { EntityManager } from "../../entity/entity-manager.js";
5
+ import { getRelationPropFromColName, getEnumInfoFromColName } from "../helpers.js";
6
+ import { Template } from "../template.js";
7
+ import { zodTypeToRenderingNode, getZodTypeById } from "../zod-converter.js";
8
+ import { getColumnsNode } from "../entity-converter.js";
9
+ export class Template__view_list extends Template {
10
+ constructor(){
11
+ super("view_list");
12
+ }
13
+ getTargetAndPath(names) {
14
+ return {
15
+ target: "web/src/pages/admin",
16
+ path: `${names.fsPlural}/index.tsx`
17
+ };
18
+ }
19
+ wrapTc(body, key, collapsing = true, className = "") {
20
+ return `<Table.Cell key="${key}"${collapsing ? " collapsing" : ""}${className ? ` className={\`${className}\`}` : ""}>${body}</Table.Cell>`;
21
+ }
22
+ renderColumn(entityId, col, names, parentObj = "row", withoutName = false) {
23
+ const colName = withoutName ? `${parentObj}` : `${parentObj}.${col.name}`;
24
+ switch(col.renderType){
25
+ case "string-plain":
26
+ case "string-date":
27
+ case "number-id":
28
+ return `<>{${colName}}</>`;
29
+ case "number-fk_id":
30
+ const relPropFk = getRelationPropFromColName(entityId, col.name.replace("_id", ""));
31
+ return `<>${relPropFk.with}#{${colName}}</>`;
32
+ case "string-image":
33
+ return `<>{${col.nullable ? `${colName} && ` : ""}<img src={${colName}} />}</>`;
34
+ case "datetime":
35
+ if (col.nullable) {
36
+ return `<span className="text-tiny">{${colName} === null ? '-' : formatDateTime(${colName})}</span>`;
37
+ } else {
38
+ return `<span className="text-tiny">{formatDateTime(${colName})}</span>`;
39
+ }
40
+ case "string-datetime":
41
+ if (col.nullable) {
42
+ return `<span className="text-tiny">{${colName} === null ? '-' : dateF(${colName})}</span>`;
43
+ } else {
44
+ return `<span className="text-tiny">{dateF(${colName})}</span>`;
45
+ }
46
+ case "boolean":
47
+ return `<>{${colName} ? <Label color='green' circular>O</Label> : <Label color='grey' circular>X</Label> }</>`;
48
+ case "enums":
49
+ const { id: enumId } = getEnumInfoFromColName(entityId, col.name);
50
+ return `<>{${col.nullable ? `${colName} && ` : ""}${enumId}Label[${colName}]}</>`;
51
+ case "array-images":
52
+ return `<>{ ${colName}.map(r => ${col.nullable ? `r && ` : ""}<img src={r} />) }</>`;
53
+ case "number-plain":
54
+ return `<>{${col.nullable ? `${colName} && ` : ""}numF(${colName})}</>`;
55
+ case "object":
56
+ return `<>{/* object ${colName} */}</>`;
57
+ case "object-pick":
58
+ const pickedChild = col.children.find((child)=>child.name === col.config?.picked);
59
+ if (!pickedChild) {
60
+ throw new Error(`object-pick 선택 실패 (오브젝트: ${col.name})`);
61
+ }
62
+ return this.renderColumn(entityId, pickedChild, names, `${colName}${col.nullable ? "?" : ""}`);
63
+ case "array":
64
+ return `<>{ /* array ${colName} */ }</>`;
65
+ default:
66
+ throw new Error(`렌더 불가 컬럼 ${col.renderType}`);
67
+ }
68
+ }
69
+ renderColumnImport(entityId, col, names) {
70
+ if (col.renderType === "enums") {
71
+ const { id: enumId } = getEnumInfoFromColName(names.capital, col.name);
72
+ return [
73
+ `import { ${enumId}Label } from 'src/services/sonamu.generated';`
74
+ ];
75
+ } else if (col.renderType === "object") {
76
+ try {
77
+ const relProp = getRelationPropFromColName(entityId, col.name);
78
+ const result = col.children.map((child)=>{
79
+ entityId = relProp.with;
80
+ names = EntityManager.getNamesFromId(relProp.with);
81
+ return this.renderColumnImport(entityId, child, names);
82
+ });
83
+ return _.flattenDeep(result);
84
+ } catch {
85
+ return [
86
+ null
87
+ ];
88
+ }
89
+ } else if (col.renderType === "array") {
90
+ return this.renderColumnImport(entityId, col.element, names);
91
+ }
92
+ return [
93
+ null
94
+ ];
95
+ }
96
+ renderFilterImport(entityId, col, names) {
97
+ if (col.name === "search") {
98
+ return `import { ${names.capital}SearchInput } from "src/components/${names.fs}/${names.capital}SearchInput";`;
99
+ } else if (col.renderType === "enums") {
100
+ if (col.name === "orderBy") {
101
+ const componentId = `${names.capital}${inflection.camelize(col.name)}Select`;
102
+ return `import { ${componentId} } from "src/components/${names.fs}/${componentId}";`;
103
+ } else {
104
+ try {
105
+ const { id, targetEntityNames: targetMDNames } = getEnumInfoFromColName(entityId, col.name);
106
+ const componentId = `${id}Select`;
107
+ return `import { ${componentId} } from "src/components/${targetMDNames.fs}/${componentId}";`;
108
+ } catch {
109
+ return "";
110
+ }
111
+ }
112
+ } else if (col.renderType === "number-fk_id") {
113
+ try {
114
+ const relProp = getRelationPropFromColName(entityId, col.name.replace("_id", ""));
115
+ const targetNames = EntityManager.getNamesFromId(relProp.with);
116
+ const componentId = `${relProp.with}IdAsyncSelect`;
117
+ return `import { ${componentId} } from "src/components/${targetNames.fs}/${componentId}";`;
118
+ } catch {
119
+ return "";
120
+ }
121
+ } else {
122
+ throw new Error(`렌더 불가능한 필터 임포트 ${col.name} ${col.renderType}`);
123
+ }
124
+ }
125
+ renderFilter(entityId, col, names) {
126
+ if (col.name === "search") {
127
+ return "";
128
+ }
129
+ const isClearable = col.optional === true && col.name !== "orderBy";
130
+ let componentId;
131
+ if (col.renderType === "enums") {
132
+ if (col.name === "orderBy") {
133
+ componentId = `${names.capital}${inflection.camelize(col.name)}Select`;
134
+ } else {
135
+ try {
136
+ const { id } = getEnumInfoFromColName(entityId, col.name);
137
+ componentId = `${id}Select`;
138
+ } catch {
139
+ return "";
140
+ }
141
+ }
142
+ return `<${componentId} {...register('${col.name}')} ${isClearable ? "clearable" : ""} />`;
143
+ } else if (col.renderType === "number-fk_id") {
144
+ try {
145
+ const relProp = getRelationPropFromColName(entityId, col.name.replace("_id", ""));
146
+ componentId = `${relProp.with}IdAsyncSelect`;
147
+ return `<${componentId} {...register('${col.name}')} ${isClearable ? "clearable" : ""} subset="A" />`;
148
+ } catch {
149
+ return "";
150
+ }
151
+ } else {
152
+ throw new Error(`렌더 불가능한 필터 임포트 ${col.name} ${col.renderType}`);
153
+ }
154
+ }
155
+ getDefault(columns) {
156
+ const def = {
157
+ orderBy: "id-desc",
158
+ search: "title"
159
+ };
160
+ const orderByZodType = columns.find((col)=>col.name === "orderBy")?.zodType;
161
+ if (orderByZodType && orderByZodType instanceof z.ZodEnum) {
162
+ def.orderBy = orderByZodType.options[0].toString();
163
+ }
164
+ const searchZodType = columns.find((col)=>col.name === "search")?.zodType;
165
+ if (searchZodType && searchZodType instanceof z.ZodEnum) {
166
+ def.search = searchZodType.options[0].toString();
167
+ }
168
+ return def;
169
+ }
170
+ async render({ entityId }) {
171
+ const columnsNode = await getColumnsNode(entityId, "A");
172
+ const listParamsZodType = await getZodTypeById(`${entityId}ListParams`);
173
+ const listParamsNode = zodTypeToRenderingNode(listParamsZodType);
174
+ const names = EntityManager.getNamesFromId(entityId);
175
+ const entity = EntityManager.get(entityId);
176
+ // 실제 리스트 컬럼
177
+ const columns = columnsNode.children.filter((col)=>col.name !== "id").map((col)=>{
178
+ const propCandidate = entity.props.find((p)=>p.name === col.name);
179
+ return {
180
+ name: col.name,
181
+ label: propCandidate?.desc ?? col.label,
182
+ tc: `(row) => ${this.renderColumn(entityId, col, names)}`
183
+ };
184
+ });
185
+ // 필터 컬럼
186
+ const filterColumns = listParamsNode.children.filter((col)=>col.name !== "id" && col.name !== "queryMode" && ([
187
+ "enums",
188
+ "number-id"
189
+ ].includes(col.renderType) || col.name.endsWith("_id")))// orderBy가 가장 뒤로 오게 순서 조정
190
+ .sort((a)=>{
191
+ return a.name == "orderBy" ? 1 : -1;
192
+ });
193
+ // 필터 컬럼을 프리 템플릿으로 설정
194
+ const preTemplates = [];
195
+ for (let col of filterColumns){
196
+ let key;
197
+ let targetEntityId = entityId;
198
+ let enumId;
199
+ if (col.renderType === "enums") {
200
+ if (col.name === "search") {
201
+ key = "view_enums_dropdown";
202
+ enumId = `${names.capital}SearchField`;
203
+ targetEntityId = names.capital;
204
+ } else {
205
+ key = "view_enums_select";
206
+ try {
207
+ const { targetEntityNames, id } = getEnumInfoFromColName(entityId, col.name);
208
+ targetEntityId = targetEntityNames.capital;
209
+ enumId = id;
210
+ } catch {
211
+ continue;
212
+ }
213
+ }
214
+ } else {
215
+ key = "view_id_async_select";
216
+ try {
217
+ const relProp = getRelationPropFromColName(entityId, col.name.replace("_id", ""));
218
+ targetEntityId = relProp.with;
219
+ } catch {
220
+ continue;
221
+ }
222
+ }
223
+ preTemplates.push({
224
+ key,
225
+ options: {
226
+ entityId: targetEntityId,
227
+ enumId
228
+ }
229
+ });
230
+ }
231
+ // 리스트 컬럼
232
+ const columnImports = _.uniq(columnsNode.children.map((col)=>{
233
+ return this.renderColumnImport(entityId, col, names);
234
+ }).flat().filter((col)=>col !== null)).join("\n");
235
+ // SearchInput
236
+ preTemplates.push({
237
+ key: "view_search_input",
238
+ options: {
239
+ entityId
240
+ }
241
+ });
242
+ // 디폴트 파라미터
243
+ const def = this.getDefault(filterColumns);
244
+ return {
245
+ ...this.getTargetAndPath(names),
246
+ body: `
247
+ import React from 'react';
248
+ import { Link } from 'react-router-dom';
249
+ import {
250
+ Breadcrumb,
251
+ Checkbox,
252
+ Pagination,
253
+ Segment,
254
+ Table,
255
+ TableRow,
256
+ Message,
257
+ Transition,
258
+ Button,
259
+ Label,
260
+ } from 'semantic-ui-react';
261
+ import classNames from 'classnames';
262
+ import { DateTime } from "luxon";
263
+ import { DelButton, EditButton, AppBreadcrumbs, AddButton, useSelection, useListParams, SonamuCol, numF, formatDate, formatDateTime } from '@sonamu-kit/react-sui';
264
+
265
+ import { ${names.capital}SubsetA } from "src/services/sonamu.generated";
266
+ import { ${names.capital}Service } from 'src/services/${names.fs}/${names.fs}.service';
267
+ import { ${names.capital}ListParams } from 'src/services/${names.fs}/${names.fs}.types';
268
+ ${columnImports}
269
+ ${filterColumns.map((col)=>{
270
+ return this.renderFilterImport(entityId, col, names);
271
+ }).join("\n")}
272
+
273
+ type ${names.capital}ListProps = {};
274
+ export default function ${names.capital}List({}: ${names.capital}ListProps) {
275
+ // 리스트 필터
276
+ const { listParams, register } = useListParams(${names.capital}ListParams, {
277
+ num: 12,
278
+ page: 1,
279
+ orderBy: '${def.orderBy}',
280
+ search: '${def.search}',
281
+ });
282
+
283
+ // 리스트 쿼리
284
+ const { data, mutate, error, isLoading } = ${names.capital}Service.use${names.capitalPlural}('A', listParams);
285
+ const { rows, total } = data ?? {};
286
+
287
+ // 삭제
288
+ const confirmDel = (ids: number[]) => {
289
+ const answer = confirm('삭제하시겠습니까?');
290
+ if (!answer) {
291
+ return;
292
+ }
293
+
294
+ ${names.capital}Service.del(ids).then(() => {
295
+ mutate();
296
+ });
297
+ };
298
+
299
+ // 일괄 삭제
300
+ const confirmDelSelected = () => {
301
+ const answer = confirm(\`\${selectedKeys.length}건을 일괄 삭제하시겠습니까?\`);
302
+ if (!answer) {
303
+ return;
304
+ }
305
+
306
+ ${names.capital}Service.del(selectedKeys).then(() => {
307
+ mutate();
308
+ });
309
+ };
310
+
311
+ // 현재 경로와 타이틀
312
+ const PAGE = {
313
+ route: '/admin/${names.fsPlural}',
314
+ title: '${entity.title ?? names.capital}',
315
+ };
316
+
317
+ // 선택
318
+ const {
319
+ getSelected,
320
+ isAllSelected,
321
+ selectedKeys,
322
+ toggle,
323
+ selectAll,
324
+ deselectAll,
325
+ handleCheckboxClick,
326
+ } = useSelection((rows ?? []).map((row) => row.id));
327
+
328
+ // 컬럼
329
+ const columns:SonamuCol<${names.capital}SubsetA>[] = [${columns.map((col)=>{
330
+ return [
331
+ `{ label: "${col.label}",`,
332
+ `tc: ${col.tc}, `,
333
+ `collapsing: ${[
334
+ "Title",
335
+ "Name"
336
+ ].includes(col.label) === false}, }`
337
+ ].join("\n");
338
+ }).join(",\n")}];
339
+
340
+ return (
341
+ <div className="list ${names.fsPlural}-index">
342
+ <div className="top-nav">
343
+ <div className="header-row">
344
+ <div className="header">{PAGE.title}</div>
345
+ <AppBreadcrumbs>
346
+ <Breadcrumb.Section active>{PAGE.title}</Breadcrumb.Section>
347
+ </AppBreadcrumbs>
348
+ <${names.capital}SearchInput
349
+ input={register('keyword')}
350
+ dropdown={register('search')}
351
+ />
352
+ </div>
353
+ <div className="filters-row">
354
+ ${filterColumns.map((col)=>{
355
+ return this.renderFilter(entityId, col, names);
356
+ }).join("&nbsp;\n")}
357
+ </div>
358
+ </div>
359
+
360
+ <Segment basic padded className="contents-segment" loading={isLoading}>
361
+ <div className="buttons-row">
362
+ <div className={classNames('count', { hidden: isLoading })}>
363
+ {total} 건
364
+ </div>
365
+ <div className="buttons">
366
+ <AddButton currentRoute={PAGE.route} icon="write" label="추가" />
367
+ </div>
368
+ </div>
369
+
370
+ <Table
371
+ celled
372
+ compact
373
+ selectable
374
+ className={classNames({ hidden: total === undefined || total === 0 })}
375
+ >
376
+ <Table.Header>
377
+ <TableRow>
378
+ <Table.HeaderCell collapsing>
379
+ <Checkbox
380
+ label="ID"
381
+ checked={isAllSelected}
382
+ onChange={isAllSelected ? deselectAll : selectAll}
383
+ />
384
+ </Table.HeaderCell>
385
+ {
386
+ /* Header */
387
+ columns.map((col, index) => col.th ?? <Table.HeaderCell key={index} collapsing={col.collapsing}>{ col.label }</Table.HeaderCell>)
388
+ }
389
+ <Table.HeaderCell>관리</Table.HeaderCell>
390
+ </TableRow>
391
+ </Table.Header>
392
+ <Table.Body>
393
+ {rows &&
394
+ rows.map((row, rowIndex) => (
395
+ <Table.Row key={row.id}>
396
+ <Table.Cell>
397
+ <Checkbox
398
+ label={row.id}
399
+ checked={getSelected(row.id)}
400
+ onChange={() => toggle(row.id)}
401
+ onClick={(e) =>
402
+ handleCheckboxClick(e, rowIndex)
403
+ }
404
+ />
405
+ </Table.Cell>
406
+ {
407
+ /* Body */
408
+ columns.map((col, colIndex) => (
409
+ <Table.Cell key={colIndex} collapsing={col.collapsing} className={col.className}>
410
+ {col.tc(row, rowIndex)}
411
+ </Table.Cell>
412
+ ))
413
+ }
414
+ <Table.Cell collapsing>
415
+ <EditButton
416
+ as={Link}
417
+ to={\`\${PAGE.route}/form?id=\${row.id}\`}
418
+ state={{ from: PAGE.route }}
419
+ />
420
+ <DelButton onClick={() => confirmDel([row.id])} />
421
+ </Table.Cell>
422
+ </Table.Row>
423
+ ))}
424
+ </Table.Body>
425
+ </Table>
426
+ <div
427
+ className={classNames('pagination-row', {
428
+ hidden: (total ?? 0) === 0,
429
+ })}
430
+ >
431
+ <Pagination
432
+ totalPages={Math.ceil((total ?? 0) / (listParams.num ?? 24))}
433
+ {...register('page')}
434
+ />
435
+ </div>
436
+ </Segment>
437
+
438
+ <div className="fixed-menu">
439
+ <Transition
440
+ visible={selectedKeys.length > 0}
441
+ animation="slide left"
442
+ duration={500}
443
+ >
444
+ <Message size="small" color="violet" className="text-center">
445
+ <span className="px-4">{selectedKeys.length}개 선택됨</span>
446
+ <Button size="tiny" color="violet" onClick={() => deselectAll()}>
447
+ 선택 해제
448
+ </Button>
449
+ <Button size="tiny" color="red" onClick={confirmDelSelected}>
450
+ 일괄 삭제
451
+ </Button>
452
+ </Message>
453
+ </Transition>
454
+ </div>
455
+ </div>
456
+ );
457
+ }
458
+ `.trim(),
459
+ importKeys: [],
460
+ preTemplates
461
+ };
462
+ }
463
+ }
464
+
465
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90ZW1wbGF0ZS9pbXBsZW1lbnRhdGlvbnMvdmlld19saXN0LnRlbXBsYXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBpbmZsZWN0aW9uIGZyb20gXCJpbmZsZWN0aW9uXCI7XG5pbXBvcnQgKiBhcyBfIGZyb20gXCJsb2Rhc2gtZXNcIjtcbmltcG9ydCB7IHogfSBmcm9tIFwiem9kXCI7XG5pbXBvcnQgeyBSZW5kZXJpbmdOb2RlLCBUZW1wbGF0ZUtleSwgVGVtcGxhdGVPcHRpb25zIH0gZnJvbSBcIi4uLy4uL3R5cGVzL3R5cGVzXCI7XG5pbXBvcnQgeyBFbnRpdHlNYW5hZ2VyLCBFbnRpdHlOYW1lc1JlY29yZCB9IGZyb20gXCIuLi8uLi9lbnRpdHkvZW50aXR5LW1hbmFnZXJcIjtcbmltcG9ydCB7IGdldFJlbGF0aW9uUHJvcEZyb21Db2xOYW1lLCBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lIH0gZnJvbSBcIi4uL2hlbHBlcnNcIjtcbmltcG9ydCB7IFJlbmRlcmVkVGVtcGxhdGUgfSBmcm9tIFwiLi4vdGVtcGxhdGVcIjtcbmltcG9ydCB7IFRlbXBsYXRlIH0gZnJvbSBcIi4uL3RlbXBsYXRlXCI7XG5pbXBvcnQgeyB6b2RUeXBlVG9SZW5kZXJpbmdOb2RlLCBnZXRab2RUeXBlQnlJZCB9IGZyb20gXCIuLi96b2QtY29udmVydGVyXCI7XG5pbXBvcnQgeyBnZXRDb2x1bW5zTm9kZSB9IGZyb20gXCIuLi9lbnRpdHktY29udmVydGVyXCI7XG5cbmV4cG9ydCBjbGFzcyBUZW1wbGF0ZV9fdmlld19saXN0IGV4dGVuZHMgVGVtcGxhdGUge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcihcInZpZXdfbGlzdFwiKTtcbiAgfVxuXG4gIGdldFRhcmdldEFuZFBhdGgobmFtZXM6IEVudGl0eU5hbWVzUmVjb3JkKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHRhcmdldDogXCJ3ZWIvc3JjL3BhZ2VzL2FkbWluXCIsXG4gICAgICBwYXRoOiBgJHtuYW1lcy5mc1BsdXJhbH0vaW5kZXgudHN4YCxcbiAgICB9O1xuICB9XG5cbiAgd3JhcFRjKFxuICAgIGJvZHk6IHN0cmluZyxcbiAgICBrZXk6IHN0cmluZyxcbiAgICBjb2xsYXBzaW5nOiBib29sZWFuID0gdHJ1ZSxcbiAgICBjbGFzc05hbWU6IHN0cmluZyA9IFwiXCJcbiAgKSB7XG4gICAgcmV0dXJuIGA8VGFibGUuQ2VsbCBrZXk9XCIke2tleX1cIiR7Y29sbGFwc2luZyA/IFwiIGNvbGxhcHNpbmdcIiA6IFwiXCJ9JHtcbiAgICAgIGNsYXNzTmFtZSA/IGAgY2xhc3NOYW1lPXtcXGAke2NsYXNzTmFtZX1cXGB9YCA6IFwiXCJcbiAgICB9PiR7Ym9keX08L1RhYmxlLkNlbGw+YDtcbiAgfVxuXG4gIHJlbmRlckNvbHVtbihcbiAgICBlbnRpdHlJZDogc3RyaW5nLFxuICAgIGNvbDogUmVuZGVyaW5nTm9kZSxcbiAgICBuYW1lczogRW50aXR5TmFtZXNSZWNvcmQsXG4gICAgcGFyZW50T2JqOiBzdHJpbmcgPSBcInJvd1wiLFxuICAgIHdpdGhvdXROYW1lOiBib29sZWFuID0gZmFsc2VcbiAgKTogc3RyaW5nIHtcbiAgICBjb25zdCBjb2xOYW1lID0gd2l0aG91dE5hbWUgPyBgJHtwYXJlbnRPYmp9YCA6IGAke3BhcmVudE9ian0uJHtjb2wubmFtZX1gO1xuXG4gICAgc3dpdGNoIChjb2wucmVuZGVyVHlwZSkge1xuICAgICAgY2FzZSBcInN0cmluZy1wbGFpblwiOlxuICAgICAgY2FzZSBcInN0cmluZy1kYXRlXCI6XG4gICAgICBjYXNlIFwibnVtYmVyLWlkXCI6XG4gICAgICAgIHJldHVybiBgPD57JHtjb2xOYW1lfX08Lz5gO1xuICAgICAgY2FzZSBcIm51bWJlci1ma19pZFwiOlxuICAgICAgICBjb25zdCByZWxQcm9wRmsgPSBnZXRSZWxhdGlvblByb3BGcm9tQ29sTmFtZShcbiAgICAgICAgICBlbnRpdHlJZCxcbiAgICAgICAgICBjb2wubmFtZS5yZXBsYWNlKFwiX2lkXCIsIFwiXCIpXG4gICAgICAgICk7XG4gICAgICAgIHJldHVybiBgPD4ke3JlbFByb3BGay53aXRofSN7JHtjb2xOYW1lfX08Lz5gO1xuICAgICAgY2FzZSBcInN0cmluZy1pbWFnZVwiOlxuICAgICAgICByZXR1cm4gYDw+eyR7XG4gICAgICAgICAgY29sLm51bGxhYmxlID8gYCR7Y29sTmFtZX0gJiYgYCA6IFwiXCJcbiAgICAgICAgfTxpbWcgc3JjPXske2NvbE5hbWV9fSAvPn08Lz5gO1xuICAgICAgY2FzZSBcImRhdGV0aW1lXCI6XG4gICAgICAgIGlmIChjb2wubnVsbGFibGUpIHtcbiAgICAgICAgICByZXR1cm4gYDxzcGFuIGNsYXNzTmFtZT1cInRleHQtdGlueVwiPnske2NvbE5hbWV9ID09PSBudWxsID8gJy0nIDogZm9ybWF0RGF0ZVRpbWUoJHtjb2xOYW1lfSl9PC9zcGFuPmA7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcmV0dXJuIGA8c3BhbiBjbGFzc05hbWU9XCJ0ZXh0LXRpbnlcIj57Zm9ybWF0RGF0ZVRpbWUoJHtjb2xOYW1lfSl9PC9zcGFuPmA7XG4gICAgICAgIH1cbiAgICAgIGNhc2UgXCJzdHJpbmctZGF0ZXRpbWVcIjpcbiAgICAgICAgaWYgKGNvbC5udWxsYWJsZSkge1xuICAgICAgICAgIHJldHVybiBgPHNwYW4gY2xhc3NOYW1lPVwidGV4dC10aW55XCI+eyR7Y29sTmFtZX0gPT09IG51bGwgPyAnLScgOiBkYXRlRigke2NvbE5hbWV9KX08L3NwYW4+YDtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXR1cm4gYDxzcGFuIGNsYXNzTmFtZT1cInRleHQtdGlueVwiPntkYXRlRigke2NvbE5hbWV9KX08L3NwYW4+YDtcbiAgICAgICAgfVxuICAgICAgY2FzZSBcImJvb2xlYW5cIjpcbiAgICAgICAgcmV0dXJuIGA8Pnske2NvbE5hbWV9ID8gPExhYmVsIGNvbG9yPSdncmVlbicgY2lyY3VsYXI+TzwvTGFiZWw+IDogPExhYmVsIGNvbG9yPSdncmV5JyBjaXJjdWxhcj5YPC9MYWJlbD4gfTwvPmA7XG4gICAgICBjYXNlIFwiZW51bXNcIjpcbiAgICAgICAgY29uc3QgeyBpZDogZW51bUlkIH0gPSBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lKGVudGl0eUlkLCBjb2wubmFtZSk7XG4gICAgICAgIHJldHVybiBgPD57JHtcbiAgICAgICAgICBjb2wubnVsbGFibGUgPyBgJHtjb2xOYW1lfSAmJiBgIDogXCJcIlxuICAgICAgICB9JHtlbnVtSWR9TGFiZWxbJHtjb2xOYW1lfV19PC8+YDtcbiAgICAgIGNhc2UgXCJhcnJheS1pbWFnZXNcIjpcbiAgICAgICAgcmV0dXJuIGA8PnsgJHtjb2xOYW1lfS5tYXAociA9PiAke1xuICAgICAgICAgIGNvbC5udWxsYWJsZSA/IGByICYmIGAgOiBcIlwiXG4gICAgICAgIH08aW1nIHNyYz17cn0gLz4pIH08Lz5gO1xuICAgICAgY2FzZSBcIm51bWJlci1wbGFpblwiOlxuICAgICAgICByZXR1cm4gYDw+eyR7Y29sLm51bGxhYmxlID8gYCR7Y29sTmFtZX0gJiYgYCA6IFwiXCJ9bnVtRigke2NvbE5hbWV9KX08Lz5gO1xuICAgICAgY2FzZSBcIm9iamVjdFwiOlxuICAgICAgICByZXR1cm4gYDw+ey8qIG9iamVjdCAke2NvbE5hbWV9ICovfTwvPmA7XG4gICAgICBjYXNlIFwib2JqZWN0LXBpY2tcIjpcbiAgICAgICAgY29uc3QgcGlja2VkQ2hpbGQgPSBjb2wuY2hpbGRyZW4hLmZpbmQoXG4gICAgICAgICAgKGNoaWxkKSA9PiBjaGlsZC5uYW1lID09PSBjb2wuY29uZmlnPy5waWNrZWRcbiAgICAgICAgKTtcbiAgICAgICAgaWYgKCFwaWNrZWRDaGlsZCkge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgb2JqZWN0LXBpY2sg7ISg7YOdIOyLpO2MqCAo7Jik67iM7KCd7Yq4OiAke2NvbC5uYW1lfSlgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcy5yZW5kZXJDb2x1bW4oXG4gICAgICAgICAgZW50aXR5SWQsXG4gICAgICAgICAgcGlja2VkQ2hpbGQsXG4gICAgICAgICAgbmFtZXMsXG4gICAgICAgICAgYCR7Y29sTmFtZX0ke2NvbC5udWxsYWJsZSA/IFwiP1wiIDogXCJcIn1gXG4gICAgICAgICk7XG4gICAgICBjYXNlIFwiYXJyYXlcIjpcbiAgICAgICAgcmV0dXJuIGA8PnsgLyogYXJyYXkgJHtjb2xOYW1lfSAqLyB9PC8+YDtcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihg66CM642UIOu2iOqwgCDsu6zrn7wgJHtjb2wucmVuZGVyVHlwZX1gKTtcbiAgICB9XG4gIH1cblxuICByZW5kZXJDb2x1bW5JbXBvcnQoXG4gICAgZW50aXR5SWQ6IHN0cmluZyxcbiAgICBjb2w6IFJlbmRlcmluZ05vZGUsXG4gICAgbmFtZXM6IEVudGl0eU5hbWVzUmVjb3JkXG4gICk6IChzdHJpbmcgfCBudWxsKVtdIHtcbiAgICBpZiAoY29sLnJlbmRlclR5cGUgPT09IFwiZW51bXNcIikge1xuICAgICAgY29uc3QgeyBpZDogZW51bUlkIH0gPSBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lKG5hbWVzLmNhcGl0YWwsIGNvbC5uYW1lKTtcbiAgICAgIHJldHVybiBbXG4gICAgICAgIGBpbXBvcnQgeyAke2VudW1JZH1MYWJlbCB9IGZyb20gJ3NyYy9zZXJ2aWNlcy9zb25hbXUuZ2VuZXJhdGVkJztgLFxuICAgICAgXTtcbiAgICB9IGVsc2UgaWYgKGNvbC5yZW5kZXJUeXBlID09PSBcIm9iamVjdFwiKSB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByZWxQcm9wID0gZ2V0UmVsYXRpb25Qcm9wRnJvbUNvbE5hbWUoZW50aXR5SWQsIGNvbC5uYW1lKTtcbiAgICAgICAgY29uc3QgcmVzdWx0ID0gY29sLmNoaWxkcmVuIS5tYXAoKGNoaWxkKSA9PiB7XG4gICAgICAgICAgZW50aXR5SWQgPSByZWxQcm9wLndpdGg7XG4gICAgICAgICAgbmFtZXMgPSBFbnRpdHlNYW5hZ2VyLmdldE5hbWVzRnJvbUlkKHJlbFByb3Aud2l0aCk7XG4gICAgICAgICAgcmV0dXJuIHRoaXMucmVuZGVyQ29sdW1uSW1wb3J0KGVudGl0eUlkLCBjaGlsZCwgbmFtZXMpO1xuICAgICAgICB9KTtcbiAgICAgICAgcmV0dXJuIF8uZmxhdHRlbkRlZXAocmVzdWx0KTtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICByZXR1cm4gW251bGxdO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAoY29sLnJlbmRlclR5cGUgPT09IFwiYXJyYXlcIikge1xuICAgICAgcmV0dXJuIHRoaXMucmVuZGVyQ29sdW1uSW1wb3J0KGVudGl0eUlkLCBjb2wuZWxlbWVudCEsIG5hbWVzKTtcbiAgICB9XG5cbiAgICByZXR1cm4gW251bGxdO1xuICB9XG5cbiAgcmVuZGVyRmlsdGVySW1wb3J0KFxuICAgIGVudGl0eUlkOiBzdHJpbmcsXG4gICAgY29sOiBSZW5kZXJpbmdOb2RlLFxuICAgIG5hbWVzOiBFbnRpdHlOYW1lc1JlY29yZFxuICApIHtcbiAgICBpZiAoY29sLm5hbWUgPT09IFwic2VhcmNoXCIpIHtcbiAgICAgIHJldHVybiBgaW1wb3J0IHsgJHtuYW1lcy5jYXBpdGFsfVNlYXJjaElucHV0IH0gZnJvbSBcInNyYy9jb21wb25lbnRzLyR7bmFtZXMuZnN9LyR7bmFtZXMuY2FwaXRhbH1TZWFyY2hJbnB1dFwiO2A7XG4gICAgfSBlbHNlIGlmIChjb2wucmVuZGVyVHlwZSA9PT0gXCJlbnVtc1wiKSB7XG4gICAgICBpZiAoY29sLm5hbWUgPT09IFwib3JkZXJCeVwiKSB7XG4gICAgICAgIGNvbnN0IGNvbXBvbmVudElkID0gYCR7bmFtZXMuY2FwaXRhbH0ke2luZmxlY3Rpb24uY2FtZWxpemUoXG4gICAgICAgICAgY29sLm5hbWVcbiAgICAgICAgKX1TZWxlY3RgO1xuICAgICAgICByZXR1cm4gYGltcG9ydCB7ICR7Y29tcG9uZW50SWR9IH0gZnJvbSBcInNyYy9jb21wb25lbnRzLyR7bmFtZXMuZnN9LyR7Y29tcG9uZW50SWR9XCI7YDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgeyBpZCwgdGFyZ2V0RW50aXR5TmFtZXM6IHRhcmdldE1ETmFtZXMgfSA9XG4gICAgICAgICAgICBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lKGVudGl0eUlkLCBjb2wubmFtZSk7XG4gICAgICAgICAgY29uc3QgY29tcG9uZW50SWQgPSBgJHtpZH1TZWxlY3RgO1xuICAgICAgICAgIHJldHVybiBgaW1wb3J0IHsgJHtjb21wb25lbnRJZH0gfSBmcm9tIFwic3JjL2NvbXBvbmVudHMvJHt0YXJnZXRNRE5hbWVzLmZzfS8ke2NvbXBvbmVudElkfVwiO2A7XG4gICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgIHJldHVybiBcIlwiO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIGlmIChjb2wucmVuZGVyVHlwZSA9PT0gXCJudW1iZXItZmtfaWRcIikge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgcmVsUHJvcCA9IGdldFJlbGF0aW9uUHJvcEZyb21Db2xOYW1lKFxuICAgICAgICAgIGVudGl0eUlkLFxuICAgICAgICAgIGNvbC5uYW1lLnJlcGxhY2UoXCJfaWRcIiwgXCJcIilcbiAgICAgICAgKTtcbiAgICAgICAgY29uc3QgdGFyZ2V0TmFtZXMgPSBFbnRpdHlNYW5hZ2VyLmdldE5hbWVzRnJvbUlkKHJlbFByb3Aud2l0aCk7XG4gICAgICAgIGNvbnN0IGNvbXBvbmVudElkID0gYCR7cmVsUHJvcC53aXRofUlkQXN5bmNTZWxlY3RgO1xuICAgICAgICByZXR1cm4gYGltcG9ydCB7ICR7Y29tcG9uZW50SWR9IH0gZnJvbSBcInNyYy9jb21wb25lbnRzLyR7dGFyZ2V0TmFtZXMuZnN9LyR7Y29tcG9uZW50SWR9XCI7YDtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICByZXR1cm4gXCJcIjtcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBg66CM642UIOu2iOqwgOuKpe2VnCDtlYTthLAg7J6E7Y+s7Yq4ICR7Y29sLm5hbWV9ICR7Y29sLnJlbmRlclR5cGV9YFxuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICByZW5kZXJGaWx0ZXIoZW50aXR5SWQ6IHN0cmluZywgY29sOiBSZW5kZXJpbmdOb2RlLCBuYW1lczogRW50aXR5TmFtZXNSZWNvcmQpIHtcbiAgICBpZiAoY29sLm5hbWUgPT09IFwic2VhcmNoXCIpIHtcbiAgICAgIHJldHVybiBcIlwiO1xuICAgIH1cblxuICAgIGNvbnN0IGlzQ2xlYXJhYmxlID0gY29sLm9wdGlvbmFsID09PSB0cnVlICYmIGNvbC5uYW1lICE9PSBcIm9yZGVyQnlcIjtcbiAgICBsZXQgY29tcG9uZW50SWQ6IHN0cmluZztcbiAgICBpZiAoY29sLnJlbmRlclR5cGUgPT09IFwiZW51bXNcIikge1xuICAgICAgaWYgKGNvbC5uYW1lID09PSBcIm9yZGVyQnlcIikge1xuICAgICAgICBjb21wb25lbnRJZCA9IGAke25hbWVzLmNhcGl0YWx9JHtpbmZsZWN0aW9uLmNhbWVsaXplKGNvbC5uYW1lKX1TZWxlY3RgO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCB7IGlkIH0gPSBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lKGVudGl0eUlkLCBjb2wubmFtZSk7XG4gICAgICAgICAgY29tcG9uZW50SWQgPSBgJHtpZH1TZWxlY3RgO1xuICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICByZXR1cm4gXCJcIjtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuIGA8JHtjb21wb25lbnRJZH0gey4uLnJlZ2lzdGVyKCcke2NvbC5uYW1lfScpfSAke1xuICAgICAgICBpc0NsZWFyYWJsZSA/IFwiY2xlYXJhYmxlXCIgOiBcIlwiXG4gICAgICB9IC8+YDtcbiAgICB9IGVsc2UgaWYgKGNvbC5yZW5kZXJUeXBlID09PSBcIm51bWJlci1ma19pZFwiKSB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByZWxQcm9wID0gZ2V0UmVsYXRpb25Qcm9wRnJvbUNvbE5hbWUoXG4gICAgICAgICAgZW50aXR5SWQsXG4gICAgICAgICAgY29sLm5hbWUucmVwbGFjZShcIl9pZFwiLCBcIlwiKVxuICAgICAgICApO1xuICAgICAgICBjb21wb25lbnRJZCA9IGAke3JlbFByb3Aud2l0aH1JZEFzeW5jU2VsZWN0YDtcbiAgICAgICAgcmV0dXJuIGA8JHtjb21wb25lbnRJZH0gey4uLnJlZ2lzdGVyKCcke2NvbC5uYW1lfScpfSAke1xuICAgICAgICAgIGlzQ2xlYXJhYmxlID8gXCJjbGVhcmFibGVcIiA6IFwiXCJcbiAgICAgICAgfSBzdWJzZXQ9XCJBXCIgLz5gO1xuICAgICAgfSBjYXRjaCB7XG4gICAgICAgIHJldHVybiBcIlwiO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGDroIzrjZQg67aI6rCA64ql7ZWcIO2VhO2EsCDsnoTtj6ztirggJHtjb2wubmFtZX0gJHtjb2wucmVuZGVyVHlwZX1gXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIGdldERlZmF1bHQoY29sdW1uczogUmVuZGVyaW5nTm9kZVtdKToge1xuICAgIG9yZGVyQnk6IHN0cmluZztcbiAgICBzZWFyY2g6IHN0cmluZztcbiAgfSB7XG4gICAgY29uc3QgZGVmID0ge1xuICAgICAgb3JkZXJCeTogXCJpZC1kZXNjXCIsXG4gICAgICBzZWFyY2g6IFwidGl0bGVcIixcbiAgICB9O1xuICAgIGNvbnN0IG9yZGVyQnlab2RUeXBlID0gY29sdW1ucy5maW5kKFxuICAgICAgKGNvbCkgPT4gY29sLm5hbWUgPT09IFwib3JkZXJCeVwiXG4gICAgKT8uem9kVHlwZTtcbiAgICBpZiAob3JkZXJCeVpvZFR5cGUgJiYgb3JkZXJCeVpvZFR5cGUgaW5zdGFuY2VvZiB6LlpvZEVudW0pIHtcbiAgICAgIGRlZi5vcmRlckJ5ID0gb3JkZXJCeVpvZFR5cGUub3B0aW9uc1swXS50b1N0cmluZygpO1xuICAgIH1cbiAgICBjb25zdCBzZWFyY2hab2RUeXBlID0gY29sdW1ucy5maW5kKChjb2wpID0+IGNvbC5uYW1lID09PSBcInNlYXJjaFwiKT8uem9kVHlwZTtcbiAgICBpZiAoc2VhcmNoWm9kVHlwZSAmJiBzZWFyY2hab2RUeXBlIGluc3RhbmNlb2Ygei5ab2RFbnVtKSB7XG4gICAgICBkZWYuc2VhcmNoID0gc2VhcmNoWm9kVHlwZS5vcHRpb25zWzBdLnRvU3RyaW5nKCk7XG4gICAgfVxuICAgIHJldHVybiBkZWY7XG4gIH1cblxuICBhc3luYyByZW5kZXIoeyBlbnRpdHlJZCB9OiBUZW1wbGF0ZU9wdGlvbnNbXCJ2aWV3X2xpc3RcIl0pIHtcbiAgICBjb25zdCBjb2x1bW5zTm9kZSA9IGF3YWl0IGdldENvbHVtbnNOb2RlKGVudGl0eUlkLCBcIkFcIik7XG4gICAgY29uc3QgbGlzdFBhcmFtc1pvZFR5cGUgPSBhd2FpdCBnZXRab2RUeXBlQnlJZChgJHtlbnRpdHlJZH1MaXN0UGFyYW1zYCk7XG4gICAgY29uc3QgbGlzdFBhcmFtc05vZGUgPSB6b2RUeXBlVG9SZW5kZXJpbmdOb2RlKGxpc3RQYXJhbXNab2RUeXBlKTtcblxuICAgIGNvbnN0IG5hbWVzID0gRW50aXR5TWFuYWdlci5nZXROYW1lc0Zyb21JZChlbnRpdHlJZCk7XG4gICAgY29uc3QgZW50aXR5ID0gRW50aXR5TWFuYWdlci5nZXQoZW50aXR5SWQpO1xuXG4gICAgLy8g7Iuk7KCcIOumrOyKpO2KuCDsu6zrn7xcbiAgICBjb25zdCBjb2x1bW5zID0gKGNvbHVtbnNOb2RlLmNoaWxkcmVuIGFzIFJlbmRlcmluZ05vZGVbXSlcbiAgICAgIC5maWx0ZXIoKGNvbCkgPT4gY29sLm5hbWUgIT09IFwiaWRcIilcbiAgICAgIC5tYXAoKGNvbCkgPT4ge1xuICAgICAgICBjb25zdCBwcm9wQ2FuZGlkYXRlID0gZW50aXR5LnByb3BzLmZpbmQoKHApID0+IHAubmFtZSA9PT0gY29sLm5hbWUpO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIG5hbWU6IGNvbC5uYW1lLFxuICAgICAgICAgIGxhYmVsOiBwcm9wQ2FuZGlkYXRlPy5kZXNjID8/IGNvbC5sYWJlbCxcbiAgICAgICAgICB0YzogYChyb3cpID0+ICR7dGhpcy5yZW5kZXJDb2x1bW4oZW50aXR5SWQsIGNvbCwgbmFtZXMpfWAsXG4gICAgICAgIH07XG4gICAgICB9KTtcblxuICAgIC8vIO2VhO2EsCDsu6zrn7xcbiAgICBjb25zdCBmaWx0ZXJDb2x1bW5zID0gKGxpc3RQYXJhbXNOb2RlLmNoaWxkcmVuIGFzIFJlbmRlcmluZ05vZGVbXSlcbiAgICAgIC5maWx0ZXIoXG4gICAgICAgIChjb2wpID0+XG4gICAgICAgICAgY29sLm5hbWUgIT09IFwiaWRcIiAmJlxuICAgICAgICAgIGNvbC5uYW1lICE9PSBcInF1ZXJ5TW9kZVwiICYmXG4gICAgICAgICAgKFtcImVudW1zXCIsIFwibnVtYmVyLWlkXCJdLmluY2x1ZGVzKGNvbC5yZW5kZXJUeXBlKSB8fFxuICAgICAgICAgICAgY29sLm5hbWUuZW5kc1dpdGgoXCJfaWRcIikpXG4gICAgICApXG4gICAgICAvLyBvcmRlckJ56rCAIOqwgOyepSDrkqTroZwg7Jik6rKMIOyInOyEnCDsobDsoJVcbiAgICAgIC5zb3J0KChhKSA9PiB7XG4gICAgICAgIHJldHVybiBhLm5hbWUgPT0gXCJvcmRlckJ5XCIgPyAxIDogLTE7XG4gICAgICB9KTtcblxuICAgIC8vIO2VhO2EsCDsu6zrn7zsnYQg7ZSE66asIO2FnO2UjOumv+ycvOuhnCDshKTsoJVcbiAgICBjb25zdCBwcmVUZW1wbGF0ZXM6IFJlbmRlcmVkVGVtcGxhdGVbXCJwcmVUZW1wbGF0ZXNcIl0gPSBbXTtcbiAgICBmb3IgKGxldCBjb2wgb2YgZmlsdGVyQ29sdW1ucykge1xuICAgICAgbGV0IGtleTogVGVtcGxhdGVLZXk7XG4gICAgICBsZXQgdGFyZ2V0RW50aXR5SWQgPSBlbnRpdHlJZDtcbiAgICAgIGxldCBlbnVtSWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICAgICAgaWYgKGNvbC5yZW5kZXJUeXBlID09PSBcImVudW1zXCIpIHtcbiAgICAgICAgaWYgKGNvbC5uYW1lID09PSBcInNlYXJjaFwiKSB7XG4gICAgICAgICAga2V5ID0gXCJ2aWV3X2VudW1zX2Ryb3Bkb3duXCI7XG4gICAgICAgICAgZW51bUlkID0gYCR7bmFtZXMuY2FwaXRhbH1TZWFyY2hGaWVsZGA7XG4gICAgICAgICAgdGFyZ2V0RW50aXR5SWQgPSBuYW1lcy5jYXBpdGFsO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGtleSA9IFwidmlld19lbnVtc19zZWxlY3RcIjtcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgY29uc3QgeyB0YXJnZXRFbnRpdHlOYW1lcywgaWQgfSA9IGdldEVudW1JbmZvRnJvbUNvbE5hbWUoXG4gICAgICAgICAgICAgIGVudGl0eUlkLFxuICAgICAgICAgICAgICBjb2wubmFtZVxuICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIHRhcmdldEVudGl0eUlkID0gdGFyZ2V0RW50aXR5TmFtZXMuY2FwaXRhbDtcbiAgICAgICAgICAgIGVudW1JZCA9IGlkO1xuICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBrZXkgPSBcInZpZXdfaWRfYXN5bmNfc2VsZWN0XCI7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgcmVsUHJvcCA9IGdldFJlbGF0aW9uUHJvcEZyb21Db2xOYW1lKFxuICAgICAgICAgICAgZW50aXR5SWQsXG4gICAgICAgICAgICBjb2wubmFtZS5yZXBsYWNlKFwiX2lkXCIsIFwiXCIpXG4gICAgICAgICAgKTtcbiAgICAgICAgICB0YXJnZXRFbnRpdHlJZCA9IHJlbFByb3Aud2l0aDtcbiAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgY29udGludWU7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgcHJlVGVtcGxhdGVzLnB1c2goe1xuICAgICAgICBrZXksXG4gICAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgICBlbnRpdHlJZDogdGFyZ2V0RW50aXR5SWQsXG4gICAgICAgICAgZW51bUlkLFxuICAgICAgICB9LFxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgLy8g66as7Iqk7Yq4IOy7rOufvFxuICAgIGNvbnN0IGNvbHVtbkltcG9ydHMgPSBfLnVuaXEoXG4gICAgICBjb2x1bW5zTm9kZVxuICAgICAgICAuY2hpbGRyZW4hLm1hcCgoY29sKSA9PiB7XG4gICAgICAgICAgcmV0dXJuIHRoaXMucmVuZGVyQ29sdW1uSW1wb3J0KGVudGl0eUlkLCBjb2wsIG5hbWVzKTtcbiAgICAgICAgfSlcbiAgICAgICAgLmZsYXQoKVxuICAgICAgICAuZmlsdGVyKChjb2wpID0+IGNvbCAhPT0gbnVsbClcbiAgICApLmpvaW4oXCJcXG5cIik7XG5cbiAgICAvLyBTZWFyY2hJbnB1dFxuICAgIHByZVRlbXBsYXRlcyEucHVzaCh7XG4gICAgICBrZXk6IFwidmlld19zZWFyY2hfaW5wdXRcIixcbiAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgZW50aXR5SWQsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgLy8g65SU7Y+07Yq4IO2MjOudvOuvuO2EsFxuICAgIGNvbnN0IGRlZiA9IHRoaXMuZ2V0RGVmYXVsdChmaWx0ZXJDb2x1bW5zKTtcblxuICAgIHJldHVybiB7XG4gICAgICAuLi50aGlzLmdldFRhcmdldEFuZFBhdGgobmFtZXMpLFxuICAgICAgYm9keTogYFxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7XG4gIEJyZWFkY3J1bWIsXG4gIENoZWNrYm94LFxuICBQYWdpbmF0aW9uLFxuICBTZWdtZW50LFxuICBUYWJsZSxcbiAgVGFibGVSb3csXG4gIE1lc3NhZ2UsXG4gIFRyYW5zaXRpb24sXG4gIEJ1dHRvbixcbiAgTGFiZWwsXG59IGZyb20gJ3NlbWFudGljLXVpLXJlYWN0JztcbmltcG9ydCBjbGFzc05hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuaW1wb3J0IHsgRGF0ZVRpbWUgfSBmcm9tIFwibHV4b25cIjtcbmltcG9ydCB7IERlbEJ1dHRvbiwgRWRpdEJ1dHRvbiwgQXBwQnJlYWRjcnVtYnMsIEFkZEJ1dHRvbiwgdXNlU2VsZWN0aW9uLCB1c2VMaXN0UGFyYW1zLCBTb25hbXVDb2wsIG51bUYsIGZvcm1hdERhdGUsIGZvcm1hdERhdGVUaW1lIH0gZnJvbSAnQHNvbmFtdS1raXQvcmVhY3Qtc3VpJztcblxuaW1wb3J0IHsgJHtuYW1lcy5jYXBpdGFsfVN1YnNldEEgfSBmcm9tIFwic3JjL3NlcnZpY2VzL3NvbmFtdS5nZW5lcmF0ZWRcIjtcbmltcG9ydCB7ICR7bmFtZXMuY2FwaXRhbH1TZXJ2aWNlIH0gZnJvbSAnc3JjL3NlcnZpY2VzLyR7bmFtZXMuZnN9LyR7XG4gICAgICAgIG5hbWVzLmZzXG4gICAgICB9LnNlcnZpY2UnO1xuaW1wb3J0IHsgJHtuYW1lcy5jYXBpdGFsfUxpc3RQYXJhbXMgfSBmcm9tICdzcmMvc2VydmljZXMvJHtuYW1lcy5mc30vJHtcbiAgICAgICAgbmFtZXMuZnNcbiAgICAgIH0udHlwZXMnO1xuJHtjb2x1bW5JbXBvcnRzfVxuJHtmaWx0ZXJDb2x1bW5zXG4gIC5tYXAoKGNvbCkgPT4ge1xuICAgIHJldHVybiB0aGlzLnJlbmRlckZpbHRlckltcG9ydChlbnRpdHlJZCwgY29sLCBuYW1lcyk7XG4gIH0pXG4gIC5qb2luKFwiXFxuXCIpfVxuXG50eXBlICR7bmFtZXMuY2FwaXRhbH1MaXN0UHJvcHMgPSB7fTtcbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uICR7bmFtZXMuY2FwaXRhbH1MaXN0KHt9OiAke25hbWVzLmNhcGl0YWx9TGlzdFByb3BzKSB7XG4gIC8vIOumrOyKpO2KuCDtlYTthLBcbiAgY29uc3QgeyBsaXN0UGFyYW1zLCByZWdpc3RlciB9ID0gdXNlTGlzdFBhcmFtcygke25hbWVzLmNhcGl0YWx9TGlzdFBhcmFtcywge1xuICAgIG51bTogMTIsXG4gICAgcGFnZTogMSxcbiAgICBvcmRlckJ5OiAnJHtkZWYub3JkZXJCeX0nLFxuICAgIHNlYXJjaDogJyR7ZGVmLnNlYXJjaH0nLFxuICB9KTtcblxuICAvLyDrpqzsiqTtirgg7L+866asXG4gIGNvbnN0IHsgZGF0YSwgbXV0YXRlLCBlcnJvciwgaXNMb2FkaW5nIH0gPSAke25hbWVzLmNhcGl0YWx9U2VydmljZS51c2Uke1xuICAgIG5hbWVzLmNhcGl0YWxQbHVyYWxcbiAgfSgnQScsIGxpc3RQYXJhbXMpO1xuICBjb25zdCB7IHJvd3MsIHRvdGFsIH0gPSBkYXRhID8/IHt9O1xuXG4gIC8vIOyCreygnFxuICBjb25zdCBjb25maXJtRGVsID0gKGlkczogbnVtYmVyW10pID0+IHtcbiAgICBjb25zdCBhbnN3ZXIgPSBjb25maXJtKCfsgq3soJztlZjsi5zqsqDsirXri4jquYw/Jyk7XG4gICAgaWYgKCFhbnN3ZXIpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAke25hbWVzLmNhcGl0YWx9U2VydmljZS5kZWwoaWRzKS50aGVuKCgpID0+IHtcbiAgICAgIG11dGF0ZSgpO1xuICAgIH0pO1xuICB9O1xuXG4gIC8vIOydvOq0hCDsgq3soJxcbiAgY29uc3QgY29uZmlybURlbFNlbGVjdGVkID0gKCkgPT4ge1xuICAgIGNvbnN0IGFuc3dlciA9IGNvbmZpcm0oXFxgXFwke3NlbGVjdGVkS2V5cy5sZW5ndGh96rG07J2EIOydvOq0hCDsgq3soJztlZjsi5zqsqDsirXri4jquYw/XFxgKTtcbiAgICBpZiAoIWFuc3dlcikge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgICR7bmFtZXMuY2FwaXRhbH1TZXJ2aWNlLmRlbChzZWxlY3RlZEtleXMpLnRoZW4oKCkgPT4ge1xuICAgICAgbXV0YXRlKCk7XG4gICAgfSk7XG4gIH07XG5cbiAgLy8g7ZiE7J6sIOqyveuhnOyZgCDtg4DsnbTti4BcbiAgY29uc3QgUEFHRSA9IHtcbiAgICByb3V0ZTogJy9hZG1pbi8ke25hbWVzLmZzUGx1cmFsfScsXG4gICAgdGl0bGU6ICcke2VudGl0eS50aXRsZSA/PyBuYW1lcy5jYXBpdGFsfScsXG4gIH07XG5cbiAgLy8g7ISg7YOdXG4gIGNvbnN0IHtcbiAgICBnZXRTZWxlY3RlZCxcbiAgICBpc0FsbFNlbGVjdGVkLFxuICAgIHNlbGVjdGVkS2V5cyxcbiAgICB0b2dnbGUsXG4gICAgc2VsZWN0QWxsLFxuICAgIGRlc2VsZWN0QWxsLFxuICAgIGhhbmRsZUNoZWNrYm94Q2xpY2ssXG4gIH0gPSB1c2VTZWxlY3Rpb24oKHJvd3MgPz8gW10pLm1hcCgocm93KSA9PiByb3cuaWQpKTtcblxuICAvLyDsu6zrn7xcbiAgY29uc3QgY29sdW1uczpTb25hbXVDb2w8JHtuYW1lcy5jYXBpdGFsfVN1YnNldEE+W10gPSBbJHtjb2x1bW5zXG4gICAgLm1hcCgoY29sKSA9PiB7XG4gICAgICByZXR1cm4gW1xuICAgICAgICBgeyBsYWJlbDogXCIke2NvbC5sYWJlbH1cIixgLFxuICAgICAgICBgdGM6ICR7Y29sLnRjfSwgYCxcbiAgICAgICAgYGNvbGxhcHNpbmc6ICR7W1wiVGl0bGVcIiwgXCJOYW1lXCJdLmluY2x1ZGVzKGNvbC5sYWJlbCkgPT09IGZhbHNlfSwgfWAsXG4gICAgICBdLmpvaW4oXCJcXG5cIik7XG4gICAgfSlcbiAgICAuam9pbihcIixcXG5cIil9XTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPVwibGlzdCAke25hbWVzLmZzUGx1cmFsfS1pbmRleFwiPlxuICAgICAgPGRpdiBjbGFzc05hbWU9XCJ0b3AtbmF2XCI+XG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiaGVhZGVyLXJvd1wiPlxuICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiaGVhZGVyXCI+e1BBR0UudGl0bGV9PC9kaXY+XG4gICAgICAgICAgPEFwcEJyZWFkY3J1bWJzPlxuICAgICAgICAgICAgPEJyZWFkY3J1bWIuU2VjdGlvbiBhY3RpdmU+e1BBR0UudGl0bGV9PC9CcmVhZGNydW1iLlNlY3Rpb24+XG4gICAgICAgICAgPC9BcHBCcmVhZGNydW1icz5cbiAgICAgICAgICA8JHtuYW1lcy5jYXBpdGFsfVNlYXJjaElucHV0XG4gICAgICAgICAgICBpbnB1dD17cmVnaXN0ZXIoJ2tleXdvcmQnKX1cbiAgICAgICAgICAgIGRyb3Bkb3duPXtyZWdpc3Rlcignc2VhcmNoJyl9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiZmlsdGVycy1yb3dcIj5cbiAgICAgICAgICAke2ZpbHRlckNvbHVtbnNcbiAgICAgICAgICAgIC5tYXAoKGNvbCkgPT4ge1xuICAgICAgICAgICAgICByZXR1cm4gdGhpcy5yZW5kZXJGaWx0ZXIoZW50aXR5SWQsIGNvbCwgbmFtZXMpO1xuICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIC5qb2luKFwiJm5ic3A7XFxuXCIpfVxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuXG4gICAgICA8U2VnbWVudCBiYXNpYyBwYWRkZWQgY2xhc3NOYW1lPVwiY29udGVudHMtc2VnbWVudFwiIGxvYWRpbmc9e2lzTG9hZGluZ30+XG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiYnV0dG9ucy1yb3dcIj5cbiAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT17Y2xhc3NOYW1lcygnY291bnQnLCB7IGhpZGRlbjogaXNMb2FkaW5nIH0pfT5cbiAgICAgICAgICAgIHt0b3RhbH0g6rG0XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJidXR0b25zXCI+XG4gICAgICAgICAgICA8QWRkQnV0dG9uIGN1cnJlbnRSb3V0ZT17UEFHRS5yb3V0ZX0gaWNvbj1cIndyaXRlXCIgbGFiZWw9XCLstpTqsIBcIiAvPlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cblxuICAgICAgICA8VGFibGVcbiAgICAgICAgICBjZWxsZWRcbiAgICAgICAgICBjb21wYWN0XG4gICAgICAgICAgc2VsZWN0YWJsZVxuICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lcyh7IGhpZGRlbjogdG90YWwgPT09IHVuZGVmaW5lZCB8fCB0b3RhbCA9PT0gMCB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDxUYWJsZS5IZWFkZXI+XG4gICAgICAgICAgICA8VGFibGVSb3c+XG4gICAgICAgICAgICAgIDxUYWJsZS5IZWFkZXJDZWxsIGNvbGxhcHNpbmc+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94XG4gICAgICAgICAgICAgICAgICBsYWJlbD1cIklEXCJcbiAgICAgICAgICAgICAgICAgIGNoZWNrZWQ9e2lzQWxsU2VsZWN0ZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aXNBbGxTZWxlY3RlZCA/IGRlc2VsZWN0QWxsIDogc2VsZWN0QWxsfVxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgIDwvVGFibGUuSGVhZGVyQ2VsbD5cbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIC8qIEhlYWRlciAqL1xuICAgICAgICAgICAgICAgIGNvbHVtbnMubWFwKChjb2wsIGluZGV4KSA9PiBjb2wudGggPz8gPFRhYmxlLkhlYWRlckNlbGwga2V5PXtpbmRleH0gY29sbGFwc2luZz17Y29sLmNvbGxhcHNpbmd9PnsgY29sLmxhYmVsIH08L1RhYmxlLkhlYWRlckNlbGw+KVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIDxUYWJsZS5IZWFkZXJDZWxsPuq0gOumrDwvVGFibGUuSGVhZGVyQ2VsbD5cbiAgICAgICAgICAgIDwvVGFibGVSb3c+XG4gICAgICAgICAgPC9UYWJsZS5IZWFkZXI+XG4gICAgICAgICAgPFRhYmxlLkJvZHk+XG4gICAgICAgICAgICB7cm93cyAmJlxuICAgICAgICAgICAgICByb3dzLm1hcCgocm93LCByb3dJbmRleCkgPT4gKFxuICAgICAgICAgICAgICAgIDxUYWJsZS5Sb3cga2V5PXtyb3cuaWR9PlxuICAgICAgICAgICAgICAgICAgPFRhYmxlLkNlbGw+XG4gICAgICAgICAgICAgICAgICAgIDxDaGVja2JveFxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsPXtyb3cuaWR9XG4gICAgICAgICAgICAgICAgICAgICAgY2hlY2tlZD17Z2V0U2VsZWN0ZWQocm93LmlkKX1cbiAgICAgICAgICAgICAgICAgICAgICBvbkNoYW5nZT17KCkgPT4gdG9nZ2xlKHJvdy5pZCl9XG4gICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KGUpID0+XG4gICAgICAgICAgICAgICAgICAgICAgICBoYW5kbGVDaGVja2JveENsaWNrKGUsIHJvd0luZGV4KVxuICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgIDwvVGFibGUuQ2VsbD5cbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgLyogQm9keSAqL1xuICAgICAgICAgICAgICAgICAgICBjb2x1bW5zLm1hcCgoY29sLCBjb2xJbmRleCkgPT4gKFxuICAgICAgICAgICAgICAgICAgICAgIDxUYWJsZS5DZWxsIGtleT17Y29sSW5kZXh9IGNvbGxhcHNpbmc9e2NvbC5jb2xsYXBzaW5nfSBjbGFzc05hbWU9e2NvbC5jbGFzc05hbWV9PlxuICAgICAgICAgICAgICAgICAgICAgICAge2NvbC50Yyhyb3csIHJvd0luZGV4KX1cbiAgICAgICAgICAgICAgICAgICAgICA8L1RhYmxlLkNlbGw+XG4gICAgICAgICAgICAgICAgICAgICkpXG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICA8VGFibGUuQ2VsbCBjb2xsYXBzaW5nPlxuICAgICAgICAgICAgICAgICAgICA8RWRpdEJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgIGFzPXtMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtcXGBcXCR7UEFHRS5yb3V0ZX0vZm9ybT9pZD1cXCR7cm93LmlkfVxcYH1cbiAgICAgICAgICAgICAgICAgICAgICBzdGF0ZT17eyBmcm9tOiBQQUdFLnJvdXRlIH19XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICAgIDxEZWxCdXR0b24gb25DbGljaz17KCkgPT4gY29uZmlybURlbChbcm93LmlkXSl9IC8+XG4gICAgICAgICAgICAgICAgICA8L1RhYmxlLkNlbGw+XG4gICAgICAgICAgICAgICAgPC9UYWJsZS5Sb3c+XG4gICAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvVGFibGUuQm9keT5cbiAgICAgICAgPC9UYWJsZT5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lcygncGFnaW5hdGlvbi1yb3cnLCB7XG4gICAgICAgICAgICBoaWRkZW46ICh0b3RhbCA/PyAwKSA9PT0gMCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDxQYWdpbmF0aW9uXG4gICAgICAgICAgICB0b3RhbFBhZ2VzPXtNYXRoLmNlaWwoKHRvdGFsID8/IDApIC8gKGxpc3RQYXJhbXMubnVtID8/IDI0KSl9XG4gICAgICAgICAgICB7Li4ucmVnaXN0ZXIoJ3BhZ2UnKX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvU2VnbWVudD5cblxuICAgICAgPGRpdiBjbGFzc05hbWU9XCJmaXhlZC1tZW51XCI+XG4gICAgICAgIDxUcmFuc2l0aW9uXG4gICAgICAgICAgdmlzaWJsZT17c2VsZWN0ZWRLZXlzLmxlbmd0aCA+IDB9XG4gICAgICAgICAgYW5pbWF0aW9uPVwic2xpZGUgbGVmdFwiXG4gICAgICAgICAgZHVyYXRpb249ezUwMH1cbiAgICAgICAgPlxuICAgICAgICAgIDxNZXNzYWdlIHNpemU9XCJzbWFsbFwiIGNvbG9yPVwidmlvbGV0XCIgY2xhc3NOYW1lPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cInB4LTRcIj57c2VsZWN0ZWRLZXlzLmxlbmd0aH3qsJwg7ISg7YOd65CoPC9zcGFuPlxuICAgICAgICAgICAgPEJ1dHRvbiBzaXplPVwidGlueVwiIGNvbG9yPVwidmlvbGV0XCIgb25DbGljaz17KCkgPT4gZGVzZWxlY3RBbGwoKX0+XG4gICAgICAgICAgICAgIOyEoO2DnSDtlbTsoJxcbiAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPEJ1dHRvbiBzaXplPVwidGlueVwiIGNvbG9yPVwicmVkXCIgb25DbGljaz17Y29uZmlybURlbFNlbGVjdGVkfT5cbiAgICAgICAgICAgICAg7J286rSEIOyCreygnFxuICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgPC9NZXNzYWdlPlxuICAgICAgICA8L1RyYW5zaXRpb24+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiAgICAgIGAudHJpbSgpLFxuICAgICAgaW1wb3J0S2V5czogW10sXG4gICAgICBwcmVUZW1wbGF0ZXMsXG4gICAgfTtcbiAgfVxufVxuIl0sIm5hbWVzIjpbImluZmxlY3Rpb24iLCJfIiwieiIsIkVudGl0eU1hbmFnZXIiLCJnZXRSZWxhdGlvblByb3BGcm9tQ29sTmFtZSIsImdldEVudW1JbmZvRnJvbUNvbE5hbWUiLCJUZW1wbGF0ZSIsInpvZFR5cGVUb1JlbmRlcmluZ05vZGUiLCJnZXRab2RUeXBlQnlJZCIsImdldENvbHVtbnNOb2RlIiwiVGVtcGxhdGVfX3ZpZXdfbGlzdCIsImdldFRhcmdldEFuZFBhdGgiLCJuYW1lcyIsInRhcmdldCIsInBhdGgiLCJmc1BsdXJhbCIsIndyYXBUYyIsImJvZHkiLCJrZXkiLCJjb2xsYXBzaW5nIiwiY2xhc3NOYW1lIiwicmVuZGVyQ29sdW1uIiwiZW50aXR5SWQiLCJjb2wiLCJwYXJlbnRPYmoiLCJ3aXRob3V0TmFtZSIsImNvbE5hbWUiLCJuYW1lIiwicmVuZGVyVHlwZSIsInJlbFByb3BGayIsInJlcGxhY2UiLCJ3aXRoIiwibnVsbGFibGUiLCJpZCIsImVudW1JZCIsInBpY2tlZENoaWxkIiwiY2hpbGRyZW4iLCJmaW5kIiwiY2hpbGQiLCJjb25maWciLCJwaWNrZWQiLCJFcnJvciIsInJlbmRlckNvbHVtbkltcG9ydCIsImNhcGl0YWwiLCJyZWxQcm9wIiwicmVzdWx0IiwibWFwIiwiZ2V0TmFtZXNGcm9tSWQiLCJmbGF0dGVuRGVlcCIsImVsZW1lbnQiLCJyZW5kZXJGaWx0ZXJJbXBvcnQiLCJmcyIsImNvbXBvbmVudElkIiwiY2FtZWxpemUiLCJ0YXJnZXRFbnRpdHlOYW1lcyIsInRhcmdldE1ETmFtZXMiLCJ0YXJnZXROYW1lcyIsInJlbmRlckZpbHRlciIsImlzQ2xlYXJhYmxlIiwib3B0aW9uYWwiLCJnZXREZWZhdWx0IiwiY29sdW1ucyIsImRlZiIsIm9yZGVyQnkiLCJzZWFyY2giLCJvcmRlckJ5Wm9kVHlwZSIsInpvZFR5cGUiLCJab2RFbnVtIiwib3B0aW9ucyIsInRvU3RyaW5nIiwic2VhcmNoWm9kVHlwZSIsInJlbmRlciIsImNvbHVtbnNOb2RlIiwibGlzdFBhcmFtc1pvZFR5cGUiLCJsaXN0UGFyYW1zTm9kZSIsImVudGl0eSIsImdldCIsImZpbHRlciIsInByb3BDYW5kaWRhdGUiLCJwcm9wcyIsInAiLCJsYWJlbCIsImRlc2MiLCJ0YyIsImZpbHRlckNvbHVtbnMiLCJpbmNsdWRlcyIsImVuZHNXaXRoIiwic29ydCIsImEiLCJwcmVUZW1wbGF0ZXMiLCJ0YXJnZXRFbnRpdHlJZCIsInB1c2giLCJjb2x1bW5JbXBvcnRzIiwidW5pcSIsImZsYXQiLCJqb2luIiwiY2FwaXRhbFBsdXJhbCIsInRpdGxlIiwidHJpbSIsImltcG9ydEtleXMiXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGdCQUFnQixhQUFhO0FBQ3BDLFlBQVlDLE9BQU8sWUFBWTtBQUMvQixTQUFTQyxDQUFDLFFBQVEsTUFBTTtBQUV4QixTQUFTQyxhQUFhLFFBQTJCLGlDQUE4QjtBQUMvRSxTQUFTQywwQkFBMEIsRUFBRUMsc0JBQXNCLFFBQVEsZ0JBQWE7QUFFaEYsU0FBU0MsUUFBUSxRQUFRLGlCQUFjO0FBQ3ZDLFNBQVNDLHNCQUFzQixFQUFFQyxjQUFjLFFBQVEsc0JBQW1CO0FBQzFFLFNBQVNDLGNBQWMsUUFBUSx5QkFBc0I7QUFFckQsT0FBTyxNQUFNQyw0QkFBNEJKO0lBQ3ZDLGFBQWM7UUFDWixLQUFLLENBQUM7SUFDUjtJQUVBSyxpQkFBaUJDLEtBQXdCLEVBQUU7UUFDekMsT0FBTztZQUNMQyxRQUFRO1lBQ1JDLE1BQU0sR0FBR0YsTUFBTUcsUUFBUSxDQUFDLFVBQVUsQ0FBQztRQUNyQztJQUNGO0lBRUFDLE9BQ0VDLElBQVksRUFDWkMsR0FBVyxFQUNYQyxhQUFzQixJQUFJLEVBQzFCQyxZQUFvQixFQUFFLEVBQ3RCO1FBQ0EsT0FBTyxDQUFDLGlCQUFpQixFQUFFRixJQUFJLENBQUMsRUFBRUMsYUFBYSxnQkFBZ0IsS0FDN0RDLFlBQVksQ0FBQyxjQUFjLEVBQUVBLFVBQVUsR0FBRyxDQUFDLEdBQUcsR0FDL0MsQ0FBQyxFQUFFSCxLQUFLLGFBQWEsQ0FBQztJQUN6QjtJQUVBSSxhQUNFQyxRQUFnQixFQUNoQkMsR0FBa0IsRUFDbEJYLEtBQXdCLEVBQ3hCWSxZQUFvQixLQUFLLEVBQ3pCQyxjQUF1QixLQUFLLEVBQ3BCO1FBQ1IsTUFBTUMsVUFBVUQsY0FBYyxHQUFHRCxXQUFXLEdBQUcsR0FBR0EsVUFBVSxDQUFDLEVBQUVELElBQUlJLElBQUksRUFBRTtRQUV6RSxPQUFRSixJQUFJSyxVQUFVO1lBQ3BCLEtBQUs7WUFDTCxLQUFLO1lBQ0wsS0FBSztnQkFDSCxPQUFPLENBQUMsR0FBRyxFQUFFRixRQUFRLElBQUksQ0FBQztZQUM1QixLQUFLO2dCQUNILE1BQU1HLFlBQVl6QiwyQkFDaEJrQixVQUNBQyxJQUFJSSxJQUFJLENBQUNHLE9BQU8sQ0FBQyxPQUFPO2dCQUUxQixPQUFPLENBQUMsRUFBRSxFQUFFRCxVQUFVRSxJQUFJLENBQUMsRUFBRSxFQUFFTCxRQUFRLElBQUksQ0FBQztZQUM5QyxLQUFLO2dCQUNILE9BQU8sQ0FBQyxHQUFHLEVBQ1RILElBQUlTLFFBQVEsR0FBRyxHQUFHTixRQUFRLElBQUksQ0FBQyxHQUFHLEdBQ25DLFVBQVUsRUFBRUEsUUFBUSxRQUFRLENBQUM7WUFDaEMsS0FBSztnQkFDSCxJQUFJSCxJQUFJUyxRQUFRLEVBQUU7b0JBQ2hCLE9BQU8sQ0FBQyw2QkFBNkIsRUFBRU4sUUFBUSxpQ0FBaUMsRUFBRUEsUUFBUSxTQUFTLENBQUM7Z0JBQ3RHLE9BQU87b0JBQ0wsT0FBTyxDQUFDLDRDQUE0QyxFQUFFQSxRQUFRLFNBQVMsQ0FBQztnQkFDMUU7WUFDRixLQUFLO2dCQUNILElBQUlILElBQUlTLFFBQVEsRUFBRTtvQkFDaEIsT0FBTyxDQUFDLDZCQUE2QixFQUFFTixRQUFRLHdCQUF3QixFQUFFQSxRQUFRLFNBQVMsQ0FBQztnQkFDN0YsT0FBTztvQkFDTCxPQUFPLENBQUMsbUNBQW1DLEVBQUVBLFFBQVEsU0FBUyxDQUFDO2dCQUNqRTtZQUNGLEtBQUs7Z0JBQ0gsT0FBTyxDQUFDLEdBQUcsRUFBRUEsUUFBUSx3RkFBd0YsQ0FBQztZQUNoSCxLQUFLO2dCQUNILE1BQU0sRUFBRU8sSUFBSUMsTUFBTSxFQUFFLEdBQUc3Qix1QkFBdUJpQixVQUFVQyxJQUFJSSxJQUFJO2dCQUNoRSxPQUFPLENBQUMsR0FBRyxFQUNUSixJQUFJUyxRQUFRLEdBQUcsR0FBR04sUUFBUSxJQUFJLENBQUMsR0FBRyxLQUNqQ1EsT0FBTyxNQUFNLEVBQUVSLFFBQVEsS0FBSyxDQUFDO1lBQ2xDLEtBQUs7Z0JBQ0gsT0FBTyxDQUFDLElBQUksRUFBRUEsUUFBUSxVQUFVLEVBQzlCSCxJQUFJUyxRQUFRLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxHQUMxQixxQkFBcUIsQ0FBQztZQUN6QixLQUFLO2dCQUNILE9BQU8sQ0FBQyxHQUFHLEVBQUVULElBQUlTLFFBQVEsR0FBRyxHQUFHTixRQUFRLElBQUksQ0FBQyxHQUFHLEdBQUcsS0FBSyxFQUFFQSxRQUFRLEtBQUssQ0FBQztZQUN6RSxLQUFLO2dCQUNILE9BQU8sQ0FBQyxhQUFhLEVBQUVBLFFBQVEsT0FBTyxDQUFDO1lBQ3pDLEtBQUs7Z0JBQ0gsTUFBTVMsY0FBY1osSUFBSWEsUUFBUSxDQUFFQyxJQUFJLENBQ3BDLENBQUNDLFFBQVVBLE1BQU1YLElBQUksS0FBS0osSUFBSWdCLE1BQU0sRUFBRUM7Z0JBRXhDLElBQUksQ0FBQ0wsYUFBYTtvQkFDaEIsTUFBTSxJQUFJTSxNQUFNLENBQUMseUJBQXlCLEVBQUVsQixJQUFJSSxJQUFJLENBQUMsQ0FBQyxDQUFDO2dCQUN6RDtnQkFDQSxPQUFPLElBQUksQ0FBQ04sWUFBWSxDQUN0QkMsVUFDQWEsYUFDQXZCLE9BQ0EsR0FBR2MsVUFBVUgsSUFBSVMsUUFBUSxHQUFHLE1BQU0sSUFBSTtZQUUxQyxLQUFLO2dCQUNILE9BQU8sQ0FBQyxhQUFhLEVBQUVOLFFBQVEsUUFBUSxDQUFDO1lBQzFDO2dCQUNFLE1BQU0sSUFBSWUsTUFBTSxDQUFDLFNBQVMsRUFBRWxCLElBQUlLLFVBQVUsRUFBRTtRQUNoRDtJQUNGO0lBRUFjLG1CQUNFcEIsUUFBZ0IsRUFDaEJDLEdBQWtCLEVBQ2xCWCxLQUF3QixFQUNMO1FBQ25CLElBQUlXLElBQUlLLFVBQVUsS0FBSyxTQUFTO1lBQzlCLE1BQU0sRUFBRUssSUFBSUMsTUFBTSxFQUFFLEdBQUc3Qix1QkFBdUJPLE1BQU0rQixPQUFPLEVBQUVwQixJQUFJSSxJQUFJO1lBQ3JFLE9BQU87Z0JBQ0wsQ0FBQyxTQUFTLEVBQUVPLE9BQU8sNkNBQTZDLENBQUM7YUFDbEU7UUFDSCxPQUFPLElBQUlYLElBQUlLLFVBQVUsS0FBSyxVQUFVO1lBQ3RDLElBQUk7Z0JBQ0YsTUFBTWdCLFVBQVV4QywyQkFBMkJrQixVQUFVQyxJQUFJSSxJQUFJO2dCQUM3RCxNQUFNa0IsU0FBU3RCLElBQUlhLFFBQVEsQ0FBRVUsR0FBRyxDQUFDLENBQUNSO29CQUNoQ2hCLFdBQVdzQixRQUFRYixJQUFJO29CQUN2Qm5CLFFBQVFULGNBQWM0QyxjQUFjLENBQUNILFFBQVFiLElBQUk7b0JBQ2pELE9BQU8sSUFBSSxDQUFDVyxrQkFBa0IsQ0FBQ3BCLFVBQVVnQixPQUFPMUI7Z0JBQ2xEO2dCQUNBLE9BQU9YLEVBQUUrQyxXQUFXLENBQUNIO1lBQ3ZCLEVBQUUsT0FBTTtnQkFDTixPQUFPO29CQUFDO2lCQUFLO1lBQ2Y7UUFDRixPQUFPLElBQUl0QixJQUFJSyxVQUFVLEtBQUssU0FBUztZQUNyQyxPQUFPLElBQUksQ0FBQ2Msa0JBQWtCLENBQUNwQixVQUFVQyxJQUFJMEIsT0FBTyxFQUFHckM7UUFDekQ7UUFFQSxPQUFPO1lBQUM7U0FBSztJQUNmO0lBRUFzQyxtQkFDRTVCLFFBQWdCLEVBQ2hCQyxHQUFrQixFQUNsQlgsS0FBd0IsRUFDeEI7UUFDQSxJQUFJVyxJQUFJSSxJQUFJLEtBQUssVUFBVTtZQUN6QixPQUFPLENBQUMsU0FBUyxFQUFFZixNQUFNK0IsT0FBTyxDQUFDLG1DQUFtQyxFQUFFL0IsTUFBTXVDLEVBQUUsQ0FBQyxDQUFDLEVBQUV2QyxNQUFNK0IsT0FBTyxDQUFDLGFBQWEsQ0FBQztRQUNoSCxPQUFPLElBQUlwQixJQUFJSyxVQUFVLEtBQUssU0FBUztZQUNyQyxJQUFJTCxJQUFJSSxJQUFJLEtBQUssV0FBVztnQkFDMUIsTUFBTXlCLGNBQWMsR0FBR3hDLE1BQU0rQixPQUFPLEdBQUczQyxXQUFXcUQsUUFBUSxDQUN4RDlCLElBQUlJLElBQUksRUFDUixNQUFNLENBQUM7Z0JBQ1QsT0FBTyxDQUFDLFNBQVMsRUFBRXlCLFlBQVksd0JBQXdCLEVBQUV4QyxNQUFNdUMsRUFBRSxDQUFDLENBQUMsRUFBRUMsWUFBWSxFQUFFLENBQUM7WUFDdEYsT0FBTztnQkFDTCxJQUFJO29CQUNGLE1BQU0sRUFBRW5CLEVBQUUsRUFBRXFCLG1CQUFtQkMsYUFBYSxFQUFFLEdBQzVDbEQsdUJBQXVCaUIsVUFBVUMsSUFBSUksSUFBSTtvQkFDM0MsTUFBTXlCLGNBQWMsR0FBR25CLEdBQUcsTUFBTSxDQUFDO29CQUNqQyxPQUFPLENBQUMsU0FBUyxFQUFFbUIsWUFBWSx3QkFBd0IsRUFBRUcsY0FBY0osRUFBRSxDQUFDLENBQUMsRUFBRUMsWUFBWSxFQUFFLENBQUM7Z0JBQzlGLEVBQUUsT0FBTTtvQkFDTixPQUFPO2dCQUNUO1lBQ0Y7UUFDRixPQUFPLElBQUk3QixJQUFJSyxVQUFVLEtBQUssZ0JBQWdCO1lBQzVDLElBQUk7Z0JBQ0YsTUFBTWdCLFVBQVV4QywyQkFDZGtCLFVBQ0FDLElBQUlJLElBQUksQ0FBQ0csT0FBTyxDQUFDLE9BQU87Z0JBRTFCLE1BQU0wQixjQUFjckQsY0FBYzRDLGNBQWMsQ0FBQ0gsUUFBUWIsSUFBSTtnQkFDN0QsTUFBTXFCLGNBQWMsR0FBR1IsUUFBUWIsSUFBSSxDQUFDLGFBQWEsQ0FBQztnQkFDbEQsT0FBTyxDQUFDLFNBQVMsRUFBRXFCLFlBQVksd0JBQXdCLEVBQUVJLFlBQVlMLEVBQUUsQ0FBQyxDQUFDLEVBQUVDLFlBQVksRUFBRSxDQUFDO1lBQzVGLEVBQUUsT0FBTTtnQkFDTixPQUFPO1lBQ1Q7UUFDRixPQUFPO1lBQ0wsTUFBTSxJQUFJWCxNQUNSLENBQUMsZUFBZSxFQUFFbEIsSUFBSUksSUFBSSxDQUFDLENBQUMsRUFBRUosSUFBSUssVUFBVSxFQUFFO1FBRWxEO0lBQ0Y7SUFFQTZCLGFBQWFuQyxRQUFnQixFQUFFQyxHQUFrQixFQUFFWCxLQUF3QixFQUFFO1FBQzNFLElBQUlXLElBQUlJLElBQUksS0FBSyxVQUFVO1lBQ3pCLE9BQU87UUFDVDtRQUVBLE1BQU0rQixjQUFjbkMsSUFBSW9DLFFBQVEsS0FBSyxRQUFRcEMsSUFBSUksSUFBSSxLQUFLO1FBQzFELElBQUl5QjtRQUNKLElBQUk3QixJQUFJSyxVQUFVLEtBQUssU0FBUztZQUM5QixJQUFJTCxJQUFJSSxJQUFJLEtBQUssV0FBVztnQkFDMUJ5QixjQUFjLEdBQUd4QyxNQUFNK0IsT0FBTyxHQUFHM0MsV0FBV3FELFFBQVEsQ0FBQzlCLElBQUlJLElBQUksRUFBRSxNQUFNLENBQUM7WUFDeEUsT0FBTztnQkFDTCxJQUFJO29CQUNGLE1BQU0sRUFBRU0sRUFBRSxFQUFFLEdBQUc1Qix1QkFBdUJpQixVQUFVQyxJQUFJSSxJQUFJO29CQUN4RHlCLGNBQWMsR0FBR25CLEdBQUcsTUFBTSxDQUFDO2dCQUM3QixFQUFFLE9BQU07b0JBQ04sT0FBTztnQkFDVDtZQUNGO1lBQ0EsT0FBTyxDQUFDLENBQUMsRUFBRW1CLFlBQVksZUFBZSxFQUFFN0IsSUFBSUksSUFBSSxDQUFDLElBQUksRUFDbkQrQixjQUFjLGNBQWMsR0FDN0IsR0FBRyxDQUFDO1FBQ1AsT0FBTyxJQUFJbkMsSUFBSUssVUFBVSxLQUFLLGdCQUFnQjtZQUM1QyxJQUFJO2dCQUNGLE1BQU1nQixVQUFVeEMsMkJBQ2RrQixVQUNBQyxJQUFJSSxJQUFJLENBQUNHLE9BQU8sQ0FBQyxPQUFPO2dCQUUxQnNCLGNBQWMsR0FBR1IsUUFBUWIsSUFBSSxDQUFDLGFBQWEsQ0FBQztnQkFDNUMsT0FBTyxDQUFDLENBQUMsRUFBRXFCLFlBQVksZUFBZSxFQUFFN0IsSUFBSUksSUFBSSxDQUFDLElBQUksRUFDbkQrQixjQUFjLGNBQWMsR0FDN0IsY0FBYyxDQUFDO1lBQ2xCLEVBQUUsT0FBTTtnQkFDTixPQUFPO1lBQ1Q7UUFDRixPQUFPO1lBQ0wsTUFBTSxJQUFJakIsTUFDUixDQUFDLGVBQWUsRUFBRWxCLElBQUlJLElBQUksQ0FBQyxDQUFDLEVBQUVKLElBQUlLLFVBQVUsRUFBRTtRQUVsRDtJQUNGO0lBRUFnQyxXQUFXQyxPQUF3QixFQUdqQztRQUNBLE1BQU1DLE1BQU07WUFDVkMsU0FBUztZQUNUQyxRQUFRO1FBQ1Y7UUFDQSxNQUFNQyxpQkFBaUJKLFFBQVF4QixJQUFJLENBQ2pDLENBQUNkLE1BQVFBLElBQUlJLElBQUksS0FBSyxZQUNyQnVDO1FBQ0gsSUFBSUQsa0JBQWtCQSwwQkFBMEIvRCxFQUFFaUUsT0FBTyxFQUFFO1lBQ3pETCxJQUFJQyxPQUFPLEdBQUdFLGVBQWVHLE9BQU8sQ0FBQyxFQUFFLENBQUNDLFFBQVE7UUFDbEQ7UUFDQSxNQUFNQyxnQkFBZ0JULFFBQVF4QixJQUFJLENBQUMsQ0FBQ2QsTUFBUUEsSUFBSUksSUFBSSxLQUFLLFdBQVd1QztRQUNwRSxJQUFJSSxpQkFBaUJBLHlCQUF5QnBFLEVBQUVpRSxPQUFPLEVBQUU7WUFDdkRMLElBQUlFLE1BQU0sR0FBR00sY0FBY0YsT0FBTyxDQUFDLEVBQUUsQ0FBQ0MsUUFBUTtRQUNoRDtRQUNBLE9BQU9QO0lBQ1Q7SUFFQSxNQUFNUyxPQUFPLEVBQUVqRCxRQUFRLEVBQWdDLEVBQUU7UUFDdkQsTUFBTWtELGNBQWMsTUFBTS9ELGVBQWVhLFVBQVU7UUFDbkQsTUFBTW1ELG9CQUFvQixNQUFNakUsZUFBZSxHQUFHYyxTQUFTLFVBQVUsQ0FBQztRQUN0RSxNQUFNb0QsaUJBQWlCbkUsdUJBQXVCa0U7UUFFOUMsTUFBTTdELFFBQVFULGNBQWM0QyxjQUFjLENBQUN6QjtRQUMzQyxNQUFNcUQsU0FBU3hFLGNBQWN5RSxHQUFHLENBQUN0RDtRQUVqQyxZQUFZO1FBQ1osTUFBTXVDLFVBQVUsQUFBQ1csWUFBWXBDLFFBQVEsQ0FDbEN5QyxNQUFNLENBQUMsQ0FBQ3RELE1BQVFBLElBQUlJLElBQUksS0FBSyxNQUM3Qm1CLEdBQUcsQ0FBQyxDQUFDdkI7WUFDSixNQUFNdUQsZ0JBQWdCSCxPQUFPSSxLQUFLLENBQUMxQyxJQUFJLENBQUMsQ0FBQzJDLElBQU1BLEVBQUVyRCxJQUFJLEtBQUtKLElBQUlJLElBQUk7WUFDbEUsT0FBTztnQkFDTEEsTUFBTUosSUFBSUksSUFBSTtnQkFDZHNELE9BQU9ILGVBQWVJLFFBQVEzRCxJQUFJMEQsS0FBSztnQkFDdkNFLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDOUQsWUFBWSxDQUFDQyxVQUFVQyxLQUFLWCxRQUFRO1lBQzNEO1FBQ0Y7UUFFRixRQUFRO1FBQ1IsTUFBTXdFLGdCQUFnQixBQUFDVixlQUFldEMsUUFBUSxDQUMzQ3lDLE1BQU0sQ0FDTCxDQUFDdEQsTUFDQ0EsSUFBSUksSUFBSSxLQUFLLFFBQ2JKLElBQUlJLElBQUksS0FBSyxlQUNaLENBQUE7Z0JBQUM7Z0JBQVM7YUFBWSxDQUFDMEQsUUFBUSxDQUFDOUQsSUFBSUssVUFBVSxLQUM3Q0wsSUFBSUksSUFBSSxDQUFDMkQsUUFBUSxDQUFDLE1BQUssRUFFN0IsMEJBQTBCO1NBQ3pCQyxJQUFJLENBQUMsQ0FBQ0M7WUFDTCxPQUFPQSxFQUFFN0QsSUFBSSxJQUFJLFlBQVksSUFBSSxDQUFDO1FBQ3BDO1FBRUYscUJBQXFCO1FBQ3JCLE1BQU04RCxlQUFpRCxFQUFFO1FBQ3pELEtBQUssSUFBSWxFLE9BQU82RCxjQUFlO1lBQzdCLElBQUlsRTtZQUNKLElBQUl3RSxpQkFBaUJwRTtZQUNyQixJQUFJWTtZQUVKLElBQUlYLElBQUlLLFVBQVUsS0FBSyxTQUFTO2dCQUM5QixJQUFJTCxJQUFJSSxJQUFJLEtBQUssVUFBVTtvQkFDekJULE1BQU07b0JBQ05nQixTQUFTLEdBQUd0QixNQUFNK0IsT0FBTyxDQUFDLFdBQVcsQ0FBQztvQkFDdEMrQyxpQkFBaUI5RSxNQUFNK0IsT0FBTztnQkFDaEMsT0FBTztvQkFDTHpCLE1BQU07b0JBQ04sSUFBSTt3QkFDRixNQUFNLEVBQUVvQyxpQkFBaUIsRUFBRXJCLEVBQUUsRUFBRSxHQUFHNUIsdUJBQ2hDaUIsVUFDQUMsSUFBSUksSUFBSTt3QkFFVitELGlCQUFpQnBDLGtCQUFrQlgsT0FBTzt3QkFDMUNULFNBQVNEO29CQUNYLEVBQUUsT0FBTTt3QkFDTjtvQkFDRjtnQkFDRjtZQUNGLE9BQU87Z0JBQ0xmLE1BQU07Z0JBQ04sSUFBSTtvQkFDRixNQUFNMEIsVUFBVXhDLDJCQUNka0IsVUFDQUMsSUFBSUksSUFBSSxDQUFDRyxPQUFPLENBQUMsT0FBTztvQkFFMUI0RCxpQkFBaUI5QyxRQUFRYixJQUFJO2dCQUMvQixFQUFFLE9BQU07b0JBQ047Z0JBQ0Y7WUFDRjtZQUVBMEQsYUFBYUUsSUFBSSxDQUFDO2dCQUNoQnpFO2dCQUNBa0QsU0FBUztvQkFDUDlDLFVBQVVvRTtvQkFDVnhEO2dCQUNGO1lBQ0Y7UUFDRjtRQUVBLFNBQVM7UUFDVCxNQUFNMEQsZ0JBQWdCM0YsRUFBRTRGLElBQUksQ0FDMUJyQixZQUNHcEMsUUFBUSxDQUFFVSxHQUFHLENBQUMsQ0FBQ3ZCO1lBQ2QsT0FBTyxJQUFJLENBQUNtQixrQkFBa0IsQ0FBQ3BCLFVBQVVDLEtBQUtYO1FBQ2hELEdBQ0NrRixJQUFJLEdBQ0pqQixNQUFNLENBQUMsQ0FBQ3RELE1BQVFBLFFBQVEsT0FDM0J3RSxJQUFJLENBQUM7UUFFUCxjQUFjO1FBQ2ROLGFBQWNFLElBQUksQ0FBQztZQUNqQnpFLEtBQUs7WUFDTGtELFNBQVM7Z0JBQ1A5QztZQUNGO1FBQ0Y7UUFFQSxXQUFXO1FBQ1gsTUFBTXdDLE1BQU0sSUFBSSxDQUFDRixVQUFVLENBQUN3QjtRQUU1QixPQUFPO1lBQ0wsR0FBRyxJQUFJLENBQUN6RSxnQkFBZ0IsQ0FBQ0MsTUFBTTtZQUMvQkssTUFBTSxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O1NBbUJKLEVBQUVMLE1BQU0rQixPQUFPLENBQUM7U0FDaEIsRUFBRS9CLE1BQU0rQixPQUFPLENBQUMsNkJBQTZCLEVBQUUvQixNQUFNdUMsRUFBRSxDQUFDLENBQUMsRUFDMUR2QyxNQUFNdUMsRUFBRSxDQUNUO1NBQ0UsRUFBRXZDLE1BQU0rQixPQUFPLENBQUMsZ0NBQWdDLEVBQUUvQixNQUFNdUMsRUFBRSxDQUFDLENBQUMsRUFDN0R2QyxNQUFNdUMsRUFBRSxDQUNUO0FBQ1AsRUFBRXlDLGNBQWM7QUFDaEIsRUFBRVIsY0FDQ3RDLEdBQUcsQ0FBQyxDQUFDdkI7Z0JBQ0osT0FBTyxJQUFJLENBQUMyQixrQkFBa0IsQ0FBQzVCLFVBQVVDLEtBQUtYO1lBQ2hELEdBQ0NtRixJQUFJLENBQUMsTUFBTTs7S0FFVCxFQUFFbkYsTUFBTStCLE9BQU8sQ0FBQzt3QkFDRyxFQUFFL0IsTUFBTStCLE9BQU8sQ0FBQyxTQUFTLEVBQUUvQixNQUFNK0IsT0FBTyxDQUFDOztpREFFaEIsRUFBRS9CLE1BQU0rQixPQUFPLENBQUM7OztjQUduRCxFQUFFbUIsSUFBSUMsT0FBTyxDQUFDO2FBQ2YsRUFBRUQsSUFBSUUsTUFBTSxDQUFDOzs7OzZDQUltQixFQUFFcEQsTUFBTStCLE9BQU8sQ0FBQyxXQUFXLEVBQ3BFL0IsTUFBTW9GLGFBQWEsQ0FDcEI7Ozs7Ozs7Ozs7SUFVQyxFQUFFcEYsTUFBTStCLE9BQU8sQ0FBQzs7Ozs7Ozs7Ozs7O0lBWWhCLEVBQUUvQixNQUFNK0IsT0FBTyxDQUFDOzs7Ozs7O21CQU9ELEVBQUUvQixNQUFNRyxRQUFRLENBQUM7WUFDeEIsRUFBRTRELE9BQU9zQixLQUFLLElBQUlyRixNQUFNK0IsT0FBTyxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7MEJBZWxCLEVBQUUvQixNQUFNK0IsT0FBTyxDQUFDLGNBQWMsRUFBRWtCLFFBQ3JEZixHQUFHLENBQUMsQ0FBQ3ZCO2dCQUNKLE9BQU87b0JBQ0wsQ0FBQyxVQUFVLEVBQUVBLElBQUkwRCxLQUFLLENBQUMsRUFBRSxDQUFDO29CQUMxQixDQUFDLElBQUksRUFBRTFELElBQUk0RCxFQUFFLENBQUMsRUFBRSxDQUFDO29CQUNqQixDQUFDLFlBQVksRUFBRTt3QkFBQzt3QkFBUztxQkFBTyxDQUFDRSxRQUFRLENBQUM5RCxJQUFJMEQsS0FBSyxNQUFNLE1BQU0sR0FBRyxDQUFDO2lCQUNwRSxDQUFDYyxJQUFJLENBQUM7WUFDVCxHQUNDQSxJQUFJLENBQUMsT0FBTzs7O3lCQUdRLEVBQUVuRixNQUFNRyxRQUFRLENBQUM7Ozs7Ozs7V0FPL0IsRUFBRUgsTUFBTStCLE9BQU8sQ0FBQzs7Ozs7O1VBTWpCLEVBQUV5QyxjQUNDdEMsR0FBRyxDQUFDLENBQUN2QjtnQkFDSixPQUFPLElBQUksQ0FBQ2tDLFlBQVksQ0FBQ25DLFVBQVVDLEtBQUtYO1lBQzFDLEdBQ0NtRixJQUFJLENBQUMsWUFBWTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O01Bc0d4QixDQUFDLENBQUNHLElBQUk7WUFDTkMsWUFBWSxFQUFFO1lBQ2RWO1FBQ0Y7SUFDRjtBQUNGIn0=
@@ -1,6 +1,6 @@
1
- import { TemplateOptions } from "../types/types";
2
- import { EntityNamesRecord } from "../entity/entity-manager";
3
- import { Template } from "./base-template";
1
+ import { TemplateOptions } from "../../types/types";
2
+ import { EntityNamesRecord } from "../../entity/entity-manager";
3
+ import { Template } from "../template";
4
4
  export declare class Template__view_list_columns extends Template {
5
5
  constructor();
6
6
  getTargetAndPath(names: EntityNamesRecord): {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"view_list_columns.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/view_list_columns.template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAiB,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,2BAA4B,SAAQ,QAAQ;;IAKvD,gBAAgB,CAAC,KAAK,EAAE,iBAAiB;;;;IAQzC,MAAM,CAAC,EACL,QAAQ,EACR,OAAO,EACP,aAAa,GACd,EAAE,eAAe,CAAC,mBAAmB,CAAC;;;;;;CAqCxC"}
@@ -0,0 +1,49 @@
1
+ import { EntityManager } from "../../entity/entity-manager.js";
2
+ import { Template } from "../template.js";
3
+ export class Template__view_list_columns extends Template {
4
+ constructor(){
5
+ super("view_list_columns");
6
+ }
7
+ getTargetAndPath(names) {
8
+ return {
9
+ target: "web/src/pages/admin",
10
+ path: `${names.fsPlural}/_columns.tsx`
11
+ };
12
+ }
13
+ // 컬럼
14
+ render({ entityId, columns, columnImports }) {
15
+ const names = EntityManager.getNamesFromId(entityId);
16
+ return {
17
+ ...this.getTargetAndPath(names),
18
+ body: `
19
+ import React from 'react';
20
+ import {
21
+ Segment,
22
+ Table,
23
+ TableRow,
24
+ Button,
25
+ Label,
26
+ } from 'semantic-ui-react';
27
+ import { DateTime } from "luxon";
28
+ import { TFColumn } from "src/typeframe/iso-types";
29
+ import { ${names.capital}SubsetA } from "src/services/${names.fs}/${names.fs}.generated";
30
+ ${columnImports}
31
+
32
+ const columns: { [key in Exclude<keyof ${names.capital}SubsetA, 'id'>]: TFColumn<${names.capital}SubsetA> } = {${columns.map((col)=>{
33
+ return [
34
+ `${col.name}: { label: "${col.label}",`,
35
+ `tc: ${col.tc}, `,
36
+ `collapsing: ${[
37
+ "Title",
38
+ "Name"
39
+ ].includes(col.label) === false}, }`
40
+ ].join("\n");
41
+ }).join(",\n")}};
42
+ export default columns;
43
+ `.trim(),
44
+ importKeys: []
45
+ };
46
+ }
47
+ }
48
+
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90ZW1wbGF0ZS9pbXBsZW1lbnRhdGlvbnMvdmlld19saXN0X2NvbHVtbnMudGVtcGxhdGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGVPcHRpb25zIH0gZnJvbSBcIi4uLy4uL3R5cGVzL3R5cGVzXCI7XG5pbXBvcnQgeyBFbnRpdHlNYW5hZ2VyLCBFbnRpdHlOYW1lc1JlY29yZCB9IGZyb20gXCIuLi8uLi9lbnRpdHkvZW50aXR5LW1hbmFnZXJcIjtcbmltcG9ydCB7IFRlbXBsYXRlIH0gZnJvbSBcIi4uL3RlbXBsYXRlXCI7XG5cbmV4cG9ydCBjbGFzcyBUZW1wbGF0ZV9fdmlld19saXN0X2NvbHVtbnMgZXh0ZW5kcyBUZW1wbGF0ZSB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKFwidmlld19saXN0X2NvbHVtbnNcIik7XG4gIH1cblxuICBnZXRUYXJnZXRBbmRQYXRoKG5hbWVzOiBFbnRpdHlOYW1lc1JlY29yZCkge1xuICAgIHJldHVybiB7XG4gICAgICB0YXJnZXQ6IFwid2ViL3NyYy9wYWdlcy9hZG1pblwiLFxuICAgICAgcGF0aDogYCR7bmFtZXMuZnNQbHVyYWx9L19jb2x1bW5zLnRzeGAsXG4gICAgfTtcbiAgfVxuXG4gIC8vIOy7rOufvFxuICByZW5kZXIoe1xuICAgIGVudGl0eUlkLFxuICAgIGNvbHVtbnMsXG4gICAgY29sdW1uSW1wb3J0cyxcbiAgfTogVGVtcGxhdGVPcHRpb25zW1widmlld19saXN0X2NvbHVtbnNcIl0pIHtcbiAgICBjb25zdCBuYW1lcyA9IEVudGl0eU1hbmFnZXIuZ2V0TmFtZXNGcm9tSWQoZW50aXR5SWQpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnRoaXMuZ2V0VGFyZ2V0QW5kUGF0aChuYW1lcyksXG4gICAgICBib2R5OiBgXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHtcbiAgU2VnbWVudCxcbiAgVGFibGUsXG4gIFRhYmxlUm93LFxuICBCdXR0b24sXG4gIExhYmVsLFxufSBmcm9tICdzZW1hbnRpYy11aS1yZWFjdCc7XG5pbXBvcnQgeyBEYXRlVGltZSB9IGZyb20gXCJsdXhvblwiO1xuaW1wb3J0IHsgVEZDb2x1bW4gfSBmcm9tIFwic3JjL3R5cGVmcmFtZS9pc28tdHlwZXNcIjtcbmltcG9ydCB7ICR7bmFtZXMuY2FwaXRhbH1TdWJzZXRBIH0gZnJvbSBcInNyYy9zZXJ2aWNlcy8ke25hbWVzLmZzfS8ke1xuICAgICAgICBuYW1lcy5mc1xuICAgICAgfS5nZW5lcmF0ZWRcIjtcbiR7Y29sdW1uSW1wb3J0c31cblxuY29uc3QgY29sdW1uczogeyBba2V5IGluIEV4Y2x1ZGU8a2V5b2YgJHtcbiAgICAgICAgbmFtZXMuY2FwaXRhbFxuICAgICAgfVN1YnNldEEsICdpZCc+XTogVEZDb2x1bW48JHtuYW1lcy5jYXBpdGFsfVN1YnNldEE+IH0gPSB7JHtjb2x1bW5zXG4gICAgICAgIC5tYXAoKGNvbCkgPT4ge1xuICAgICAgICAgIHJldHVybiBbXG4gICAgICAgICAgICBgJHtjb2wubmFtZX06IHsgbGFiZWw6IFwiJHtjb2wubGFiZWx9XCIsYCxcbiAgICAgICAgICAgIGB0YzogJHtjb2wudGN9LCBgLFxuICAgICAgICAgICAgYGNvbGxhcHNpbmc6ICR7W1wiVGl0bGVcIiwgXCJOYW1lXCJdLmluY2x1ZGVzKGNvbC5sYWJlbCkgPT09IGZhbHNlfSwgfWAsXG4gICAgICAgICAgXS5qb2luKFwiXFxuXCIpO1xuICAgICAgICB9KVxuICAgICAgICAuam9pbihcIixcXG5cIil9fTtcbmV4cG9ydCBkZWZhdWx0IGNvbHVtbnM7XG4gICAgICBgLnRyaW0oKSxcbiAgICAgIGltcG9ydEtleXM6IFtdLFxuICAgIH07XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJFbnRpdHlNYW5hZ2VyIiwiVGVtcGxhdGUiLCJUZW1wbGF0ZV9fdmlld19saXN0X2NvbHVtbnMiLCJnZXRUYXJnZXRBbmRQYXRoIiwibmFtZXMiLCJ0YXJnZXQiLCJwYXRoIiwiZnNQbHVyYWwiLCJyZW5kZXIiLCJlbnRpdHlJZCIsImNvbHVtbnMiLCJjb2x1bW5JbXBvcnRzIiwiZ2V0TmFtZXNGcm9tSWQiLCJib2R5IiwiY2FwaXRhbCIsImZzIiwibWFwIiwiY29sIiwibmFtZSIsImxhYmVsIiwidGMiLCJpbmNsdWRlcyIsImpvaW4iLCJ0cmltIiwiaW1wb3J0S2V5cyJdLCJtYXBwaW5ncyI6IkFBQ0EsU0FBU0EsYUFBYSxRQUEyQixpQ0FBOEI7QUFDL0UsU0FBU0MsUUFBUSxRQUFRLGlCQUFjO0FBRXZDLE9BQU8sTUFBTUMsb0NBQW9DRDtJQUMvQyxhQUFjO1FBQ1osS0FBSyxDQUFDO0lBQ1I7SUFFQUUsaUJBQWlCQyxLQUF3QixFQUFFO1FBQ3pDLE9BQU87WUFDTEMsUUFBUTtZQUNSQyxNQUFNLEdBQUdGLE1BQU1HLFFBQVEsQ0FBQyxhQUFhLENBQUM7UUFDeEM7SUFDRjtJQUVBLEtBQUs7SUFDTEMsT0FBTyxFQUNMQyxRQUFRLEVBQ1JDLE9BQU8sRUFDUEMsYUFBYSxFQUN3QixFQUFFO1FBQ3ZDLE1BQU1QLFFBQVFKLGNBQWNZLGNBQWMsQ0FBQ0g7UUFFM0MsT0FBTztZQUNMLEdBQUcsSUFBSSxDQUFDTixnQkFBZ0IsQ0FBQ0MsTUFBTTtZQUMvQlMsTUFBTSxDQUFDOzs7Ozs7Ozs7OztTQVdKLEVBQUVULE1BQU1VLE9BQU8sQ0FBQyw2QkFBNkIsRUFBRVYsTUFBTVcsRUFBRSxDQUFDLENBQUMsRUFDMURYLE1BQU1XLEVBQUUsQ0FDVDtBQUNQLEVBQUVKLGNBQWM7O3VDQUV1QixFQUMvQlAsTUFBTVUsT0FBTyxDQUNkLDBCQUEwQixFQUFFVixNQUFNVSxPQUFPLENBQUMsY0FBYyxFQUFFSixRQUN4RE0sR0FBRyxDQUFDLENBQUNDO2dCQUNKLE9BQU87b0JBQ0wsR0FBR0EsSUFBSUMsSUFBSSxDQUFDLFlBQVksRUFBRUQsSUFBSUUsS0FBSyxDQUFDLEVBQUUsQ0FBQztvQkFDdkMsQ0FBQyxJQUFJLEVBQUVGLElBQUlHLEVBQUUsQ0FBQyxFQUFFLENBQUM7b0JBQ2pCLENBQUMsWUFBWSxFQUFFO3dCQUFDO3dCQUFTO3FCQUFPLENBQUNDLFFBQVEsQ0FBQ0osSUFBSUUsS0FBSyxNQUFNLE1BQU0sR0FBRyxDQUFDO2lCQUNwRSxDQUFDRyxJQUFJLENBQUM7WUFDVCxHQUNDQSxJQUFJLENBQUMsT0FBTzs7TUFFZixDQUFDLENBQUNDLElBQUk7WUFDTkMsWUFBWSxFQUFFO1FBQ2hCO0lBQ0Y7QUFDRiJ9
@@ -1,6 +1,6 @@
1
- import { TemplateOptions } from "../types/types";
2
- import { EntityNamesRecord } from "../entity/entity-manager";
3
- import { Template } from "./base-template";
1
+ import { TemplateOptions } from "../../types/types";
2
+ import { EntityNamesRecord } from "../../entity/entity-manager";
3
+ import { Template } from "../template";
4
4
  export declare class Template__view_search_input extends Template {
5
5
  constructor();
6
6
  getTargetAndPath(names: EntityNamesRecord): {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"view_search_input.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/view_search_input.template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAiB,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,2BAA4B,SAAQ,QAAQ;;IAKvD,gBAAgB,CAAC,KAAK,EAAE,iBAAiB;;;;IAOzC,MAAM,CAAC,EAAE,QAAQ,EAAE,EAAE,eAAe,CAAC,mBAAmB,CAAC;;;;;;CAkD1D"}