@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,56 @@
|
|
|
1
|
+
# num
|
|
2
|
+
|
|
3
|
+
숫자 유틸리티 네임스페이스.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { num } from "@simplysm/core-common";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Functions
|
|
10
|
+
|
|
11
|
+
| Function | Signature | Description |
|
|
12
|
+
|----------|-----------|-------------|
|
|
13
|
+
| `parseInt` | `(text: unknown) => number \| undefined` | 문자열을 정수로 파싱. 비숫자 문자 제거 후 파싱. 소수점 이하 버림 |
|
|
14
|
+
| `parseFloat` | `(text: unknown) => number \| undefined` | 문자열을 float로 파싱. 비숫자 문자 제거 후 파싱 |
|
|
15
|
+
| `parseRoundedInt` | `(text: unknown) => number \| undefined` | 문자열을 float로 파싱한 후 반올림하여 정수 반환 |
|
|
16
|
+
| `isNullOrEmpty` | `(val: number \| undefined) => val is 0 \| undefined` | 타입 가드: undefined, null, 0이면 true |
|
|
17
|
+
| `format` | `(val: number, digit?) => string` | 천 단위 구분자 포함 문자열로 포맷 |
|
|
18
|
+
| `format` | `(val: number \| undefined, digit?) => string \| undefined` | undefined이면 undefined 반환 |
|
|
19
|
+
|
|
20
|
+
## `parseInt` / `parseFloat` 동작
|
|
21
|
+
|
|
22
|
+
- 숫자, `-`, `.` 이외의 문자 제거 후 파싱
|
|
23
|
+
- 선행 `-`만 음수 부호로 유지 (중간 `-`는 제거)
|
|
24
|
+
- 파싱 실패 시 `undefined` 반환
|
|
25
|
+
|
|
26
|
+
## `format` — `digit` 옵션
|
|
27
|
+
|
|
28
|
+
| Field | Type | Description |
|
|
29
|
+
|-------|------|-------------|
|
|
30
|
+
| `max` | `number` | 최대 소수점 자릿수 |
|
|
31
|
+
| `min` | `number` | 최소 소수점 자릿수 (부족하면 0으로 채움) |
|
|
32
|
+
|
|
33
|
+
## Usage
|
|
34
|
+
|
|
35
|
+
```typescript
|
|
36
|
+
import { num } from "@simplysm/core-common";
|
|
37
|
+
|
|
38
|
+
num.parseInt("1,234.56"); // 1234
|
|
39
|
+
num.parseInt("-123"); // -123
|
|
40
|
+
num.parseInt("010-1234-5678"); // 1012345678 (중간 - 제거)
|
|
41
|
+
num.parseInt("abc"); // undefined
|
|
42
|
+
|
|
43
|
+
num.parseFloat("1,234.56"); // 1234.56
|
|
44
|
+
num.parseRoundedInt("1.7"); // 2
|
|
45
|
+
|
|
46
|
+
// null/zero 검사 (타입 가드)
|
|
47
|
+
const count: number | undefined = getValue();
|
|
48
|
+
if (num.isNullOrEmpty(count)) {
|
|
49
|
+
// count: 0 | undefined
|
|
50
|
+
} else {
|
|
51
|
+
// count: number (non-zero)
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
num.format(1234567.89, { max: 2 }); // "1,234,567.89"
|
|
55
|
+
num.format(1234, { min: 2 }); // "1,234.00"
|
|
56
|
+
```
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
# obj
|
|
2
|
+
|
|
3
|
+
객체 유틸리티 네임스페이스. 깊은 복사, 비교, 병합, key 조작 등을 제공한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { obj } from "@simplysm/core-common";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Functions
|
|
10
|
+
|
|
11
|
+
| Function | Signature | Description |
|
|
12
|
+
|----------|-----------|-------------|
|
|
13
|
+
| `clone` | `<T>(source: T) => T` | 깊은 복사. 순환 참조, 커스텀 타입(`DateTime`, `DateOnly`, `Time`, `Uuid`, `Uint8Array`) 지원 |
|
|
14
|
+
| `equal` | `(source, target, options?) => boolean` | 깊은 동등성 비교 |
|
|
15
|
+
| `merge` | `<S, T>(source: S, target: T, opt?) => S & T` | 깊은 병합. source를 기반으로 target을 병합하여 새 객체 반환 |
|
|
16
|
+
| `merge3` | `(source, origin, target, optionsObj?) => { conflict, result }` | 3-way 병합 |
|
|
17
|
+
| `omit` | `<T, K>(item: T, omitKeys: K[]) => Omit<T, K>` | 특정 key 제외 |
|
|
18
|
+
| `omitByFilter` | `<T>(item: T, omitKeyFn) => T` | 조건에 맞는 key 제외 |
|
|
19
|
+
| `pick` | `<T, K>(item: T, pickKeys: K[]) => Pick<T, K>` | 특정 key만 선택 |
|
|
20
|
+
| `getChainValue` | `(obj, chain, optional?) => unknown` | 체인 경로로 값 조회 (예: `"a.b[0].c"`) |
|
|
21
|
+
| `getChainValueByDepth` | `(obj, key, depth, optional?) => TObject[TKey]` | 같은 key로 지정된 깊이만큼 하강 |
|
|
22
|
+
| `setChainValue` | `(obj, chain, value) => void` | 체인 경로로 값 설정 |
|
|
23
|
+
| `deleteChainValue` | `(obj, chain) => void` | 체인 경로로 값 삭제 |
|
|
24
|
+
| `clearUndefined` | `<T>(obj: T) => T` | 객체에서 undefined/null 값을 가진 key 삭제 (원본 수정) |
|
|
25
|
+
| `clear` | `<T>(obj: T) => Record<string, never>` | 객체의 모든 key 삭제 (원본 수정) |
|
|
26
|
+
| `nullToUndefined` | `<T>(obj: T) => T \| undefined` | null을 undefined로 변환 (재귀, 원본 수정) |
|
|
27
|
+
| `unflatten` | `(flatObj) => Record<string, unknown>` | 평탄화된 객체를 중첩 객체로 변환 (`"a.b.c": 1` → `{ a: { b: { c: 1 } } }`) |
|
|
28
|
+
| `keys` | `<T>(obj: T) => (keyof T)[]` | 타입 안전한 `Object.keys` |
|
|
29
|
+
| `entries` | `<T>(obj: T) => Entries<T>` | 타입 안전한 `Object.entries` |
|
|
30
|
+
| `fromEntries` | `<T>(entryPairs: T[]) => { [K in T[0]]: T[1] }` | 타입 안전한 `Object.fromEntries` |
|
|
31
|
+
| `map` | `(obj, fn) => Record<string, TNewValue>` | 각 엔트리를 변환하여 새 객체 반환 |
|
|
32
|
+
|
|
33
|
+
## Related Types
|
|
34
|
+
|
|
35
|
+
### `EqualOptions`
|
|
36
|
+
|
|
37
|
+
`equal()` 옵션:
|
|
38
|
+
|
|
39
|
+
| Field | Type | Description |
|
|
40
|
+
|-------|------|-------------|
|
|
41
|
+
| `topLevelIncludes` | `string[]` | 비교할 key 목록 (최상위 레벨에만 적용) |
|
|
42
|
+
| `topLevelExcludes` | `string[]` | 비교에서 제외할 key 목록 (최상위 레벨에만 적용) |
|
|
43
|
+
| `ignoreArrayIndex` | `boolean` | 배열 순서를 무시할지 여부. `true`면 O(n²) 복잡도 |
|
|
44
|
+
| `shallow` | `boolean` | 얕은 비교 여부. `true`면 1단계만 비교 (참조 비교) |
|
|
45
|
+
|
|
46
|
+
### `MergeOptions`
|
|
47
|
+
|
|
48
|
+
`merge()` 옵션:
|
|
49
|
+
|
|
50
|
+
| Field | Type | Description |
|
|
51
|
+
|-------|------|-------------|
|
|
52
|
+
| `arrayProcess` | `"replace" \| "concat"` | 배열 처리 방식. `"replace"`: target으로 교체 (기본값), `"concat"`: 병합 (중복 제거) |
|
|
53
|
+
| `useDelTargetNull` | `boolean` | target이 null일 때 해당 key를 삭제할지 여부 |
|
|
54
|
+
|
|
55
|
+
### `Merge3KeyOptions`
|
|
56
|
+
|
|
57
|
+
`merge3()` key별 옵션:
|
|
58
|
+
|
|
59
|
+
| Field | Type | Description |
|
|
60
|
+
|-------|------|-------------|
|
|
61
|
+
| `keys` | `string[]` | 비교할 하위 key 목록 |
|
|
62
|
+
| `excludes` | `string[]` | 비교에서 제외할 하위 key 목록 |
|
|
63
|
+
| `ignoreArrayIndex` | `boolean` | 배열 순서를 무시할지 여부 |
|
|
64
|
+
|
|
65
|
+
### `UndefToOptional<T>`
|
|
66
|
+
|
|
67
|
+
`undefined` 타입을 가진 속성을 optional로 변환:
|
|
68
|
+
|
|
69
|
+
```typescript
|
|
70
|
+
// { a: string; b: string | undefined } → { a: string; b?: string | undefined }
|
|
71
|
+
export type UndefToOptional<TObject> = ...
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
### `OptionalToUndef<T>`
|
|
75
|
+
|
|
76
|
+
optional 속성을 필수 + `undefined` 유니온으로 변환:
|
|
77
|
+
|
|
78
|
+
```typescript
|
|
79
|
+
// { a: string; b?: string } → { a: string; b: string | undefined }
|
|
80
|
+
export type OptionalToUndef<TObject> = ...
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
## Usage
|
|
84
|
+
|
|
85
|
+
```typescript
|
|
86
|
+
import { obj } from "@simplysm/core-common";
|
|
87
|
+
|
|
88
|
+
// 깊은 복사
|
|
89
|
+
const copied = obj.clone({ nested: { data: [1, 2, 3] } });
|
|
90
|
+
|
|
91
|
+
// 깊은 비교
|
|
92
|
+
const isEqual = obj.equal(a, b, { topLevelExcludes: ["updatedAt"] });
|
|
93
|
+
|
|
94
|
+
// 깊은 병합
|
|
95
|
+
const merged = obj.merge(defaults, overrides);
|
|
96
|
+
|
|
97
|
+
// omit / pick
|
|
98
|
+
const noId = obj.omit(user, ["id"]);
|
|
99
|
+
const onlyName = obj.pick(user, ["name", "email"]);
|
|
100
|
+
|
|
101
|
+
// 체인 경로
|
|
102
|
+
const val = obj.getChainValue(data, "user.address[0].city");
|
|
103
|
+
obj.setChainValue(data, "user.name", "Alice");
|
|
104
|
+
|
|
105
|
+
// 객체 변환
|
|
106
|
+
const mapped = obj.map(colors, (key, rgb) => [null, `rgb(${rgb})`]);
|
|
107
|
+
```
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
# path
|
|
2
|
+
|
|
3
|
+
경로 유틸리티 네임스페이스. Node.js `path` 모듈 대체 (브라우저 환경 지원). POSIX 스타일 경로(슬래시 `/`)만 지원한다. Windows 백슬래시(`\`)는 지원하지 않는다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { path } from "@simplysm/core-common";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Functions
|
|
10
|
+
|
|
11
|
+
| Function | Signature | Description |
|
|
12
|
+
|----------|-----------|-------------|
|
|
13
|
+
| `join` | `(...segments: string[]) => string` | 경로 결합 (`path.join` 대체) |
|
|
14
|
+
| `basename` | `(filePath: string, ext?: string) => string` | 파일명 추출 (`path.basename` 대체). ext 지정 시 해당 확장자 제거 |
|
|
15
|
+
| `extname` | `(filePath: string) => string` | 파일 확장자 추출 (`path.extname` 대체). 숨김 파일(`.gitignore`)은 빈 문자열 반환 |
|
|
16
|
+
|
|
17
|
+
## Usage
|
|
18
|
+
|
|
19
|
+
```typescript
|
|
20
|
+
import { path } from "@simplysm/core-common";
|
|
21
|
+
|
|
22
|
+
path.join("/foo", "bar", "baz"); // "/foo/bar/baz"
|
|
23
|
+
path.join("/foo/", "/bar/"); // "/foo/bar"
|
|
24
|
+
|
|
25
|
+
path.basename("/foo/bar/file.txt"); // "file.txt"
|
|
26
|
+
path.basename("/foo/bar/file.txt", ".txt"); // "file"
|
|
27
|
+
|
|
28
|
+
path.extname("/foo/bar/file.txt"); // ".txt"
|
|
29
|
+
path.extname("/foo/.gitignore"); // ""
|
|
30
|
+
```
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
# primitive
|
|
2
|
+
|
|
3
|
+
원시 타입 변환 유틸리티 네임스페이스.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { primitive } from "@simplysm/core-common";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Functions
|
|
10
|
+
|
|
11
|
+
| Function | Signature | Description |
|
|
12
|
+
|----------|-----------|-------------|
|
|
13
|
+
| `typeStr` | `(value: PrimitiveTypeMap[PrimitiveTypeStr]) => PrimitiveTypeStr` | 값으로부터 `PrimitiveTypeStr` 추론. 지원하지 않는 타입이면 `ArgumentError` 발생 |
|
|
14
|
+
|
|
15
|
+
## Usage
|
|
16
|
+
|
|
17
|
+
```typescript
|
|
18
|
+
import { primitive } from "@simplysm/core-common";
|
|
19
|
+
|
|
20
|
+
primitive.typeStr("hello"); // "string"
|
|
21
|
+
primitive.typeStr(123); // "number"
|
|
22
|
+
primitive.typeStr(true); // "boolean"
|
|
23
|
+
primitive.typeStr(new DateTime()); // "DateTime"
|
|
24
|
+
primitive.typeStr(new DateOnly()); // "DateOnly"
|
|
25
|
+
primitive.typeStr(new Time()); // "Time"
|
|
26
|
+
primitive.typeStr(Uuid.generate()); // "Uuid"
|
|
27
|
+
primitive.typeStr(new Uint8Array()); // "Bytes"
|
|
28
|
+
```
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
# str
|
|
2
|
+
|
|
3
|
+
문자열 유틸리티 네임스페이스.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { str } from "@simplysm/core-common";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Functions
|
|
10
|
+
|
|
11
|
+
| Function | Signature | Description |
|
|
12
|
+
|----------|-----------|-------------|
|
|
13
|
+
| `getKoreanSuffix` | `(text, type) => string` | 받침 유무에 따라 적절한 한국어 조사 반환 |
|
|
14
|
+
| `replaceFullWidth` | `(str) => string` | 전각 문자(A-Z, a-z, 0-9, 전각 공백, 전각 괄호)를 반각 문자로 변환 |
|
|
15
|
+
| `toPascalCase` | `(str) => string` | PascalCase로 변환 (`-`, `_`, `.` 구분자 지원) |
|
|
16
|
+
| `toCamelCase` | `(str) => string` | camelCase로 변환 |
|
|
17
|
+
| `toKebabCase` | `(str) => string` | kebab-case로 변환 |
|
|
18
|
+
| `toSnakeCase` | `(str) => string` | snake_case로 변환 |
|
|
19
|
+
| `isNullOrEmpty` | `(str: string \| undefined) => str is "" \| undefined` | 타입 가드: undefined, null, 빈 문자열이면 true |
|
|
20
|
+
| `insert` | `(str, index, insertString) => string` | 특정 위치에 문자열 삽입 |
|
|
21
|
+
|
|
22
|
+
## `getKoreanSuffix` — 조사 타입
|
|
23
|
+
|
|
24
|
+
| `type` | 받침 있음 | 받침 없음 | 설명 |
|
|
25
|
+
|--------|----------|----------|------|
|
|
26
|
+
| `"을"` | 을 | 를 | 목적격 조사 |
|
|
27
|
+
| `"은"` | 은 | 는 | 주격 보조사 |
|
|
28
|
+
| `"이"` | 이 | 가 | 주격 조사 |
|
|
29
|
+
| `"와"` | 과 | 와 | 접속 조사 |
|
|
30
|
+
| `"랑"` | 이랑 | 랑 | 접속 조사 |
|
|
31
|
+
| `"로"` | 으로 (ㄹ 받침은 "로") | 로 | 도구격 조사 |
|
|
32
|
+
| `"라"` | 이라 | 라 | 서술격 조사 |
|
|
33
|
+
|
|
34
|
+
## Usage
|
|
35
|
+
|
|
36
|
+
```typescript
|
|
37
|
+
import { str } from "@simplysm/core-common";
|
|
38
|
+
|
|
39
|
+
// 한국어 조사
|
|
40
|
+
str.getKoreanSuffix("Apple", "을"); // "를"
|
|
41
|
+
str.getKoreanSuffix("책", "이"); // "이"
|
|
42
|
+
str.getKoreanSuffix("파일", "을"); // "을"
|
|
43
|
+
|
|
44
|
+
// 전각 → 반각
|
|
45
|
+
str.replaceFullWidth("A123"); // "A123"
|
|
46
|
+
|
|
47
|
+
// 케이스 변환
|
|
48
|
+
str.toPascalCase("hello-world"); // "HelloWorld"
|
|
49
|
+
str.toCamelCase("HelloWorld"); // "helloWorld"
|
|
50
|
+
str.toKebabCase("HelloWorld"); // "hello-world"
|
|
51
|
+
str.toSnakeCase("HelloWorld"); // "hello_world"
|
|
52
|
+
|
|
53
|
+
// null/empty 검사 (타입 가드)
|
|
54
|
+
const name: string | undefined = getValue();
|
|
55
|
+
if (str.isNullOrEmpty(name)) {
|
|
56
|
+
// name: "" | undefined
|
|
57
|
+
} else {
|
|
58
|
+
// name: string (non-empty)
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// 문자열 삽입
|
|
62
|
+
str.insert("Hello World", 5, ","); // "Hello, World"
|
|
63
|
+
```
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
# Template Strings
|
|
2
|
+
|
|
3
|
+
IDE 코드 하이라이팅 지원용 태그드 템플릿 리터럴 함수. 실제 동작은 문자열 결합 + 들여쓰기 정규화(앞뒤 빈 줄 제거, 공통 들여쓰기 제거)이다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
export function js(strings: TemplateStringsArray, ...values: unknown[]): string;
|
|
7
|
+
export function ts(strings: TemplateStringsArray, ...values: unknown[]): string;
|
|
8
|
+
export function html(strings: TemplateStringsArray, ...values: unknown[]): string;
|
|
9
|
+
export function tsql(strings: TemplateStringsArray, ...values: unknown[]): string;
|
|
10
|
+
export function mysql(strings: TemplateStringsArray, ...values: unknown[]): string;
|
|
11
|
+
export function pgsql(strings: TemplateStringsArray, ...values: unknown[]): string;
|
|
12
|
+
```
|
|
13
|
+
|
|
14
|
+
직접 named import로 사용한다 (네임스페이스 아님):
|
|
15
|
+
|
|
16
|
+
```typescript
|
|
17
|
+
import { js, ts, html, tsql, mysql, pgsql } from "@simplysm/core-common";
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
## Functions
|
|
21
|
+
|
|
22
|
+
| Function | Description |
|
|
23
|
+
|----------|-------------|
|
|
24
|
+
| `js` | JavaScript 코드 하이라이팅용 |
|
|
25
|
+
| `ts` | TypeScript 코드 하이라이팅용 |
|
|
26
|
+
| `html` | HTML 마크업 하이라이팅용 |
|
|
27
|
+
| `tsql` | MSSQL T-SQL 하이라이팅용 |
|
|
28
|
+
| `mysql` | MySQL SQL 하이라이팅용 |
|
|
29
|
+
| `pgsql` | PostgreSQL SQL 하이라이팅용 |
|
|
30
|
+
|
|
31
|
+
## Usage
|
|
32
|
+
|
|
33
|
+
```typescript
|
|
34
|
+
import { ts, tsql } from "@simplysm/core-common";
|
|
35
|
+
|
|
36
|
+
const code = ts`
|
|
37
|
+
interface User {
|
|
38
|
+
name: string;
|
|
39
|
+
age: number;
|
|
40
|
+
}
|
|
41
|
+
`;
|
|
42
|
+
// "interface User {\n name: string;\n age: number;\n}"
|
|
43
|
+
|
|
44
|
+
const query = tsql`
|
|
45
|
+
SELECT TOP 10 *
|
|
46
|
+
FROM Users
|
|
47
|
+
WHERE Name = ${keyword}
|
|
48
|
+
`;
|
|
49
|
+
```
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
# transfer
|
|
2
|
+
|
|
3
|
+
Worker 간 전송 가능한 객체 변환 유틸리티 네임스페이스. `structuredClone`이 지원하지 않는 커스텀 타입을 처리한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { transfer } from "@simplysm/core-common";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Functions
|
|
10
|
+
|
|
11
|
+
| Function | Signature | Description |
|
|
12
|
+
|----------|-----------|-------------|
|
|
13
|
+
| `encode` | `(obj) => { result: unknown; transferList: ArrayBuffer[] }` | Simplysm 타입을 포함한 객체를 Worker 전송 가능한 형태로 변환. 순환 참조 시 `TypeError` 발생 |
|
|
14
|
+
| `decode` | `(obj) => unknown` | `encode()`로 변환된 객체를 원래 Simplysm 타입으로 복원 |
|
|
15
|
+
|
|
16
|
+
## 지원 타입
|
|
17
|
+
|
|
18
|
+
`Date`, `DateTime`, `DateOnly`, `Time`, `Uuid`, `RegExp`, `Error` (cause, code, detail 포함), `Uint8Array`, `Array`, `Map`, `Set`, 일반 객체
|
|
19
|
+
|
|
20
|
+
`Uint8Array`는 zero-copy 전송을 위해 `ArrayBuffer`를 `transferList`에 추가한다. `SharedArrayBuffer`는 이미 공유 메모리이므로 `transferList`에 추가하지 않는다.
|
|
21
|
+
|
|
22
|
+
## Usage
|
|
23
|
+
|
|
24
|
+
```typescript
|
|
25
|
+
import { transfer } from "@simplysm/core-common";
|
|
26
|
+
|
|
27
|
+
// Worker로 데이터 전송
|
|
28
|
+
const { result, transferList } = transfer.encode(data);
|
|
29
|
+
worker.postMessage(result, transferList);
|
|
30
|
+
|
|
31
|
+
// Worker에서 데이터 수신
|
|
32
|
+
self.onmessage = (event) => {
|
|
33
|
+
const decoded = transfer.decode(event.data);
|
|
34
|
+
};
|
|
35
|
+
```
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
# wait
|
|
2
|
+
|
|
3
|
+
비동기 대기 유틸리티 네임스페이스.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { wait } from "@simplysm/core-common";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Functions
|
|
10
|
+
|
|
11
|
+
| Function | Signature | Description |
|
|
12
|
+
|----------|-----------|-------------|
|
|
13
|
+
| `until` | `(forwarder, milliseconds?, maxCount?) => Promise<void>` | 조건이 true가 될 때까지 대기 |
|
|
14
|
+
| `time` | `(millisecond: number) => Promise<void>` | 지정된 시간만큼 대기 |
|
|
15
|
+
|
|
16
|
+
## `until` — Parameters
|
|
17
|
+
|
|
18
|
+
| Param | Type | Default | Description |
|
|
19
|
+
|-------|------|---------|-------------|
|
|
20
|
+
| `forwarder` | `() => boolean \| Promise<boolean>` | - | 조건 함수. 첫 번째 호출에서 true이면 즉시 반환 |
|
|
21
|
+
| `milliseconds` | `number` | `100` | 확인 간격 (ms) |
|
|
22
|
+
| `maxCount` | `number` | `undefined` | 최대 시도 횟수. 초과 시 `TimeoutError` 발생. 미지정 시 무제한 |
|
|
23
|
+
|
|
24
|
+
## Usage
|
|
25
|
+
|
|
26
|
+
```typescript
|
|
27
|
+
import { wait } from "@simplysm/core-common";
|
|
28
|
+
|
|
29
|
+
// 조건 대기
|
|
30
|
+
await wait.until(() => isReady);
|
|
31
|
+
await wait.until(() => isReady, 100, 50); // 100ms 간격, 최대 50회
|
|
32
|
+
|
|
33
|
+
// 시간 대기
|
|
34
|
+
await wait.time(1000); // 1초 대기
|
|
35
|
+
```
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
# xml
|
|
2
|
+
|
|
3
|
+
XML 변환 유틸리티 네임스페이스. `fast-xml-parser` 기반.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { xml } from "@simplysm/core-common";
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Functions
|
|
10
|
+
|
|
11
|
+
| Function | Signature | Description |
|
|
12
|
+
|----------|-----------|-------------|
|
|
13
|
+
| `parse` | `(str, options?) => unknown` | XML 문자열을 객체로 파싱 |
|
|
14
|
+
| `stringify` | `(obj, options?) => string` | 객체를 XML 문자열로 직렬화 |
|
|
15
|
+
|
|
16
|
+
## `parse` — 파싱 규칙
|
|
17
|
+
|
|
18
|
+
- 속성: `$` 객체에 그룹화
|
|
19
|
+
- 텍스트 노드: `_` key에 저장
|
|
20
|
+
- 자식 요소: 배열로 변환 (루트 요소 제외)
|
|
21
|
+
|
|
22
|
+
## `parse` — options
|
|
23
|
+
|
|
24
|
+
| Field | Type | Description |
|
|
25
|
+
|-------|------|-------------|
|
|
26
|
+
| `stripTagPrefix` | `boolean` | 태그 접두사(네임스페이스) 제거 여부. 속성은 접두사 유지 |
|
|
27
|
+
|
|
28
|
+
## Usage
|
|
29
|
+
|
|
30
|
+
```typescript
|
|
31
|
+
import { xml } from "@simplysm/core-common";
|
|
32
|
+
|
|
33
|
+
// 파싱
|
|
34
|
+
const result = xml.parse('<root id="1"><item>hello</item></root>');
|
|
35
|
+
// { root: { $: { id: "1" }, item: [{ _: "hello" }] } }
|
|
36
|
+
|
|
37
|
+
// 네임스페이스 제거
|
|
38
|
+
const clean = xml.parse('<ns:root><ns:item>hello</ns:item></ns:root>', { stripTagPrefix: true });
|
|
39
|
+
// { root: { item: [{ _: "hello" }] } }
|
|
40
|
+
|
|
41
|
+
// 직렬화
|
|
42
|
+
const str = xml.stringify({
|
|
43
|
+
root: {
|
|
44
|
+
$: { id: "1" },
|
|
45
|
+
item: [{ _: "hello" }, { _: "world" }],
|
|
46
|
+
},
|
|
47
|
+
});
|
|
48
|
+
// '<root id="1"><item>hello</item><item>world</item></root>'
|
|
49
|
+
```
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
# ZipArchive
|
|
2
|
+
|
|
3
|
+
ZIP 파일 처리 클래스. ZIP 파일의 읽기, 쓰기, 압축, 해제를 처리한다. 동일 파일의 중복 해제를 방지하기 위해 내부 캐싱을 사용한다. `@zip.js/zip.js` 기반.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
import { ZipArchive } from "@simplysm/core-common";
|
|
7
|
+
|
|
8
|
+
export class ZipArchive {
|
|
9
|
+
constructor(data?: Blob | Bytes);
|
|
10
|
+
}
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
## Members
|
|
14
|
+
|
|
15
|
+
| Member | Kind | Type | Description |
|
|
16
|
+
|--------|------|------|-------------|
|
|
17
|
+
| `extractAll` | method | `(progressCallback?) => Promise<Map<string, Bytes \| undefined>>` | 모든 파일 추출 |
|
|
18
|
+
| `get` | method | `(fileName: string) => Promise<Bytes \| undefined>` | 특정 파일 추출. 내부 캐시 활용 |
|
|
19
|
+
| `exists` | method | `(fileName: string) => Promise<boolean>` | 파일 존재 여부 확인 |
|
|
20
|
+
| `write` | method | `(fileName: string, bytes: Bytes) => void` | 파일 쓰기 (캐시에 저장) |
|
|
21
|
+
| `compress` | method | `() => Promise<Bytes>` | 캐시된 파일을 ZIP으로 압축 |
|
|
22
|
+
| `close` | method | `() => Promise<void>` | 리더 닫기 및 캐시 비우기 |
|
|
23
|
+
|
|
24
|
+
## Related Types
|
|
25
|
+
|
|
26
|
+
### `ZipArchiveProgress`
|
|
27
|
+
|
|
28
|
+
`extractAll()` 진행률 콜백의 파라미터 타입:
|
|
29
|
+
|
|
30
|
+
```typescript
|
|
31
|
+
export interface ZipArchiveProgress {
|
|
32
|
+
fileName: string;
|
|
33
|
+
totalSize: number;
|
|
34
|
+
extractedSize: number;
|
|
35
|
+
}
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
| Field | Type | Description |
|
|
39
|
+
|-------|------|-------------|
|
|
40
|
+
| `fileName` | `string` | 현재 처리 중인 파일명 |
|
|
41
|
+
| `totalSize` | `number` | 전체 파일 크기 (바이트) |
|
|
42
|
+
| `extractedSize` | `number` | 현재까지 추출된 크기 (바이트) |
|
|
43
|
+
|
|
44
|
+
## Usage
|
|
45
|
+
|
|
46
|
+
```typescript
|
|
47
|
+
import { ZipArchive } from "@simplysm/core-common";
|
|
48
|
+
|
|
49
|
+
// ZIP 파일 읽기
|
|
50
|
+
const archive = new ZipArchive(zipBytes);
|
|
51
|
+
try {
|
|
52
|
+
const content = await archive.get("file.txt");
|
|
53
|
+
} finally {
|
|
54
|
+
await archive.close();
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
// ZIP 파일 생성
|
|
58
|
+
const newArchive = new ZipArchive();
|
|
59
|
+
try {
|
|
60
|
+
newArchive.write("file.txt", textBytes);
|
|
61
|
+
newArchive.write("data.json", jsonBytes);
|
|
62
|
+
const zipBytes = await newArchive.compress();
|
|
63
|
+
} finally {
|
|
64
|
+
await newArchive.close();
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// 모든 파일 추출 (진행률 보고 포함)
|
|
68
|
+
const archive2 = new ZipArchive(zipBytes);
|
|
69
|
+
try {
|
|
70
|
+
const files = await archive2.extractAll((progress) => {
|
|
71
|
+
const pct = (progress.extractedSize / progress.totalSize * 100).toFixed(1);
|
|
72
|
+
console.log(`${progress.fileName}: ${pct}%`);
|
|
73
|
+
});
|
|
74
|
+
} finally {
|
|
75
|
+
await archive2.close();
|
|
76
|
+
}
|
|
77
|
+
```
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
# @simplysm/core-node
|
|
2
|
+
|
|
3
|
+
> Node.js 전용 코어 유틸리티 패키지. 파일 시스템 조작, 자식 프로세스 실행, 경로 처리, 파일 감시, Worker thread 래퍼, consola 로깅 설정을 제공한다.
|
|
4
|
+
> `@simplysm/core-common`에 의존하며, Node.js 런타임에서만 동작한다.
|
|
5
|
+
|
|
6
|
+
## Installation
|
|
7
|
+
|
|
8
|
+
```bash
|
|
9
|
+
npm install @simplysm/core-node
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
## 하려는 작업 → 먼저 읽을 파일
|
|
13
|
+
|
|
14
|
+
| 작업 | 먼저 읽을 파일 |
|
|
15
|
+
|------|----------------|
|
|
16
|
+
| 파일 읽기/쓰기/복사/삭제 | [fsx](./utils/fsx.md) |
|
|
17
|
+
| 자식 프로세스 실행 | [cpx](./utils/cpx.md) |
|
|
18
|
+
| 경로 변환/비교 | [pathx](./utils/pathx.md) |
|
|
19
|
+
| 파일 변경 감시 | [FsWatcher](./features/fs-watcher.md) |
|
|
20
|
+
| 로깅 설정 | [setupConsola](./logging/setup-consola.md) |
|
|
21
|
+
| 커스텀 터미널 로깅 | [PrettyReporter](./logging/pretty-reporter.md) |
|
|
22
|
+
| 커스텀 파일 로깅 | [createFileReporter](./logging/create-file-reporter.md) |
|
|
23
|
+
| 워커 스레드로 작업 분리 | [Worker](./worker/worker.md) + [createWorker](./worker/create-worker.md) |
|
|
24
|
+
|
|
25
|
+
## API Overview
|
|
26
|
+
|
|
27
|
+
### Utils
|
|
28
|
+
|
|
29
|
+
| Entry | Kind | 언제 쓰나 |
|
|
30
|
+
|-------|------|-----------|
|
|
31
|
+
| [`fsx`](./utils/fsx.md) | namespace | 파일 시스템 작업(존재 확인, 읽기/쓰기, 복사, 삭제, glob)이 필요할 때 |
|
|
32
|
+
| [`cpx`](./utils/cpx.md) | namespace | 외부 명령어나 자식 프로세스를 실행할 때 |
|
|
33
|
+
| [`pathx`](./utils/pathx.md) | namespace | 경로를 POSIX 스타일로 변환하거나, 경로 간 관계(하위 경로 여부)를 확인할 때 |
|
|
34
|
+
|
|
35
|
+
### Features
|
|
36
|
+
|
|
37
|
+
| Entry | Kind | 언제 쓰나 |
|
|
38
|
+
|-------|------|-----------|
|
|
39
|
+
| [`FsWatcher`](./features/fs-watcher.md) | class | 파일/디렉토리 변경을 지속적으로 감시하고 이벤트를 받아야 할 때 |
|
|
40
|
+
|
|
41
|
+
### Logging
|
|
42
|
+
|
|
43
|
+
| Entry | Kind | 언제 쓰나 |
|
|
44
|
+
|-------|------|-----------|
|
|
45
|
+
| [`setupConsola`](./logging/setup-consola.md) | function | 서버/CLI 시작 시 consola 로깅을 환경에 맞게 자동 구성할 때 |
|
|
46
|
+
| [`PrettyReporter`](./logging/pretty-reporter.md) | class | 터미널에 아이콘/색상이 포함된 포맷으로 로그를 출력할 때 |
|
|
47
|
+
| [`createFileReporter`](./logging/create-file-reporter.md) | function | 로그를 JSON 라인 파일로 기록하고 날짜별 로테이션이 필요할 때 |
|
|
48
|
+
|
|
49
|
+
### Worker
|
|
50
|
+
|
|
51
|
+
| Entry | Kind | 언제 쓰나 |
|
|
52
|
+
|-------|------|-----------|
|
|
53
|
+
| [`Worker`](./worker/worker.md) | const | 메인 스레드에서 타입 안전하게 워커 메서드를 호출할 때 |
|
|
54
|
+
| [`createWorker`](./worker/create-worker.md) | function | 워커 파일에서 메서드/이벤트를 등록할 때 (`Worker`와 쌍으로 사용) |
|
|
55
|
+
|
|
56
|
+
## 이 패키지를 쓰지 말아야 할 때
|
|
57
|
+
|
|
58
|
+
- 브라우저 환경 → `@simplysm/core-browser`
|
|
59
|
+
- 플랫폼 중립 유틸리티(DateTime, UUID, EventEmitter 등) → `@simplysm/core-common`
|