Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@ type Props = EditorProps & {
toggleConfigUI: () => void;
};

export class Configuration extends React.PureComponent<Props>
export class Configuration
extends React.PureComponent<Props>
implements Editor {
disposeInitializer?: Function;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,11 @@ type Props = EditorProps & {
onDispose: (cb: () => void) => void;
openText: () => void;
theme: any;
createFile: () => void;
};

export class ConfigurationComponent extends React.PureComponent<Props>
export class ConfigurationComponent
extends React.PureComponent<Props>
implements Editor {
disposeInitializer: Function;
currentModule: Module;
Expand Down Expand Up @@ -155,6 +157,7 @@ export class ConfigurationComponent extends React.PureComponent<Props>
sandbox={sandbox}
updateFile={this.updateFile}
file={this.props.getCode()}
updateFaker={this.props.updateFaker}
/>
</ThemeProvider>
</Container>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ export const VSCode: React.FunctionComponent = () => {
onChange={(code, moduleShortid) =>
actions.editor.codeChanged({ code, moduleShortid })
}
updateFaker={actions.files.updateFakerDataFile}
// Copy the object, we don't want mutations in the component
currentModule={json(getCurrentModule())}
config={config}
Expand Down
3 changes: 3 additions & 0 deletions packages/app/src/app/overmind/effects/api/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -176,6 +176,9 @@ export default {
id: sandboxId,
});
},
generateFakerData(fakerConfig: object) {
return api.post<object>(`/faker`, fakerConfig);
},
savePrivacy(sandboxId: string, privacy: 0 | 1 | 2) {
return api.patch<SandboxAPIResponse>(`/sandboxes/${sandboxId}/privacy`, {
sandbox: {
Expand Down
25 changes: 25 additions & 0 deletions packages/app/src/app/overmind/namespaces/files/actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -890,3 +890,28 @@ export const syncSandbox: AsyncAction<any[]> = async (
state.editor.currentSandbox
);
};

export const updateFakerDataFile: AsyncAction<object> = async (
{ state, actions, effects },
fakerConfig
) => {
if (!fakerConfig) return;

const json = await effects.api.generateFakerData(fakerConfig);

const jsonFile = state.editor.modulesByPath['/data.json'];
const code = JSON.stringify(json, null, 2);
if (jsonFile) {
actions.editor.codeSaved({
moduleShortid: jsonFile.shortid,
code,
cbID: null,
});
} else {
actions.files.moduleCreated({
title: 'data.json',
code,
directoryShortid: null,
});
}
};
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import folderSvg from '@codesandbox/common/lib/icons/folder.svg';
import folderOpenSvg from '@codesandbox/common/lib/icons/folder-open.svg';
import imageSvg from '@codesandbox/common/lib/icons/image.svg';
import nowSvg from '@codesandbox/common/lib/icons/now.svg';
import fakerSVG from '@codesandbox/common/lib/icons/faker.svg';

const imageExists = async (url: string): Promise<boolean> =>
new Promise((resolve, reject) => {
Expand All @@ -21,6 +22,7 @@ export const getIconURL = async (type: string): Promise<string> => {
const defaultURL = `${base}/${type}.svg`;
const URLByType = {
codesandbox: CodeSandboxSvg,
faker: fakerSVG,
image: imageSvg,
now: nowSvg,
directory: folderSvg,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,32 @@ export const JSIcon = props => (
</svg>
);

export const FakerIcon = props => (
<svg width={16} height={16} fill="none" viewBox="0 0 100 100" {...props}>
<path fill="#fff" d="M0 0H100V100H0z" />
<path fill="url(#pattern0)" d="M27 4H70V96H27z" />
<defs>
<pattern
id="pattern0"
width={1}
height={1}
patternContentUnits="objectBoundingBox"
>
<use
transform="matrix(.02326 0 0 .01087 -.302 -.087)"
xlinkHref="#image0"
/>
</pattern>
<image
id="image0"
width={394}
height={128}
xlinkHref=""
/>
</defs>
</svg>
);

export const CodeSandboxIcon = props => (
<svg width={16} height={16} viewBox="0 0 16 16" {...props}>
<g id="Page-1" fill="none" fillRule="evenodd" stroke="none" strokeWidth={1}>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import {
VercelIcon,
JSIcon,
CodeSandboxIcon,
FakerIcon,
} from './Icons';

const getIcon = name => {
Expand All @@ -32,6 +33,7 @@ const getIcon = name => {
'jsconfig.json': JSIcon,
'tsconfig.json': TypescriptIcon,
'sandbox.config.json': CodeSandboxIcon,
'faker-config.codesandbox.json': FakerIcon,
};

return icons[name] || JSIcon;
Expand Down
1 change: 1 addition & 0 deletions packages/app/src/app/utils/get-type.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ const specialCasesMap = {
'yarn.lock': 'yarn',
'package.json': 'npm',
'sandbox.config.json': 'codesandbox',
'faker-config.codesandbox.json': 'faker',
'now.json': 'now',
prisma: 'prisma',
'netlify.toml': 'netlify',
Expand Down
1 change: 1 addition & 0 deletions packages/common/src/components/Preference/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ type PreferenceProps<TString extends PreferenceType> = {
tooltip?: string;
options?: any[];
type: TString;
onChange?: any;
};

export type BooleanPreference = PreferenceProps<'boolean'> &
Expand Down
Loading