@simplysm/sd-claude 14.0.50 → 14.0.52
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/claude/references/sd-frontend-design.md +10 -9
- package/claude/references/sd-simplysm-v14/angular/README.md +497 -0
- package/claude/references/sd-simplysm-v14/angular/bootstrap/provide-sd-angular.md +37 -0
- package/claude/references/sd-simplysm-v14/angular/bootstrap/sd-angular-config-provider.md +16 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-command-directive.md +27 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-events.md +25 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-intersection-directive.md +36 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-invalid.md +24 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-resize-directive.md +42 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-ripple.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-router-link.md +38 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-show-effect.md +18 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-typed-template.md +69 -0
- package/claude/references/sd-simplysm-v14/angular/features/sd-address-search-modal.md +50 -0
- package/claude/references/sd-simplysm-v14/angular/features/sd-permission-table.md +20 -0
- package/claude/references/sd-simplysm-v14/angular/features/sd-shared-data-components.md +158 -0
- package/claude/references/sd-simplysm-v14/angular/features/sd-tiptap-editor.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/pipes/format-pipe.md +41 -0
- package/claude/references/sd-simplysm-v14/angular/plugins/sd-global-error-handler.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/plugins/sd-option-event-plugin.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/provider-types/sd-menu.md +65 -0
- package/claude/references/sd-simplysm-v14/angular/provider-types/sd-modal-content-def.md +148 -0
- package/claude/references/sd-simplysm-v14/angular/provider-types/sd-toast-content-def.md +73 -0
- package/claude/references/sd-simplysm-v14/angular/provider-types/shared-data-base.md +59 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-activated-modal-provider.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-app-structure-provider.md +81 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-busy-provider.md +18 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-file-dialog-provider.md +40 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-local-storage-provider.md +20 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-modal-provider.md +67 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-navigate-window-provider.md +18 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-print-provider.md +25 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-service-client-factory-provider.md +43 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-shared-data-provider.md +64 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-system-config-provider.md +46 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-system-log-provider.md +18 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-theme-provider.md +38 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-toast-provider.md +65 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/_common-rules.md +336 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-a-edit-save.md +191 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-b-delete-restore.md +103 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-c-modal-view.md +198 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-d-control-view.md +109 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-e-auxiliary.md +87 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-f-complex-detail.md +202 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail.md +280 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-a-inline-edit.md +386 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-b-selection.md +215 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-c-inline-delete.md +64 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-d-select-modal.md +193 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-e-readonly-modal.md +140 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-f-modal-edit.md +123 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-g-excel.md +145 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list.md +377 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/data-select-button.md +368 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/page-modal-container.md +238 -0
- package/claude/references/sd-simplysm-v14/angular/styling/classes.md +149 -0
- package/claude/references/sd-simplysm-v14/angular/styling/mixins.md +100 -0
- package/claude/references/sd-simplysm-v14/angular/styling/themes.md +35 -0
- package/claude/references/sd-simplysm-v14/angular/styling/variables.md +147 -0
- package/claude/references/sd-simplysm-v14/angular/type-utilities/directive-input-signals.md +232 -0
- package/claude/references/sd-simplysm-v14/angular/ui-data/sd-list.md +37 -0
- package/claude/references/sd-simplysm-v14/angular/ui-data/sd-sheet.md +212 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-additional-button.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-anchor.md +31 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-button.md +103 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-checkbox-group.md +39 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-checkbox.md +81 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-date-range-picker.md +27 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-form.md +89 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-modal-select-button.md +54 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-numpad.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-range.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-select.md +68 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-shared-data-select.md +52 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-state-preset.md +37 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-switch.md +27 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-textarea.md +33 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-textfield.md +145 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-dock-container.md +64 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-dock.md +37 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-gap.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban-board.md +96 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban-lane.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban.md +29 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-collapse.md +35 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-pagination.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-container.md +49 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-menu.md +22 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-user.md +43 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-tab.md +51 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-container.md +97 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-menu.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-user.md +38 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar.md +30 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-busy-container.md +69 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-confirm-modal.md +30 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-dropdown.md +40 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-modal.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-prompt-modal.md +30 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-toast.md +35 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-barcode.md +36 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-calendar.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-echarts.md +32 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-label.md +24 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-note.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-progress.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/utils/inject-routing-signals.md +161 -0
- package/claude/references/sd-simplysm-v14/angular/utils/inject-sd-system-config-resource.md +35 -0
- package/claude/references/sd-simplysm-v14/angular/utils/mark.md +43 -0
- package/claude/references/sd-simplysm-v14/angular/utils/selection-managers.md +96 -0
- package/claude/references/sd-simplysm-v14/angular/utils/set-safe-style.md +19 -0
- package/claude/references/sd-simplysm-v14/angular/utils/setup-functions.md +93 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/README.md +38 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/apk-installer/apk-installer.md +115 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/auto-update/auto-update.md +113 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-file-system/README.md +197 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-intent/README.md +235 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-usb-storage/README.md +251 -0
- package/claude/references/sd-simplysm-v14/core-browser/README.md +52 -0
- package/claude/references/sd-simplysm-v14/core-browser/extensions/copy-paste.md +59 -0
- package/claude/references/sd-simplysm-v14/core-browser/extensions/element-prototype-extensions.md +137 -0
- package/claude/references/sd-simplysm-v14/core-browser/extensions/get-bounds.md +84 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/download-blob.md +59 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/fetch-url-bytes.md +91 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/indexed-db-store.md +131 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/indexed-db-virtual-fs.md +121 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/open-file-dialog.md +60 -0
- package/claude/references/sd-simplysm-v14/core-common/README.md +179 -0
- package/claude/references/sd-simplysm-v14/core-common/errors/argument-error.md +26 -0
- package/claude/references/sd-simplysm-v14/core-common/errors/not-implemented-error.md +33 -0
- package/claude/references/sd-simplysm-v14/core-common/errors/sd-error.md +38 -0
- package/claude/references/sd-simplysm-v14/core-common/errors/timeout-error.md +36 -0
- package/claude/references/sd-simplysm-v14/core-common/extensions/array.md +125 -0
- package/claude/references/sd-simplysm-v14/core-common/extensions/map.md +43 -0
- package/claude/references/sd-simplysm-v14/core-common/extensions/set.md +35 -0
- package/claude/references/sd-simplysm-v14/core-common/features/debounce-queue.md +48 -0
- package/claude/references/sd-simplysm-v14/core-common/features/event-emitter.md +52 -0
- package/claude/references/sd-simplysm-v14/core-common/features/serial-queue.md +44 -0
- package/claude/references/sd-simplysm-v14/core-common/type-utils/common-types.md +100 -0
- package/claude/references/sd-simplysm-v14/core-common/type-utils/env.md +42 -0
- package/claude/references/sd-simplysm-v14/core-common/types/date-only.md +86 -0
- package/claude/references/sd-simplysm-v14/core-common/types/date-time.md +106 -0
- package/claude/references/sd-simplysm-v14/core-common/types/lazy-gc-map.md +59 -0
- package/claude/references/sd-simplysm-v14/core-common/types/time.md +62 -0
- package/claude/references/sd-simplysm-v14/core-common/types/uuid.md +41 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/bytes.md +36 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/dt.md +60 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/err.md +26 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/json.md +58 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/num.md +56 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/obj.md +107 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/path.md +30 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/primitive.md +28 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/str.md +63 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/template-strings.md +49 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/transfer.md +35 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/wait.md +35 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/xml.md +49 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/zip-archive.md +77 -0
- package/claude/references/sd-simplysm-v14/core-node/README.md +59 -0
- package/claude/references/sd-simplysm-v14/core-node/features/fs-watcher.md +110 -0
- package/claude/references/sd-simplysm-v14/core-node/logging/create-file-reporter.md +78 -0
- package/claude/references/sd-simplysm-v14/core-node/logging/pretty-reporter.md +38 -0
- package/claude/references/sd-simplysm-v14/core-node/logging/setup-consola.md +77 -0
- package/claude/references/sd-simplysm-v14/core-node/utils/cpx.md +128 -0
- package/claude/references/sd-simplysm-v14/core-node/utils/fsx.md +168 -0
- package/claude/references/sd-simplysm-v14/core-node/utils/pathx.md +73 -0
- package/claude/references/sd-simplysm-v14/core-node/worker/create-worker.md +85 -0
- package/claude/references/sd-simplysm-v14/core-node/worker/worker.md +160 -0
- package/claude/references/sd-simplysm-v14/excel/README.md +66 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-cell.md +79 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-col.md +36 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-row.md +34 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-workbook.md +93 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-worksheet.md +147 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-address-point.md +33 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-style-options.md +57 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-value-type.md +28 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-content-type-data.md +23 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-drawing-data.md +29 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-relationship-data.md +39 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-shared-string-data.md +42 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-style-data.md +97 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-workbook-data.md +22 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-worksheet-data.md +68 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml.md +15 -0
- package/claude/references/sd-simplysm-v14/excel/utilities/excel-utils.md +101 -0
- package/claude/references/sd-simplysm-v14/excel/wrapper/excel-wrapper.md +108 -0
- package/claude/references/sd-simplysm-v14/lint/README.md +183 -0
- package/claude/references/sd-simplysm-v14/orm-common/README.md +156 -0
- package/claude/references/sd-simplysm-v14/orm-common/core/db-context.md +208 -0
- package/claude/references/sd-simplysm-v14/orm-common/core/db-transaction-error.md +64 -0
- package/claude/references/sd-simplysm-v14/orm-common/expression/expr-unit.md +62 -0
- package/claude/references/sd-simplysm-v14/orm-common/expression/expr.md +198 -0
- package/claude/references/sd-simplysm-v14/orm-common/models/migration.md +37 -0
- package/claude/references/sd-simplysm-v14/orm-common/query-builder/create-query-builder.md +80 -0
- package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/executable.md +54 -0
- package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/parse-search-query.md +75 -0
- package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/queryable.md +238 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/column-builder.md +63 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/foreign-key-builder.md +137 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/index-builder.md +54 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/procedure.md +67 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/table.md +95 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/view.md +71 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/data-type.md +146 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/dialect.md +151 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/expr.md +175 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/parse-query-result.md +58 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/query-def.md +224 -0
- package/claude/references/sd-simplysm-v14/orm-node/README.md +65 -0
- package/claude/references/sd-simplysm-v14/orm-node/connections/mssql-db-conn.md +85 -0
- package/claude/references/sd-simplysm-v14/orm-node/connections/mysql-db-conn.md +83 -0
- package/claude/references/sd-simplysm-v14/orm-node/connections/postgresql-db-conn.md +86 -0
- package/claude/references/sd-simplysm-v14/orm-node/core/create-db-conn.md +62 -0
- package/claude/references/sd-simplysm-v14/orm-node/core/create-orm.md +107 -0
- package/claude/references/sd-simplysm-v14/orm-node/core/node-db-context-executor.md +50 -0
- package/claude/references/sd-simplysm-v14/orm-node/types/db-conn-config.md +91 -0
- package/claude/references/sd-simplysm-v14/orm-node/types/db-conn-constants.md +33 -0
- package/claude/references/sd-simplysm-v14/orm-node/types/db-conn.md +60 -0
- package/claude/references/sd-simplysm-v14/orm-node/types/get-dialect-from-config.md +17 -0
- package/{README.md → claude/references/sd-simplysm-v14/sd-claude/README.md} +85 -84
- package/{docs → claude/references/sd-simplysm-v14/sd-claude}/assets.md +2 -2
- package/{docs → claude/references/sd-simplysm-v14/sd-claude}/hooks.md +15 -1
- package/claude/references/sd-simplysm-v14/sd-cli/README.md +138 -0
- package/claude/references/sd-simplysm-v14/sd-cli/angular-vite-plugin/sd-angular-plugin.md +60 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/build-target.md +31 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/npm-config.md +27 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-browser-support-config.md +19 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-build-package-config.md +21 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-capacitor-config.md +109 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-client-package-config.md +33 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-config.md +78 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-electron-config.md +27 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-package-config.md +18 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-post-publish-script-config.md +19 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-publish-config.md +72 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-pwa-config.md +41 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-scripts-package-config.md +19 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-server-package-config.md +32 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-watch-hook-config.md +19 -0
- package/claude/references/sd-simplysm-v14/sd-cli/ts-compiler/sd-ts-compiler.md +158 -0
- package/claude/references/sd-simplysm-v14/service-client/README.md +74 -0
- package/claude/references/sd-simplysm-v14/service-client/features/event-client.md +93 -0
- package/claude/references/sd-simplysm-v14/service-client/features/file-client.md +63 -0
- package/claude/references/sd-simplysm-v14/service-client/features/orm-client-connector.md +89 -0
- package/claude/references/sd-simplysm-v14/service-client/features/orm-client-db-context-executor.md +31 -0
- package/claude/references/sd-simplysm-v14/service-client/main/service-client.md +206 -0
- package/claude/references/sd-simplysm-v14/service-client/protocol/client-protocol-wrapper.md +64 -0
- package/claude/references/sd-simplysm-v14/service-client/transport/service-transport.md +68 -0
- package/claude/references/sd-simplysm-v14/service-client/transport/socket-provider.md +100 -0
- package/claude/references/sd-simplysm-v14/service-client/types/blob-input.md +7 -0
- package/claude/references/sd-simplysm-v14/service-client/types/browser-worker.md +47 -0
- package/claude/references/sd-simplysm-v14/service-client/types/file-collection.md +21 -0
- package/claude/references/sd-simplysm-v14/service-client/types/service-connection-options.md +22 -0
- package/claude/references/sd-simplysm-v14/service-client/types/service-progress.md +39 -0
- package/claude/references/sd-simplysm-v14/service-common/README.md +161 -0
- package/claude/references/sd-simplysm-v14/service-common/app-structure/app-structure-item.md +107 -0
- package/claude/references/sd-simplysm-v14/service-common/app-structure/get-flat-permissions.md +57 -0
- package/claude/references/sd-simplysm-v14/service-common/app-structure/is-usable-modules-chain.md +23 -0
- package/claude/references/sd-simplysm-v14/service-common/app-structure/is-usable-modules.md +42 -0
- package/claude/references/sd-simplysm-v14/service-common/events/define-event.md +68 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/create-service-protocol.md +93 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/protocol-config.md +21 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-add-event-listener-message.md +23 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-auth-message.md +17 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-emit-event-message.md +21 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-error-message.md +29 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-event-message.md +21 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-get-event-listener-infos-message.md +19 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-message.md +52 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-progress-message.md +21 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-remove-event-listener-message.md +19 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-request-message.md +17 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-response-message.md +17 -0
- package/claude/references/sd-simplysm-v14/service-common/service-types/app-structure-service.md +15 -0
- package/claude/references/sd-simplysm-v14/service-common/service-types/auto-update-service.md +20 -0
- package/claude/references/sd-simplysm-v14/service-common/service-types/orm-service.md +61 -0
- package/claude/references/sd-simplysm-v14/service-common/types/service-upload-result.md +19 -0
- package/claude/references/sd-simplysm-v14/service-server/README.md +162 -0
- package/claude/references/sd-simplysm-v14/service-server/auth/auth-token-payload.md +18 -0
- package/claude/references/sd-simplysm-v14/service-server/auth/sign-jwt.md +30 -0
- package/claude/references/sd-simplysm-v14/service-server/auth/verify-jwt.md +35 -0
- package/claude/references/sd-simplysm-v14/service-server/core/auth.md +64 -0
- package/claude/references/sd-simplysm-v14/service-server/core/define-service.md +81 -0
- package/claude/references/sd-simplysm-v14/service-server/core/execute-service-method.md +43 -0
- package/claude/references/sd-simplysm-v14/service-server/core/service-context.md +79 -0
- package/claude/references/sd-simplysm-v14/service-server/legacy/handle-v1-connection.md +25 -0
- package/claude/references/sd-simplysm-v14/service-server/main/create-service-server.md +32 -0
- package/claude/references/sd-simplysm-v14/service-server/main/service-server.md +113 -0
- package/claude/references/sd-simplysm-v14/service-server/protocol/server-protocol-wrapper.md +35 -0
- package/claude/references/sd-simplysm-v14/service-server/services/app-structure-service.md +59 -0
- package/claude/references/sd-simplysm-v14/service-server/services/auto-update-service.md +34 -0
- package/claude/references/sd-simplysm-v14/service-server/services/orm-service.md +43 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-http-request.md +33 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-static-file.md +29 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-upload.md +33 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-socket/service-socket.md +64 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-socket/websocket-handler.md +57 -0
- package/claude/references/sd-simplysm-v14/service-server/types/service-server-options.md +36 -0
- package/claude/references/sd-simplysm-v14/service-server/utils/get-config.md +29 -0
- package/claude/references/sd-simplysm-v14/storage/README.md +99 -0
- package/claude/references/sd-simplysm-v14/storage/clients/ftp-storage-client.md +99 -0
- package/claude/references/sd-simplysm-v14/storage/clients/sftp-storage-client.md +108 -0
- package/claude/references/sd-simplysm-v14/storage/factory/storage-factory.md +114 -0
- package/claude/references/sd-simplysm-v14/storage/types/file-info.md +32 -0
- package/claude/references/sd-simplysm-v14/storage/types/storage-client.md +55 -0
- package/claude/references/sd-simplysm-v14/storage/types/storage-conn-config.md +34 -0
- package/claude/rules/sd-claude-rules.md +8 -8
- package/claude/rules/sd-simplysm-v14.md +33 -0
- package/claude/skills/sd-claude-docs/SKILL.md +41 -24
- package/claude/skills/sd-claude-docs/references/package-docs.md +240 -116
- package/claude/skills/sd-inner-debug/SKILL.md +1 -1
- package/claude/skills/sd-inner-review/SKILL.md +4 -2
- package/package.json +2 -3
- /package/{docs → claude/references/sd-simplysm-v14/sd-claude}/cli.md +0 -0
- /package/{docs → claude/references/sd-simplysm-v14/sd-claude}/scripts.md +0 -0
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
# @simplysm/sd-cli
|
|
2
|
+
|
|
3
|
+
Simplysm 모노레포용 빌드/개발/배포 CLI 도구. `sd.config.ts` 설정 타입과 Angular AOT Vite 플러그인(`sdAngularPlugin`)을 export한다.
|
|
4
|
+
|
|
5
|
+
## Installation
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
npm install @simplysm/sd-cli
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## 하려는 작업 → 먼저 읽을 파일
|
|
12
|
+
|
|
13
|
+
| 작업 | 먼저 읽을 파일 |
|
|
14
|
+
|------|----------------|
|
|
15
|
+
| `sd.config.ts` 작성 | [SdConfig](./config/sd-config.md), [SdPackageConfig](./config/sd-package-config.md) |
|
|
16
|
+
| 클라이언트 패키지 설정 | [SdClientPackageConfig](./config/sd-client-package-config.md) |
|
|
17
|
+
| 서버 패키지 설정 | [SdServerPackageConfig](./config/sd-server-package-config.md) |
|
|
18
|
+
| 배포 설정 (npm/FTP/SFTP) | [SdPublishConfig](./config/sd-publish-config.md) |
|
|
19
|
+
| Capacitor 앱 설정 | [SdCapacitorConfig](./config/sd-capacitor-config.md) |
|
|
20
|
+
| Electron 앱 설정 | [SdElectronConfig](./config/sd-electron-config.md) |
|
|
21
|
+
| 프로그래매틱 TypeScript 컴파일 | [SdTsCompiler](./ts-compiler/sd-ts-compiler.md) |
|
|
22
|
+
| Vitest Angular 테스트 | [sdAngularPlugin](./angular-vite-plugin/sd-angular-plugin.md) |
|
|
23
|
+
|
|
24
|
+
## API Overview
|
|
25
|
+
|
|
26
|
+
### Config
|
|
27
|
+
|
|
28
|
+
| Entry | Kind | 언제 쓰나 |
|
|
29
|
+
|-------|------|-----------|
|
|
30
|
+
| [`SdConfig`](./config/sd-config.md) | interface | `sd.config.ts` 작성 시 최상위 설정 타입이 필요할 때 |
|
|
31
|
+
| [`SdPackageConfig`](./config/sd-package-config.md) | type | 패키지 target에 따라 분기해야 할 때 (`target` 필드 discriminated union) |
|
|
32
|
+
| [`SdBuildPackageConfig`](./config/sd-build-package-config.md) | interface | `node`/`browser`/`neutral` 라이브러리 패키지를 설정할 때 |
|
|
33
|
+
| [`SdClientPackageConfig`](./config/sd-client-package-config.md) | interface | `client` 타겟 프론트엔드 패키지를 설정할 때 |
|
|
34
|
+
| [`SdServerPackageConfig`](./config/sd-server-package-config.md) | interface | `server` 타겟 Fastify 서버 패키지를 설정할 때 |
|
|
35
|
+
| [`SdScriptsPackageConfig`](./config/sd-scripts-package-config.md) | interface | 빌드 없이 watch 훅만 실행하는 스크립트 패키지를 설정할 때 |
|
|
36
|
+
| [`BuildTarget`](./config/build-target.md) | type | 라이브러리 패키지의 빌드 플랫폼을 지정할 때 (`"node"` \| `"browser"` \| `"neutral"`) |
|
|
37
|
+
| [`SdPublishConfig`](./config/sd-publish-config.md) | type | 패키지 배포 방식을 설정할 때 (npm / 로컬 디렉토리 / FTP·SFTP) |
|
|
38
|
+
| [`SdPostPublishScriptConfig`](./config/sd-post-publish-script-config.md) | interface | 배포 후 스크립트를 실행할 때 |
|
|
39
|
+
| [`SdCapacitorConfig`](./config/sd-capacitor-config.md) | interface | 클라이언트 패키지에 Capacitor 모바일 앱 설정을 추가할 때 |
|
|
40
|
+
| [`SdElectronConfig`](./config/sd-electron-config.md) | interface | 클라이언트 패키지에 Electron 데스크톱 앱 설정을 추가할 때 |
|
|
41
|
+
| [`SdPwaConfig`](./config/sd-pwa-config.md) | interface | PWA manifest를 설정할 때 |
|
|
42
|
+
| [`SdBrowserSupportConfig`](./config/sd-browser-support-config.md) | interface | 클라이언트 패키지의 브라우저 호환성(browserslist, PostCSS)을 설정할 때 |
|
|
43
|
+
| [`SdWatchHookConfig`](./config/sd-watch-hook-config.md) | interface | watch 모드에서 파일 변경 시 명령어 훅을 실행할 때 |
|
|
44
|
+
| [`NpmConfig`](./config/npm-config.md) | interface | `package.json` 구조를 타입으로 참조해야 할 때 |
|
|
45
|
+
|
|
46
|
+
### TypeScript Compiler
|
|
47
|
+
|
|
48
|
+
| Entry | Kind | 언제 쓰나 |
|
|
49
|
+
|-------|------|-----------|
|
|
50
|
+
| [`SdTsCompiler`](./ts-compiler/sd-ts-compiler.md) | class | Angular/TS 패키지를 프로그래매틱하게 AOT 컴파일할 때 |
|
|
51
|
+
|
|
52
|
+
### Angular Vite Plugin
|
|
53
|
+
|
|
54
|
+
| Entry | Kind | 언제 쓰나 |
|
|
55
|
+
|-------|------|-----------|
|
|
56
|
+
| [`sdAngularPlugin`](./angular-vite-plugin/sd-angular-plugin.md) | function | Vitest에서 Angular 컴포넌트 테스트 시 AOT 컴파일이 필요할 때 |
|
|
57
|
+
|
|
58
|
+
## Usage Examples
|
|
59
|
+
|
|
60
|
+
### SdTsCompiler를 사용한 TypeScript 컴파일
|
|
61
|
+
|
|
62
|
+
```typescript
|
|
63
|
+
import { SdTsCompiler } from "@simplysm/sd-cli";
|
|
64
|
+
|
|
65
|
+
const compiler = new SdTsCompiler({
|
|
66
|
+
pkgDir: "/workspace/packages/my-lib",
|
|
67
|
+
cwd: "/workspace",
|
|
68
|
+
output: { js: true, dts: true },
|
|
69
|
+
lint: true,
|
|
70
|
+
globalScss: true,
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
// 초기 컴파일
|
|
74
|
+
const result = await compiler.compileAsync();
|
|
75
|
+
|
|
76
|
+
if (result.errors) {
|
|
77
|
+
console.error("Compilation errors:", result.errors);
|
|
78
|
+
process.exit(1);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
console.log(`Compiled ${result.affectedFiles?.size ?? "all"} files`);
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
### watch 모드에서 증분 컴파일
|
|
85
|
+
|
|
86
|
+
```typescript
|
|
87
|
+
import { SdTsCompiler } from "@simplysm/sd-cli";
|
|
88
|
+
|
|
89
|
+
const compiler = new SdTsCompiler({
|
|
90
|
+
pkgDir: "/workspace/packages/my-lib",
|
|
91
|
+
cwd: "/workspace",
|
|
92
|
+
output: { js: true, dts: true },
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
// 초기 컴파일
|
|
96
|
+
let result = await compiler.compileAsync();
|
|
97
|
+
|
|
98
|
+
// 파일 변경 감지 시 증분 컴파일
|
|
99
|
+
const changedFiles = new Set(["/workspace/packages/my-lib/src/foo.ts"]);
|
|
100
|
+
result = await compiler.compileAsync(changedFiles);
|
|
101
|
+
|
|
102
|
+
// SCSS 의존성이 변경된 TS 파일 찾기
|
|
103
|
+
const affectedByScss = compiler.findAffectedByScss("/workspace/packages/my-lib/scss/variables.scss");
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
### sd.config.ts 작성
|
|
107
|
+
|
|
108
|
+
```typescript
|
|
109
|
+
import type { SdConfigFn } from "@simplysm/sd-cli";
|
|
110
|
+
|
|
111
|
+
const config: SdConfigFn = (params) => ({
|
|
112
|
+
packages: {
|
|
113
|
+
"core-common": { target: "neutral" },
|
|
114
|
+
"core-node": { target: "node" },
|
|
115
|
+
"my-client": {
|
|
116
|
+
target: "client",
|
|
117
|
+
server: "my-server",
|
|
118
|
+
},
|
|
119
|
+
"my-server": {
|
|
120
|
+
target: "server",
|
|
121
|
+
publish: { type: "npm" },
|
|
122
|
+
},
|
|
123
|
+
},
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
export default config;
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
### Vite에서 Angular AOT 플러그인 사용
|
|
130
|
+
|
|
131
|
+
```typescript
|
|
132
|
+
import { defineConfig } from "vite";
|
|
133
|
+
import { sdAngularPlugin } from "@simplysm/sd-cli";
|
|
134
|
+
|
|
135
|
+
export default defineConfig({
|
|
136
|
+
plugins: [sdAngularPlugin({ pkg: "my-client" })],
|
|
137
|
+
});
|
|
138
|
+
```
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
# sdAngularPlugin
|
|
2
|
+
|
|
3
|
+
Angular AOT 컴파일을 수행하는 Vite 플러그인. Vitest 환경에서 Angular 컴포넌트를 포함한 TypeScript 패키지를 컴파일할 때 사용한다.
|
|
4
|
+
|
|
5
|
+
## When to use
|
|
6
|
+
|
|
7
|
+
- ✅ Vitest에서 Angular 컴포넌트/서비스를 포함한 패키지를 테스트할 때 — `vitest.config.ts`에 플러그인 등록
|
|
8
|
+
- ❌ 프로덕션 빌드 — sd-cli가 내부적으로 esbuild + Angular 컴파일러 플러그인을 사용하므로 직접 사용 불필요
|
|
9
|
+
- ❌ Non-Angular 패키지 테스트 — Vite의 기본 TypeScript 처리로 충분
|
|
10
|
+
|
|
11
|
+
```typescript
|
|
12
|
+
export function sdAngularPlugin(options: SdAngularPluginOptions): Plugin;
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
## Parameters
|
|
16
|
+
|
|
17
|
+
| Param | Type | Description |
|
|
18
|
+
|-------|------|-------------|
|
|
19
|
+
| `options` | `SdAngularPluginOptions` | 플러그인 옵션 |
|
|
20
|
+
|
|
21
|
+
## Returns
|
|
22
|
+
|
|
23
|
+
`Plugin` — Vite 플러그인 객체
|
|
24
|
+
|
|
25
|
+
## Vite 훅
|
|
26
|
+
|
|
27
|
+
| 훅 | 동작 |
|
|
28
|
+
|----|------|
|
|
29
|
+
| `config` | `process.cwd()/packages/{pkg}` 경로를 `resolvedPkgDir`로 초기화 |
|
|
30
|
+
| `watchChange` | Vitest watch 모드에서 변경된 파일 경로를 `pendingWatchChanges`에 수집 |
|
|
31
|
+
| `buildStart` | `SdTsCompiler` 초기화 → `compileAsync()` → emit 결과를 내부 맵에 캐싱. watch 재빌드 시 변경 파일로 증분 재컴파일 |
|
|
32
|
+
| `transform` | `.ts` 파일 요청 시 캐싱된 컴파일 결과 반환 + 인라인 소스맵 분리 |
|
|
33
|
+
| `buildEnd` | `SdTsCompiler` 참조 해제 |
|
|
34
|
+
|
|
35
|
+
## Related Types
|
|
36
|
+
|
|
37
|
+
### `SdAngularPluginOptions`
|
|
38
|
+
|
|
39
|
+
```typescript
|
|
40
|
+
export interface SdAngularPluginOptions {
|
|
41
|
+
pkg: string;
|
|
42
|
+
}
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
| Field | Type | Description |
|
|
46
|
+
|-------|------|-------------|
|
|
47
|
+
| `pkg` | `string` | `sd.config.ts` `packages` 키 (패키지 디렉토리명). 예: `"my-client"` |
|
|
48
|
+
|
|
49
|
+
## Usage
|
|
50
|
+
|
|
51
|
+
`vite.config.ts` 또는 `vitest.config.ts`에 플러그인을 등록한다.
|
|
52
|
+
|
|
53
|
+
```typescript
|
|
54
|
+
import { defineConfig } from "vite";
|
|
55
|
+
import { sdAngularPlugin } from "@simplysm/sd-cli";
|
|
56
|
+
|
|
57
|
+
export default defineConfig({
|
|
58
|
+
plugins: [sdAngularPlugin({ pkg: "my-client" })],
|
|
59
|
+
});
|
|
60
|
+
```
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
# BuildTarget
|
|
2
|
+
|
|
3
|
+
esbuild로 빌드되는 라이브러리 패키지의 타겟 플랫폼을 나타내는 타입.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export type BuildTarget = "node" | "browser" | "neutral";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
| 값 | 설명 |
|
|
10
|
+
|----|------|
|
|
11
|
+
| `"node"` | Node.js 전용 패키지. esbuild `platform: "node"` |
|
|
12
|
+
| `"browser"` | 브라우저 전용 패키지. esbuild `platform: "browser"` |
|
|
13
|
+
| `"neutral"` | Node/브라우저 공용 패키지. esbuild `platform: "neutral"` |
|
|
14
|
+
|
|
15
|
+
## Usage
|
|
16
|
+
|
|
17
|
+
[`SdBuildPackageConfig`](./sd-build-package-config.md)의 `target` 필드에 사용한다.
|
|
18
|
+
|
|
19
|
+
```typescript
|
|
20
|
+
import type { SdConfigFn } from "@simplysm/sd-cli";
|
|
21
|
+
|
|
22
|
+
const config: SdConfigFn = () => ({
|
|
23
|
+
packages: {
|
|
24
|
+
"core-common": { target: "neutral" },
|
|
25
|
+
"core-node": { target: "node" },
|
|
26
|
+
"core-browser": { target: "browser" },
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
export default config;
|
|
31
|
+
```
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
# NpmConfig
|
|
2
|
+
|
|
3
|
+
npm `package.json` 구조를 나타내는 인터페이스. 패키지 의존성 탐색, 버전 조회 등 내부 유틸리티에서 사용한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export interface NpmConfig {
|
|
7
|
+
name: string;
|
|
8
|
+
version: string;
|
|
9
|
+
description?: string;
|
|
10
|
+
dependencies?: Record<string, string>;
|
|
11
|
+
devDependencies?: Record<string, string>;
|
|
12
|
+
peerDependencies?: Record<string, string>;
|
|
13
|
+
volta?: unknown;
|
|
14
|
+
}
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
## Members
|
|
18
|
+
|
|
19
|
+
| Field | Type | Description |
|
|
20
|
+
|-------|------|-------------|
|
|
21
|
+
| `name` | `string` | 패키지명 |
|
|
22
|
+
| `version` | `string` | 패키지 버전 |
|
|
23
|
+
| `description` | `string?` | 패키지 설명 |
|
|
24
|
+
| `dependencies` | `Record<string, string>?` | 프로덕션 의존성 |
|
|
25
|
+
| `devDependencies` | `Record<string, string>?` | 개발 의존성 |
|
|
26
|
+
| `peerDependencies` | `Record<string, string>?` | 피어 의존성 |
|
|
27
|
+
| `volta` | `unknown?` | Volta 설정 |
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# SdBrowserSupportConfig
|
|
2
|
+
|
|
3
|
+
클라이언트 패키지의 브라우저 지원 설정. [`SdClientPackageConfig`](./sd-client-package-config.md)의 `browserSupport` 필드에 사용한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export interface SdBrowserSupportConfig {
|
|
7
|
+
browserslist?: string | string[];
|
|
8
|
+
postCss?: { plugins: [string, (object | string)?][] };
|
|
9
|
+
legacyModule?: boolean;
|
|
10
|
+
}
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
## Members
|
|
14
|
+
|
|
15
|
+
| Field | Type | Description |
|
|
16
|
+
|-------|------|-------------|
|
|
17
|
+
| `browserslist` | `string \| string[]?` | browserslist 쿼리. esbuild target으로 변환되어 문법(syntax)만 다운레벨 컴파일된다. 예: `"last 2 Chrome versions"` |
|
|
18
|
+
| `postCss` | `{ plugins: [string, (object \| string)?][] }?` | PostCSS 플러그인 설정. `[패키지명, 옵션]` 튜플 배열 |
|
|
19
|
+
| `legacyModule` | `boolean?` | 레거시 모듈 지원. `true`이면 코드 분할 비활성화 + `import.meta` 치환 |
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
# SdBuildPackageConfig
|
|
2
|
+
|
|
3
|
+
`node` / `browser` / `neutral` 타겟 라이브러리 패키지 설정. esbuild + tsc로 빌드된다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export interface SdBuildPackageConfig {
|
|
7
|
+
target: BuildTarget;
|
|
8
|
+
publish?: SdPublishConfig;
|
|
9
|
+
copySrc?: string[];
|
|
10
|
+
watch?: SdWatchHookConfig;
|
|
11
|
+
}
|
|
12
|
+
```
|
|
13
|
+
|
|
14
|
+
## Members
|
|
15
|
+
|
|
16
|
+
| Field | Type | Description |
|
|
17
|
+
|-------|------|-------------|
|
|
18
|
+
| `target` | [`BuildTarget`](./build-target.md) | 빌드 타겟 (`"node"` \| `"browser"` \| `"neutral"`) |
|
|
19
|
+
| `publish` | [`SdPublishConfig?`](./sd-publish-config.md) | 배포 설정 |
|
|
20
|
+
| `copySrc` | `string[]?` | `src/`에서 `dist/`로 복사할 파일의 glob 패턴 (`src/` 기준 상대 경로) |
|
|
21
|
+
| `watch` | [`SdWatchHookConfig?`](./sd-watch-hook-config.md) | watch 훅 설정. 설정 시 watch 모드에서 빌드 엔진과 함께 훅이 실행된다 |
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
# SdCapacitorConfig
|
|
2
|
+
|
|
3
|
+
Capacitor 모바일 앱 설정. [`SdClientPackageConfig`](./sd-client-package-config.md)의 `capacitor` 필드에 사용한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export interface SdCapacitorConfig {
|
|
7
|
+
appId: string;
|
|
8
|
+
appName: string;
|
|
9
|
+
plugins?: Record<string, Record<string, unknown> | true>;
|
|
10
|
+
icon?: string;
|
|
11
|
+
debug?: boolean;
|
|
12
|
+
platform?: {
|
|
13
|
+
android?: SdCapacitorAndroidConfig;
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
## Members
|
|
19
|
+
|
|
20
|
+
| Field | Type | Description |
|
|
21
|
+
|-------|------|-------------|
|
|
22
|
+
| `appId` | `string` | 앱 ID (예: `"com.example.app"`) |
|
|
23
|
+
| `appName` | `string` | 앱 이름 |
|
|
24
|
+
| `plugins` | `Record<string, Record<string, unknown> \| true>?` | Capacitor 플러그인 설정. key: 패키지명, value: `true` 또는 플러그인 옵션 객체 |
|
|
25
|
+
| `icon` | `string?` | 앱 아이콘 경로 (패키지 디렉토리 기준 상대 경로) |
|
|
26
|
+
| `debug` | `boolean?` | 디버그 빌드 플래그 |
|
|
27
|
+
| `platform` | `{ android?: SdCapacitorAndroidConfig }?` | 플랫폼별 설정 |
|
|
28
|
+
|
|
29
|
+
## Related Types
|
|
30
|
+
|
|
31
|
+
### `SdCapacitorAndroidConfig`
|
|
32
|
+
|
|
33
|
+
Capacitor Android 플랫폼 설정.
|
|
34
|
+
|
|
35
|
+
```typescript
|
|
36
|
+
export interface SdCapacitorAndroidConfig {
|
|
37
|
+
config?: Record<string, string>;
|
|
38
|
+
bundle?: boolean;
|
|
39
|
+
intentFilters?: SdCapacitorIntentFilter[];
|
|
40
|
+
sign?: SdCapacitorSignConfig;
|
|
41
|
+
sdkVersion?: number;
|
|
42
|
+
permissions?: SdCapacitorPermission[];
|
|
43
|
+
}
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
| Field | Type | Description |
|
|
47
|
+
|-------|------|-------------|
|
|
48
|
+
| `config` | `Record<string, string>?` | AndroidManifest.xml `application` 태그 속성 (예: `{ requestLegacyExternalStorage: "true" }`) |
|
|
49
|
+
| `bundle` | `boolean?` | AAB 번들 빌드 플래그. `false`이면 APK |
|
|
50
|
+
| `intentFilters` | `SdCapacitorIntentFilter[]?` | Intent Filter 설정 |
|
|
51
|
+
| `sign` | `SdCapacitorSignConfig?` | APK/AAB 서명 설정 |
|
|
52
|
+
| `sdkVersion` | `number?` | Android SDK 버전 (minSdk, targetSdk에 동시 적용) |
|
|
53
|
+
| `permissions` | `SdCapacitorPermission[]?` | 추가 권한 설정 |
|
|
54
|
+
|
|
55
|
+
### `SdCapacitorSignConfig`
|
|
56
|
+
|
|
57
|
+
Android APK/AAB 서명 설정.
|
|
58
|
+
|
|
59
|
+
```typescript
|
|
60
|
+
export interface SdCapacitorSignConfig {
|
|
61
|
+
keystore: string;
|
|
62
|
+
storePassword: string;
|
|
63
|
+
alias: string;
|
|
64
|
+
password: string;
|
|
65
|
+
keystoreType?: string;
|
|
66
|
+
}
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
| Field | Type | Description |
|
|
70
|
+
|-------|------|-------------|
|
|
71
|
+
| `keystore` | `string` | keystore 파일 경로 (패키지 디렉토리 기준 상대 경로) |
|
|
72
|
+
| `storePassword` | `string` | keystore 비밀번호 |
|
|
73
|
+
| `alias` | `string` | 키 별칭 |
|
|
74
|
+
| `password` | `string` | 키 비밀번호 |
|
|
75
|
+
| `keystoreType` | `string?` | keystore 타입 (기본값: `"jks"`) |
|
|
76
|
+
|
|
77
|
+
### `SdCapacitorPermission`
|
|
78
|
+
|
|
79
|
+
Android 권한 설정.
|
|
80
|
+
|
|
81
|
+
```typescript
|
|
82
|
+
export interface SdCapacitorPermission {
|
|
83
|
+
name: string;
|
|
84
|
+
maxSdkVersion?: number;
|
|
85
|
+
ignore?: string;
|
|
86
|
+
}
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
| Field | Type | Description |
|
|
90
|
+
|-------|------|-------------|
|
|
91
|
+
| `name` | `string` | 권한 이름 (예: `"CAMERA"`, `"WRITE_EXTERNAL_STORAGE"`) |
|
|
92
|
+
| `maxSdkVersion` | `number?` | 이 권한을 적용할 최대 SDK 버전 |
|
|
93
|
+
| `ignore` | `string?` | `tools:ignore` 속성 값 |
|
|
94
|
+
|
|
95
|
+
### `SdCapacitorIntentFilter`
|
|
96
|
+
|
|
97
|
+
Android Intent Filter 설정.
|
|
98
|
+
|
|
99
|
+
```typescript
|
|
100
|
+
export interface SdCapacitorIntentFilter {
|
|
101
|
+
action?: string;
|
|
102
|
+
category?: string;
|
|
103
|
+
}
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
| Field | Type | Description |
|
|
107
|
+
|-------|------|-------------|
|
|
108
|
+
| `action` | `string?` | intent 액션 (예: `"android.intent.action.VIEW"`) |
|
|
109
|
+
| `category` | `string?` | intent 카테고리 (예: `"android.intent.category.DEFAULT"`) |
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
# SdClientPackageConfig
|
|
2
|
+
|
|
3
|
+
`client` 타겟 패키지 설정. esbuild 기반으로 빌드되며 개발 시 Vite dev server를 사용한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export interface SdClientPackageConfig {
|
|
7
|
+
target: "client";
|
|
8
|
+
server: string | number;
|
|
9
|
+
env?: Record<string, string>;
|
|
10
|
+
publish?: SdPublishConfig;
|
|
11
|
+
capacitor?: SdCapacitorConfig;
|
|
12
|
+
electron?: SdElectronConfig;
|
|
13
|
+
configs?: Record<string, unknown>;
|
|
14
|
+
exclude?: string[];
|
|
15
|
+
browserSupport?: SdBrowserSupportConfig;
|
|
16
|
+
pwa?: false | SdPwaConfig;
|
|
17
|
+
}
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
## Members
|
|
21
|
+
|
|
22
|
+
| Field | Type | Description |
|
|
23
|
+
|-------|------|-------------|
|
|
24
|
+
| `target` | `"client"` | 빌드 타겟 식별자 |
|
|
25
|
+
| `server` | `string \| number` | 연결할 서버 패키지명 (예: `"my-server"`) 또는 포트 직접 지정 (하위 호환) |
|
|
26
|
+
| `env` | `Record<string, string>?` | 빌드 시 치환할 환경 변수. `process.env`를 객체로 치환 |
|
|
27
|
+
| `publish` | [`SdPublishConfig?`](./sd-publish-config.md) | 배포 설정 |
|
|
28
|
+
| `capacitor` | [`SdCapacitorConfig?`](./sd-capacitor-config.md) | Capacitor 모바일 앱 설정 |
|
|
29
|
+
| `electron` | [`SdElectronConfig?`](./sd-electron-config.md) | Electron 데스크톱 앱 설정 |
|
|
30
|
+
| `configs` | `Record<string, unknown>?` | 런타임 설정. 빌드 시 `dist/.config.json`으로 기록 |
|
|
31
|
+
| `exclude` | `string[]?` | Capacitor/Electron `package.json`에 추가할 패키지 목록 |
|
|
32
|
+
| `browserSupport` | [`SdBrowserSupportConfig?`](./sd-browser-support-config.md) | 브라우저 지원 설정 |
|
|
33
|
+
| `pwa` | `false \| SdPwaConfig?` | PWA 설정. `false`이면 비활성화. 미지정 시 기본값으로 활성화 |
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
# SdConfig
|
|
2
|
+
|
|
3
|
+
`sd.config.ts` 설정 타입. `sd.config.ts`는 반드시 [`SdConfigFn`](#sdconfigfn) 형식의 함수를 default export해야 한다.
|
|
4
|
+
|
|
5
|
+
## When to use
|
|
6
|
+
|
|
7
|
+
- ✅ 프로젝트 루트에 `sd.config.ts`를 작성할 때 — 이 인터페이스가 최상위 설정 구조를 정의한다
|
|
8
|
+
- ✅ 의존성 교체(`replaceDeps`) 또는 배포 후 스크립트(`postPublish`)를 설정할 때
|
|
9
|
+
|
|
10
|
+
```typescript
|
|
11
|
+
export interface SdConfig {
|
|
12
|
+
packages: Record<string, SdPackageConfig | undefined>;
|
|
13
|
+
replaceDeps?: Record<string, string>;
|
|
14
|
+
postPublish?: SdPostPublishScriptConfig[];
|
|
15
|
+
}
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
## Members
|
|
19
|
+
|
|
20
|
+
| Field | Type | Description |
|
|
21
|
+
|-------|------|-------------|
|
|
22
|
+
| `packages` | `Record<string, SdPackageConfig \| undefined>` | 패키지별 설정. key: `packages/` 하위 디렉토리명 (예: `"core-common"`) |
|
|
23
|
+
| `replaceDeps` | `Record<string, string>?` | 의존성 교체 설정. `node_modules` 패키지를 로컬 소스로 심링크 교체. key: 패키지 glob 패턴, value: 소스 디렉토리 경로. key의 `*`에서 캡처된 값이 value의 `*`에 치환됨 |
|
|
24
|
+
| `postPublish` | [`SdPostPublishScriptConfig[]?`](./sd-post-publish-script-config.md) | 배포 완료 후 실행할 스크립트 목록 |
|
|
25
|
+
|
|
26
|
+
## Related Types
|
|
27
|
+
|
|
28
|
+
### `SdConfigParams`
|
|
29
|
+
|
|
30
|
+
`sd.config.ts` 함수에 전달되는 매개변수.
|
|
31
|
+
|
|
32
|
+
```typescript
|
|
33
|
+
export interface SdConfigParams {
|
|
34
|
+
cwd: string;
|
|
35
|
+
dev: boolean;
|
|
36
|
+
opt: string[];
|
|
37
|
+
}
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
| Field | Type | Description |
|
|
41
|
+
|-------|------|-------------|
|
|
42
|
+
| `cwd` | `string` | 현재 작업 디렉토리 |
|
|
43
|
+
| `dev` | `boolean` | 개발 모드 플래그 (`pnpm dev` 실행 시 `true`) |
|
|
44
|
+
| `opt` | `string[]` | 추가 옵션 (`-o` 플래그에서 전달된 값 배열) |
|
|
45
|
+
|
|
46
|
+
### `SdConfigFn`
|
|
47
|
+
|
|
48
|
+
`sd.config.ts`가 default export해야 하는 함수 타입.
|
|
49
|
+
|
|
50
|
+
```typescript
|
|
51
|
+
export type SdConfigFn = (params: SdConfigParams) => SdConfig | Promise<SdConfig>;
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
## Usage
|
|
55
|
+
|
|
56
|
+
```typescript
|
|
57
|
+
import type { SdConfigFn } from "@simplysm/sd-cli";
|
|
58
|
+
|
|
59
|
+
const config: SdConfigFn = (params) => ({
|
|
60
|
+
packages: {
|
|
61
|
+
"core-common": { target: "neutral" },
|
|
62
|
+
"core-node": { target: "node" },
|
|
63
|
+
"my-client": {
|
|
64
|
+
target: "client",
|
|
65
|
+
server: "my-server",
|
|
66
|
+
},
|
|
67
|
+
"my-server": {
|
|
68
|
+
target: "server",
|
|
69
|
+
publish: { type: "npm" },
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
replaceDeps: {
|
|
73
|
+
"@simplysm/*": "../simplysm/packages/*",
|
|
74
|
+
},
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
export default config;
|
|
78
|
+
```
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
# SdElectronConfig
|
|
2
|
+
|
|
3
|
+
Electron 데스크톱 앱 설정. [`SdClientPackageConfig`](./sd-client-package-config.md)의 `electron` 필드에 사용한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export interface SdElectronConfig {
|
|
7
|
+
appId: string;
|
|
8
|
+
portable?: boolean;
|
|
9
|
+
installerIcon?: string;
|
|
10
|
+
reinstallDependencies?: string[];
|
|
11
|
+
postInstallScript?: string;
|
|
12
|
+
nsisOptions?: Record<string, unknown>;
|
|
13
|
+
env?: Record<string, string>;
|
|
14
|
+
}
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
## Members
|
|
18
|
+
|
|
19
|
+
| Field | Type | Description |
|
|
20
|
+
|-------|------|-------------|
|
|
21
|
+
| `appId` | `string` | Electron 앱 ID (예: `"com.example.myapp"`) |
|
|
22
|
+
| `portable` | `boolean?` | `true`이면 포터블 `.exe`, `false`/미지정이면 NSIS 설치 프로그램 |
|
|
23
|
+
| `installerIcon` | `string?` | 설치 프로그램 아이콘 경로 (`.ico`, 패키지 디렉토리 기준 상대 경로) |
|
|
24
|
+
| `reinstallDependencies` | `string[]?` | Electron에 포함할 npm 패키지 목록 (네이티브 모듈 등 별도 설치 필요 패키지) |
|
|
25
|
+
| `postInstallScript` | `string?` | npm `postinstall` 스크립트 |
|
|
26
|
+
| `nsisOptions` | `Record<string, unknown>?` | NSIS 옵션. `portable`이 `false`일 때 적용 |
|
|
27
|
+
| `env` | `Record<string, string>?` | 환경 변수. `electron-main.ts`에서 `process.env`로 접근 가능 |
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
# SdPackageConfig
|
|
2
|
+
|
|
3
|
+
`sd.config.ts`의 패키지별 설정. `target` 필드로 분기하는 discriminated union이다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export type SdPackageConfig =
|
|
7
|
+
| SdBuildPackageConfig
|
|
8
|
+
| SdClientPackageConfig
|
|
9
|
+
| SdServerPackageConfig
|
|
10
|
+
| SdScriptsPackageConfig;
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
| `target` 값 | 타입 | 설명 |
|
|
14
|
+
|-------------|------|------|
|
|
15
|
+
| `"node"` \| `"browser"` \| `"neutral"` | [`SdBuildPackageConfig`](./sd-build-package-config.md) | esbuild+tsc로 빌드되는 라이브러리 패키지 |
|
|
16
|
+
| `"client"` | [`SdClientPackageConfig`](./sd-client-package-config.md) | Vite/esbuild로 빌드되는 프론트엔드 패키지 |
|
|
17
|
+
| `"server"` | [`SdServerPackageConfig`](./sd-server-package-config.md) | esbuild로 빌드되는 Fastify 서버 패키지 |
|
|
18
|
+
| `"scripts"` | [`SdScriptsPackageConfig`](./sd-scripts-package-config.md) | 빌드 없이 watch 훅만 실행하는 스크립트 패키지 |
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# SdPostPublishScriptConfig
|
|
2
|
+
|
|
3
|
+
배포 완료 후 실행할 스크립트 설정. [`SdConfig`](./sd-config.md)의 `postPublish` 배열 항목으로 사용한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export interface SdPostPublishScriptConfig {
|
|
7
|
+
type: "script";
|
|
8
|
+
cmd: string;
|
|
9
|
+
args: string[];
|
|
10
|
+
}
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
## Members
|
|
14
|
+
|
|
15
|
+
| Field | Type | Description |
|
|
16
|
+
|-------|------|-------------|
|
|
17
|
+
| `type` | `"script"` | 타입 식별자 |
|
|
18
|
+
| `cmd` | `string` | 실행할 명령어 |
|
|
19
|
+
| `args` | `string[]` | 명령어 인수. 환경 변수 치환 지원: `%VER%` (버전), `%PROJECT%` (프로젝트명) |
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
# SdPublishConfig
|
|
2
|
+
|
|
3
|
+
패키지 배포 설정. `type` 필드로 분기하는 discriminated union이다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export type SdPublishConfig =
|
|
7
|
+
| SdNpmPublishConfig
|
|
8
|
+
| SdLocalDirectoryPublishConfig
|
|
9
|
+
| SdStoragePublishConfig;
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
| `type` 값 | 타입 | 설명 |
|
|
13
|
+
|-----------|------|------|
|
|
14
|
+
| `"npm"` | `SdNpmPublishConfig` | npm 레지스트리 배포 |
|
|
15
|
+
| `"local-directory"` | `SdLocalDirectoryPublishConfig` | 로컬 디렉토리 복사 |
|
|
16
|
+
| `"ftp"` \| `"ftps"` \| `"sftp"` | `SdStoragePublishConfig` | 스토리지 업로드 |
|
|
17
|
+
|
|
18
|
+
## Related Types
|
|
19
|
+
|
|
20
|
+
### `SdNpmPublishConfig`
|
|
21
|
+
|
|
22
|
+
npm 레지스트리에 배포한다. 버전은 자동으로 증가된다.
|
|
23
|
+
|
|
24
|
+
```typescript
|
|
25
|
+
export interface SdNpmPublishConfig {
|
|
26
|
+
type: "npm";
|
|
27
|
+
}
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
| Field | Type | Description |
|
|
31
|
+
|-------|------|-------------|
|
|
32
|
+
| `type` | `"npm"` | 배포 타입 식별자 |
|
|
33
|
+
|
|
34
|
+
### `SdLocalDirectoryPublishConfig`
|
|
35
|
+
|
|
36
|
+
로컬 디렉토리로 빌드 산출물을 복사한다.
|
|
37
|
+
|
|
38
|
+
```typescript
|
|
39
|
+
export interface SdLocalDirectoryPublishConfig {
|
|
40
|
+
type: "local-directory";
|
|
41
|
+
path: string;
|
|
42
|
+
}
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
| Field | Type | Description |
|
|
46
|
+
|-------|------|-------------|
|
|
47
|
+
| `type` | `"local-directory"` | 배포 타입 식별자 |
|
|
48
|
+
| `path` | `string` | 배포 대상 경로. 환경 변수 치환 지원: `%VER%` (버전), `%PROJECT%` (프로젝트명) |
|
|
49
|
+
|
|
50
|
+
### `SdStoragePublishConfig`
|
|
51
|
+
|
|
52
|
+
FTP/FTPS/SFTP 서버에 빌드 산출물을 업로드한다.
|
|
53
|
+
|
|
54
|
+
```typescript
|
|
55
|
+
export interface SdStoragePublishConfig {
|
|
56
|
+
type: "ftp" | "ftps" | "sftp";
|
|
57
|
+
host: string;
|
|
58
|
+
port?: number;
|
|
59
|
+
path?: string;
|
|
60
|
+
user?: string;
|
|
61
|
+
password?: string;
|
|
62
|
+
}
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
| Field | Type | Description |
|
|
66
|
+
|-------|------|-------------|
|
|
67
|
+
| `type` | `"ftp" \| "ftps" \| "sftp"` | 스토리지 프로토콜 |
|
|
68
|
+
| `host` | `string` | 서버 호스트 |
|
|
69
|
+
| `port` | `number?` | 서버 포트 |
|
|
70
|
+
| `path` | `string?` | 원격 경로 |
|
|
71
|
+
| `user` | `string?` | 사용자명 |
|
|
72
|
+
| `password` | `string?` | 비밀번호 |
|