Skip to content

Commit

Permalink
[core] Fix useTheme import change (#134)
Browse files Browse the repository at this point in the history
Co-authored-by: siriwatknp <[email protected]>
  • Loading branch information
brijeshb42 and siriwatknp authored Jun 10, 2024
1 parent e672e4b commit 9da7690
Show file tree
Hide file tree
Showing 7 changed files with 19 additions and 7 deletions.
2 changes: 1 addition & 1 deletion packages/pigment-css-react/src/createExtendSxProp.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
* to reduce bundle size only. DO NOT use it in your codebase.
*/
function extendSxProp(props) {
return props;
return { ...props };
}
export default function createExtendSxProp() {
return extendSxProp;
Expand Down
3 changes: 3 additions & 0 deletions packages/pigment-css-react/src/processors/useTheme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,9 @@ export type TemplateCallback = (params: Record<string, unknown> | undefined) =>
export class UseThemeProcessor extends BaseProcessor {
constructor(params: Params, ...args: TailProcessorParams) {
super([params[0]], ...args);
if (params.length === 1) {
throw BaseProcessor.SKIP;
}
validateParams(params, ['callee', ['call']], `Invalid use of ${this.tagSource.imported} tag.`);
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
import { describe } from 'yargs';
import { expect } from 'chai';
import createExtendSxProp from '../../src/createExtendSxProp';

describe('createExtendSxProp', () => {
it('return the new copy of input', () => {
const original = { color: 'red' };
expect(createExtendSxProp()(original)).to.not.equal(original);
expect(createExtendSxProp()(original)).not.to.equal(original);
expect(createExtendSxProp()(original)).to.deep.equal({ color: 'red' });
});
});
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
import { useTheme } from '../zero-styled';
import { useTheme } from '@pigment-css/react';

// This is intentional to make sure Pigment leaves the reference as-is.
console.log(useTheme);

export const Fade = React.forwardRef(function Fade(props, ref) {
const theme = useTheme();
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
import _default from '@pigment-css/react/theme';
import { useTheme } from '@pigment-css/react';

// This is intentional to make sure Pigment leaves the reference as-is.
console.log(useTheme);
export const Fade = React.forwardRef(function Fade(props, ref) {
const theme = _default;
return (
Expand Down
5 changes: 4 additions & 1 deletion packages/pigment-css-unplugin/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -347,7 +347,10 @@ export const plugin = createUnplugin<PigmentOptions, true>((options) => {
if (id.endsWith('styles.css')) {
return theme ? generateTokenCss(theme) : _code;
}
if (id.includes('pigment-css-react/theme')) {
if (
id.includes('pigment-css-react/theme') ||
id.includes(`${process.env.RUNTIME_PACKAGE_NAME}/theme`)
) {
return generateThemeSource(theme);
}
return null;
Expand Down
4 changes: 2 additions & 2 deletions packages/pigment-css-vite-plugin/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,10 +52,10 @@ export function pigment(options: PigmentOptions) {
name: 'vite-mui-theme-injection-plugin',
enforce: 'pre',
resolveId(source) {
if (source === `${process.env.RUNTIME_PACKAGE_NAME}/styles.css`) {
if (source.includes(`${process.env.RUNTIME_PACKAGE_NAME}/styles.css`)) {
return VIRTUAL_CSS_FILE;
}
if (source === `${process.env.RUNTIME_PACKAGE_NAME}/theme`) {
if (source.includes(`${process.env.RUNTIME_PACKAGE_NAME}/theme`)) {
return VIRTUAL_THEME_FILE;
}
return null;
Expand Down

0 comments on commit 9da7690

Please sign in to comment.