Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create public import for uniqueId helper #20171

Closed
wants to merge 8 commits into from
Closed
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions packages/@ember/-internals/glimmer/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -324,3 +324,4 @@ export {
setComponentManager,
} from './lib/utils/managers';
export { isSerializationFirstNode } from './lib/utils/serialization-first-node-helpers';
export { uniqueId } from './lib/helpers/unique-id';
TechieQian marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ export default internalHelper((): Reference<string> => {
// implementation details into an intimate API. It also ensures that the UUID
// always starts with a letter, to avoid creating invalid IDs with a numeric
// digit at the start.
function uniqueId() {
export function uniqueId() {
TechieQian marked this conversation as resolved.
Show resolved Hide resolved
// @ts-expect-error this one-liner abuses weird JavaScript semantics that
// TypeScript (legitimately) doesn't like, but they're nonetheless valid and
// specced.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,34 @@
import { RenderingTestCase, strip, moduleFor, runTask } from 'internal-test-helpers';
import {
AbstractTestCase,
RenderingTestCase,
strip,
moduleFor,
runTask,
} from 'internal-test-helpers';
import { setProperties } from '@ember/object';
import { uniqueId } from '@ember/helper';
TechieQian marked this conversation as resolved.
Show resolved Hide resolved
import { EMBER_UNIQUE_ID_HELPER } from '@ember/canary-features';

if (EMBER_UNIQUE_ID_HELPER) {
moduleFor(
'Helpers test: {{unique-id}} JS',
class JSRenderingTest extends AbstractTestCase {
chriskrycho marked this conversation as resolved.
Show resolved Hide resolved
constructor(assert) {
super(assert);
this.assert = assert;
}
['@test it can be invoked as a JS function']() {
let first = uniqueId();
let second = uniqueId();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here, then, you should be able to use those new imports like this:

Suggested change
let first = uniqueId();
let second = uniqueId();
let first = getValue(invokeHelper({}, uniqueId()));
let second = getValue(invokeHelper({}, uniqueId()));

The rest of the test should “just work” once you’ve added that in. This gets at the bit we’ll need to do follow-up work around—this obviously isn’t a great experience in JS! However, we don’t need to tackle that here, and it needs some broader design work!

Copy link
Contributor Author

@TechieQian TechieQian Sep 2, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hrm, assuming we want just uniqueId since its not fn. So trying
getValue(invokeHelper({}, uniqueId) I get the following very intentional sounding error.

Died on test #1: Found a helper manager, but it was an internal built-in helper manager. `invokeHelper` does not support internal helpers yet.

I dug into @glimmer/runtime a bit, and it seems like we just determine this to be an internal built-in helper manager based on the fact that it takes in a type function.

  function invokeHelper(context, definition, computeArgs) {
    ... 

    if (true
    /* DEBUG */
    && typeof internalManager === 'function') {
      throw new Error('Found a helper manager, but it was an internal built-in helper manager. `invokeHelper` does not support internal helpers yet.');
    }

Here's the minimal repro of the situation:

   let myRef = internalHelper(() => createConstRef('foo', 'unique-id'));
    try {
      invokeHelper({}, myRef);
    } catch (ex) {
      console.error('see error:', ex);
    }

I am missing some context of what an internal helper is vs external(?). Had this just been a Reference, I see there are helper functions like valueForRef(createConst('foo', 'unique-id')) // => foo


this.assert.notStrictEqual(
first,
second,
`different invocations of {{unique-id}} should produce different values`
);
}
}
);
moduleFor(
'Helpers test: {{unique-id}}',
class extends RenderingTestCase {
Expand Down
1 change: 1 addition & 0 deletions packages/@ember/helper/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -314,3 +314,4 @@

export { setHelperManager, helperCapabilities as capabilities } from '@glimmer/manager';
export { invokeHelper, hash, array, concat, get, fn } from '@glimmer/runtime';
export { uniqueId } from "@ember/-internals/glimmer";
1 change: 1 addition & 0 deletions packages/ember/tests/reexports_test.js
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,7 @@ let allExports = [
['_hash', '@ember/helper', 'hash'],
['_get', '@ember/helper', 'get'],
['_concat', '@ember/helper', 'concat'],
['_uniqueId', '@ember/helper', 'uniqueId'],

// @ember/object
['Object', '@ember/object', 'default'],
Expand Down