Skip to content

feat(studio): package-id wizard feedback + P3 dogfood polish#2275

Merged
os-zhuang merged 2 commits into
mainfrom
work/2615-wizard-p3
Jul 5, 2026
Merged

feat(studio): package-id wizard feedback + P3 dogfood polish#2275
os-zhuang merged 2 commits into
mainfrom
work/2615-wizard-p3

Conversation

@os-zhuang

Copy link
Copy Markdown
Contributor

Summary

Completes the remaining Studio package-create UX dogfood items from objectstack-ai/framework#2615 — the last P2 (wizard ergonomics) plus all five P3 polish items. The P1 items and the other two P2 items shipped in #2263, #2271, and #2270.

P2 — package-id wizard feedback

The three package wizards (switcher create, landing create, landing duplicate) now share a PackageIdInput:

  • Illegal characters are still normalized to the allowed alphabet, but no longer silently — an inline notice says what was removed (the audit repro bad id!!badid no longer reads as the input eating keys).
  • A reverse-domain format hint (com.example.myapp) shows while the id doesn't parse yet, instead of leaving the user staring at a disabled create button.
  • A CJK-only display name that yields no id suggestion now gets a hint to type one manually, instead of an unexplained empty id box.
  • sanitizePackageId extracted to packages-io and unit-tested.

P3 — polish

  • Duplicated "Actions" column in the Studio records grid: a field literally named actions is dropped from the grid's data columns so it no longer collides with the always-pinned row-actions column (still editable in the form designer).
  • Record-create verb consistency: ObjectView's toolbar create button resolved a hardcoded English "Create"; it now uses the same console.objectView.new ("New" / 新建) key as the runtime object pages so Studio and the running app agree.
  • Branded cold-load splash: the console's pre-auth loading gate rendered a bare unbranded "Loading…"; it now delegates to the boot-safe branded LoadingScreen (logo + product name + step list).
  • Picklist option editor truncation: the six controls that shared one cramped row (value + label inputs, color swatch, up/down/remove) are split into a two-row layout so the value/label inputs get the full panel width — "Value"/"Label" placeholders and CJK option labels (待处理) stop truncating.
  • Draft-save confirmation: the Data pillar's "Save draft" now shows a success toast and a "last saved HH:MM" indicator, matching the App and Automations pillars (previously nothing confirmed the draft persisted).

The "read-only toast fires twice" P3 sub-item was investigated but not changed: the shared data-table inline editor already guards the Enter+blur commit pair via skipBlurSaveRef, and ObjectGrid's Enter-vs-✓ are distinct gestures — no reproducible double-fire from static analysis. Touching the shared grid commit path risked regressing the runtime app, so it's left for the live browser dogfood pass.

Test plan

  • New PackageIdInput.test.tsx — 8 tests covering sanitizePackageId (clean id, bad id!! stripped, lowercase-only unflagged, CJK stripped) and the input's notice/hint show-hide behavior.
  • ObjectView.test.tsx create-button assertion updated to the shared verb ("New").
  • npx vitest run packages/app-shell — 131 files / 994 tests passing.
  • npx vitest run packages/plugin-view — 58 tests passing.
  • turbo run build for app-shell (runs tsc) and plugin-view — clean.
  • npx eslint on changed files — 0 errors.

Not browser-verified here — the reporter is running a consolidated live dogfood pass over all the merged #2615 fixes.

🤖 Generated with Claude Code


Generated by Claude Code

claude added 2 commits July 5, 2026 08:34
…mat hint, CJK fallback

P2 wizard-ergonomics finding from the Studio package-create dogfood
(objectstack-ai/framework#2615): the three package wizards (switcher create,
landing create, landing duplicate) silently stripped illegal id characters
(`bad id!!` -> `badid`), gave no hint about the reverse-domain format while
the create button sat disabled, and a CJK-only name produced no id
suggestion with no explanation.

Shared PackageIdInput now sanitizes with an explicit "unsupported characters
removed" notice, shows the reverse-domain format hint while the id doesn't
parse, and PackageIdSuggestionHint tells CJK-named packages to type an id
manually. sanitizePackageId extracted to packages-io (unit-tested); en+zh
strings added.
…anded splash, picklist layout, save confirmation

Five P3 findings from the Studio package-create dogfood (framework#2615):

- Records grid dropped a field named `actions` from its data columns so it
  no longer duplicates the always-pinned row-actions column.
- ObjectView's create button uses console.objectView.new ("New" / 新建),
  matching the runtime object pages instead of a hardcoded "Create".
- Console pre-auth loading gate renders the branded LoadingScreen instead of
  a bare "Loading…".
- Picklist option-editor rows split into two lines so value/label inputs and
  CJK labels stop truncating.
- Data pillar "Save draft" now confirms with a success toast + "last saved"
  timestamp, matching the App/Automations pillars.

The "read-only toast fires twice" sub-item was investigated: the data-table
inline editor already guards the Enter+blur pair (skipBlurSaveRef) and
ObjectGrid's Enter-vs-check-button are distinct gestures — no reproducible
double-fire from static analysis, left for the live browser pass.
@vercel

vercel Bot commented Jul 5, 2026

Copy link
Copy Markdown

The latest updates on your projects. Learn more about Vercel for GitHub.

1 Skipped Deployment
Project Deployment Actions Updated (UTC)
objectui Ignored Ignored Jul 5, 2026 8:52am

Request Review

@github-actions

github-actions Bot commented Jul 5, 2026

Copy link
Copy Markdown
Contributor

✅ Console Performance Budget

Metric Value Budget
Main entry (gzip) 59.5 KB 350 KB
Entry file index-CbNvxk0h.js
Status PASS

📦 Bundle Size Report

Package Size Gzipped
app-shell (index.js) 7.51KB 2.72KB
app-shell (runtime-config.js) 4.72KB 1.69KB
app-shell (types.js) 0.01KB 0.04KB
auth (AuthContext.js) 0.31KB 0.24KB
auth (AuthGuard.js) 1.17KB 0.53KB
auth (AuthProvider.js) 18.34KB 3.80KB
auth (AuthShell.js) 3.49KB 1.40KB
auth (ForgotPasswordForm.js) 4.79KB 1.88KB
auth (LoginForm.js) 9.55KB 3.36KB
auth (PreviewBanner.js) 0.90KB 0.50KB
auth (RegisterForm.js) 6.63KB 2.15KB
auth (SocialSignInButtons.js) 8.89KB 3.61KB
auth (UserMenu.js) 3.40KB 1.22KB
auth (auth-gate-events.js) 1.29KB 0.66KB
auth (authStyles.js) 5.04KB 1.72KB
auth (createAuthClient.js) 26.07KB 6.30KB
auth (createAuthenticatedFetch.js) 3.93KB 1.55KB
auth (index.js) 1.75KB 0.76KB
auth (types.js) 0.59KB 0.35KB
auth (useAuth.js) 4.29KB 0.82KB
auth (useIsWorkspaceAdmin.js) 1.61KB 0.85KB
collaboration (CommentThread.js) 18.38KB 4.49KB
collaboration (LiveCursors.js) 3.17KB 1.27KB
collaboration (PresenceAvatars.js) 3.65KB 1.42KB
collaboration (PresenceProvider.js) 2.42KB 0.96KB
collaboration (index.js) 1.25KB 0.53KB
collaboration (useCommentSearch.js) 1.98KB 0.88KB
collaboration (useConflictResolution.js) 7.75KB 1.86KB
collaboration (useMentionNotifications.js) 1.81KB 0.68KB
collaboration (usePresence.js) 6.33KB 1.84KB
collaboration (useRealtimeSubscription.js) 7.91KB 2.01KB
components (index.js) 437.19KB 93.97KB
core (index.js) 1.65KB 0.59KB
create-plugin (index.js) 9.28KB 2.98KB
data-objectstack (index.js) 109.66KB 27.05KB
fields (index.js) 185.40KB 45.26KB
i18n (LocalizationContext.js) 1.76KB 0.96KB
i18n (currency.js) 1.22KB 0.64KB
i18n (i18n.js) 4.32KB 1.77KB
i18n (index.js) 2.46KB 0.96KB
i18n (pickLocalized.js) 1.31KB 0.67KB
i18n (provider.js) 5.37KB 1.72KB
i18n (useObjectLabel.js) 21.15KB 4.68KB
i18n (useSafeTranslation.js) 2.68KB 0.98KB
layout (index.js) 38.41KB 10.65KB
mobile (MobileProvider.js) 0.92KB 0.49KB
mobile (ResponsiveContainer.js) 0.94KB 0.38KB
mobile (breakpoints.js) 1.51KB 0.70KB
mobile (createOfflineDataSource.js) 5.61KB 1.74KB
mobile (index.js) 1.50KB 0.62KB
mobile (offlineQueue.js) 3.91KB 1.35KB
mobile (pwa.js) 0.97KB 0.49KB
mobile (serviceWorker.js) 1.48KB 0.62KB
mobile (serviceWorkerSource.js) 3.41KB 1.48KB
mobile (useBreakpoint.js) 1.54KB 0.65KB
mobile (useGesture.js) 4.42KB 1.27KB
mobile (useOfflineSync.js) 1.99KB 0.72KB
mobile (usePullToRefresh.js) 2.53KB 0.85KB
mobile (useResponsive.js) 0.71KB 0.42KB
mobile (useResponsiveConfig.js) 1.36KB 0.63KB
mobile (useSpecGesture.js) 1.77KB 0.77KB
mobile (useTouchTarget.js) 1.01KB 0.54KB
permissions (MePermissionsProvider.js) 5.09KB 1.84KB
permissions (PermissionContext.js) 0.31KB 0.25KB
permissions (PermissionGuard.js) 0.89KB 0.45KB
permissions (PermissionProvider.js) 3.46KB 1.03KB
permissions (evaluator.js) 4.00KB 1.23KB
permissions (index.js) 0.91KB 0.41KB
permissions (store.js) 0.91KB 0.42KB
permissions (useFieldPermissions.js) 1.28KB 0.52KB
permissions (usePermissions.js) 1.50KB 0.70KB
plugin-ai (index.js) 15.71KB 3.79KB
plugin-calendar (index.js) 45.10KB 12.33KB
plugin-charts (index.js) 46.18KB 13.02KB
plugin-chatbot (index.js) 173.06KB 41.28KB
plugin-dashboard (index.js) 108.28KB 26.86KB
plugin-designer (index.js) 213.56KB 42.96KB
plugin-detail (index.js) 203.63KB 49.07KB
plugin-editor (index.js) 2.46KB 1.10KB
plugin-form (index.js) 102.48KB 24.90KB
plugin-gantt (index.js) 136.67KB 33.88KB
plugin-grid (index.js) 165.48KB 43.77KB
plugin-kanban (index.js) 48.15KB 12.94KB
plugin-list (index.js) 97.89KB 23.09KB
plugin-map (index.js) 16.78KB 5.23KB
plugin-markdown (index.js) 13.65KB 4.67KB
plugin-report (index.js) 37.83KB 9.97KB
plugin-timeline (index.js) 25.37KB 7.20KB
plugin-tree (index.js) 8.21KB 2.76KB
plugin-view (index.js) 86.02KB 20.96KB
providers (DataSourceProvider.js) 0.75KB 0.39KB
providers (MetadataProvider.js) 1.37KB 0.59KB
providers (ThemeProvider.js) 1.55KB 0.67KB
providers (UploadProvider.js) 11.71KB 3.53KB
providers (index.js) 0.44KB 0.22KB
providers (types.js) 0.01KB 0.04KB
react-runtime (index.js) 3.19KB 1.38KB
react (LazyPluginLoader.js) 3.77KB 1.33KB
react (SchemaRenderer.js) 18.23KB 5.97KB
react (index.js) 0.76KB 0.42KB
sdui-parser (codegen.js) 4.09KB 1.74KB
sdui-parser (index.js) 2.16KB 0.94KB
sdui-parser (parse.js) 10.04KB 2.82KB
sdui-parser (types.js) 0.29KB 0.24KB
sdui-parser (validate.js) 4.69KB 1.48KB
tenant (TenantContext.js) 0.31KB 0.25KB
tenant (TenantGuard.js) 1.04KB 0.43KB
tenant (TenantProvider.js) 2.76KB 0.98KB
tenant (TenantScopedQuery.js) 0.77KB 0.44KB
tenant (index.js) 0.75KB 0.38KB
tenant (resolver.js) 2.64KB 0.76KB
tenant (useTenant.js) 0.50KB 0.32KB
tenant (useTenantBranding.js) 0.62KB 0.39KB
types (ai.js) 0.20KB 0.17KB
types (api-types.js) 0.20KB 0.18KB
types (app.js) 2.87KB 0.99KB
types (base.js) 0.20KB 0.18KB
types (blocks.js) 0.20KB 0.18KB
types (complex.js) 0.20KB 0.18KB
types (crud.js) 0.20KB 0.18KB
types (data-display.js) 0.20KB 0.18KB
types (data-protocol.js) 0.20KB 0.19KB
types (data.js) 0.20KB 0.18KB
types (designer.js) 0.77KB 0.41KB
types (disclosure.js) 0.20KB 0.18KB
types (feedback.js) 0.20KB 0.18KB
types (field-types.js) 0.20KB 0.18KB
types (form.js) 0.20KB 0.18KB
types (index.js) 1.54KB 0.68KB
types (layout.js) 0.20KB 0.18KB
types (mobile.js) 0.20KB 0.18KB
types (navigation.js) 0.20KB 0.18KB
types (objectql.js) 0.20KB 0.18KB
types (overlay.js) 0.20KB 0.18KB
types (permissions.js) 0.20KB 0.18KB
types (plugin-scope.js) 0.20KB 0.18KB
types (record-components.js) 0.20KB 0.19KB
types (registry.js) 0.20KB 0.18KB
types (reports.js) 0.20KB 0.18KB
types (spec-report.js) 5.26KB 1.96KB
types (tenant.js) 0.20KB 0.18KB
types (theme.js) 0.20KB 0.18KB
types (ui-action.js) 0.75KB 0.46KB
types (views.js) 0.20KB 0.18KB
types (widget.js) 0.20KB 0.18KB

Size Limits

  • ✅ Core packages should be < 50KB gzipped
  • ✅ Component packages should be < 100KB gzipped
  • ⚠️ Plugin packages should be < 150KB gzipped

@os-zhuang os-zhuang marked this pull request as ready for review July 5, 2026 09:16
@os-zhuang os-zhuang merged commit 70c4a3f into main Jul 5, 2026
10 checks passed
@os-zhuang os-zhuang deleted the work/2615-wizard-p3 branch July 5, 2026 09:16
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants