Skip to content

Commit

Permalink
feat: add support taro-react generator
Browse files Browse the repository at this point in the history
  • Loading branch information
axetroy committed Aug 26, 2023
1 parent a797a35 commit d4e3772
Show file tree
Hide file tree
Showing 25 changed files with 913 additions and 3 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ IconFont Componentized 是一系列工具,用于生成 IconFont 组件用于
### 支持生成的框架/环境

- [React](packages/gen-react/__tests__/output.spec.1/)
- [Taro-React](packages/gen-taro-react/__tests__/output.spec.1/)
- [Vue](packages/gen-vue/__tests__/output.spec.1/)
- [WebComponent](packages/gen-web-component/__tests__/output.spec.1/)
- [DOM](packages/gen-dom/__tests__/output.spec.1/)
Expand Down
4 changes: 2 additions & 2 deletions packages/gen-react/__tests__/index.spec.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { DiskWriter, DEFAULT_CONFIG } from "@iconfont-componentized/share";

import ReactComponentGenerator from "../src/index";
import TaroReactComponentGenerator from "../src/index";
import path from "path";

describe("generate react", () => {
it("generate react 1", async () => {
await new ReactComponentGenerator(DiskWriter, DEFAULT_CONFIG).write("https://at.alicdn.com/t/font_caopq7l9o8t1emi.js", {
await new TaroReactComponentGenerator(DiskWriter, DEFAULT_CONFIG).write("https://at.alicdn.com/t/font_caopq7l9o8t1emi.js", {
outputDir: path.join(__dirname, "output.spec.1"),
});
});
Expand Down
Empty file.
46 changes: 46 additions & 0 deletions packages/gen-taro-react/LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
Copyright (c) 2023 Axetroy

Anti 996 License Version 1.0 (Draft)

Permission is hereby granted to any individual or legal entity
obtaining a copy of this licensed work (including the source code,
documentation and/or related items, hereinafter collectively referred
to as the "licensed work"), free of charge, to deal with the licensed
work for any purpose, including without limitation, the rights to use,
reproduce, modify, prepare derivative works of, distribute, publish
and sublicense the licensed work, subject to the following conditions:

1. The individual or the legal entity must conspicuously display,
without modification, this License and the notice on each redistributed
or derivative copy of the Licensed Work.

2. The individual or the legal entity must strictly comply with all
applicable laws, regulations, rules and standards of the jurisdiction
relating to labor and employment where the individual is physically
located or where the individual was born or naturalized; or where the
legal entity is registered or is operating (whichever is stricter). In
case that the jurisdiction has no such laws, regulations, rules and
standards or its laws, regulations, rules and standards are
unenforceable, the individual or the legal entity are required to
comply with Core International Labor Standards.

3. The individual or the legal entity shall not induce or force its
employee(s), whether full-time or part-time, or its independent
contractor(s), in any methods, to agree in oral or written form, to
directly or indirectly restrict, weaken or relinquish his or her
rights or remedies under such laws, regulations, rules and standards
relating to labor and employment as mentioned above, no matter whether
such written or oral agreement are enforceable under the laws of the
said jurisdiction, nor shall such individual or the legal entity
limit, in any methods, the rights of its employee(s) or independent
contractor(s) from reporting or complaining to the copyright holder or
relevant authorities monitoring the compliance of the license about
its violation(s) of the said license.

THE LICENSED WORK IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM,
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
OTHERWISE, ARISING FROM, OUT OF OR IN ANY WAY CONNECTION WITH THE
LICENSED WORK OR THE USE OR OTHER DEALINGS IN THE LICENSED WORK.
1 change: 1 addition & 0 deletions packages/gen-taro-react/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
[Docs](https://github.com/axetroy/iconfont-componentized)
12 changes: 12 additions & 0 deletions packages/gen-taro-react/__tests__/index.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import { DiskWriter, DEFAULT_CONFIG } from "@iconfont-componentized/share";

import ReactComponentGenerator from "../src/index";
import path from "path";

describe("generate react", () => {
it("generate react 1", async () => {
await new ReactComponentGenerator(DiskWriter, DEFAULT_CONFIG).write("https://at.alicdn.com/t/font_caopq7l9o8t1emi.js", {
outputDir: path.join(__dirname, "output.spec.1"),
});
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// generate by iconfont-componentized

import React from "react";
import { ImageProps } from '@tarojs/components';

declare var IconFontAnonymousIconfont: React.FC<ImageProps & { size?: number | string }>;

export default IconFontAnonymousIconfont;
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
// generate by iconfont-componentized
import React, { memo, useMemo } from 'react';
import { Image } from '@tarojs/components';

function IconFontAnonymousIconfont (props) {
const classNames = useMemo(() => {
const classNameParts = ['icon-font', 'icon-font-anonymous-iconfont'];

if (props.className) {
classNameParts.push(props.className);
}

return classNameParts.join(' ');
}, [props.className]);

const src = useMemo(() => {
return ""
}, [])

const styles = useMemo(() => {
return {
width: props.size,
height: props.size,
...(props.style || {})
}
}, [props.size, props.style])

return <Image className={classNames} {...props} style={styles} src={src}/>
}

IconFontAnonymousIconfont.displayName = 'IconFontAnonymousIconfont';

IconFontAnonymousIconfont.defaultProps = {
size: 32
}

export default memo(IconFontAnonymousIconfont)
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// generate by iconfont-componentized

import React from "react";
import { ImageProps } from '@tarojs/components';

declare var IconFontBriefcase: React.FC<ImageProps & { size?: number | string }>;

export default IconFontBriefcase;
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
// generate by iconfont-componentized
import React, { memo, useMemo } from 'react';
import { Image } from '@tarojs/components';

function IconFontBriefcase (props) {
const classNames = useMemo(() => {
const classNameParts = ['icon-font', 'icon-font-briefcase'];

if (props.className) {
classNameParts.push(props.className);
}

return classNameParts.join(' ');
}, [props.className]);

const src = useMemo(() => {
return ""
}, [])

const styles = useMemo(() => {
return {
width: props.size,
height: props.size,
...(props.style || {})
}
}, [props.size, props.style])

return <Image className={classNames} {...props} style={styles} src={src}/>
}

IconFontBriefcase.displayName = 'IconFontBriefcase';

IconFontBriefcase.defaultProps = {
size: 32
}

export default memo(IconFontBriefcase)
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// generate by iconfont-componentized

import React from "react";
import { ImageProps } from '@tarojs/components';

declare var IconFontCanjuYongcan: React.FC<ImageProps & { size?: number | string }>;

export default IconFontCanjuYongcan;
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
// generate by iconfont-componentized
import React, { memo, useMemo } from 'react';
import { Image } from '@tarojs/components';

function IconFontCanjuYongcan (props) {
const classNames = useMemo(() => {
const classNameParts = ['icon-font', 'icon-font-canju-yongcan'];

if (props.className) {
classNameParts.push(props.className);
}

return classNameParts.join(' ');
}, [props.className]);

const src = useMemo(() => {
return ""
}, [])

const styles = useMemo(() => {
return {
width: props.size,
height: props.size,
...(props.style || {})
}
}, [props.size, props.style])

return <Image className={classNames} {...props} style={styles} src={src}/>
}

IconFontCanjuYongcan.displayName = 'IconFontCanjuYongcan';

IconFontCanjuYongcan.defaultProps = {
size: 32
}

export default memo(IconFontCanjuYongcan)
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// generate by iconfont-componentized

import React from "react";
import { ImageProps } from '@tarojs/components';

declare var IconFontJia: React.FC<ImageProps & { size?: number | string }>;

export default IconFontJia;
37 changes: 37 additions & 0 deletions packages/gen-taro-react/__tests__/output.spec.1/IconFontJia.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
// generate by iconfont-componentized
import React, { memo, useMemo } from 'react';
import { Image } from '@tarojs/components';

function IconFontJia (props) {
const classNames = useMemo(() => {
const classNameParts = ['icon-font', 'icon-font-jia'];

if (props.className) {
classNameParts.push(props.className);
}

return classNameParts.join(' ');
}, [props.className]);

const src = useMemo(() => {
return ""
}, [])

const styles = useMemo(() => {
return {
width: props.size,
height: props.size,
...(props.style || {})
}
}, [props.size, props.style])

return <Image className={classNames} {...props} style={styles} src={src}/>
}

IconFontJia.displayName = 'IconFontJia';

IconFontJia.defaultProps = {
size: 32
}

export default memo(IconFontJia)
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
// generate by iconfont-componentized

import React from "react";
import { ImageProps } from '@tarojs/components';

declare var IconFontJiesuan: React.FC<ImageProps & { size?: number | string }>;

export default IconFontJiesuan;
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
// generate by iconfont-componentized
import React, { memo, useMemo } from 'react';
import { Image } from '@tarojs/components';

function IconFontJiesuan (props) {
const classNames = useMemo(() => {
const classNameParts = ['icon-font', 'icon-font-jiesuan'];

if (props.className) {
classNameParts.push(props.className);
}

return classNameParts.join(' ');
}, [props.className]);

const src = useMemo(() => {
return ""
}, [])

const styles = useMemo(() => {
return {
width: props.size,
height: props.size,
...(props.style || {})
}
}, [props.size, props.style])

return <Image className={classNames} {...props} style={styles} src={src}/>
}

IconFontJiesuan.displayName = 'IconFontJiesuan';

IconFontJiesuan.defaultProps = {
size: 32
}

export default memo(IconFontJiesuan)
22 changes: 22 additions & 0 deletions packages/gen-taro-react/__tests__/output.spec.1/index.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
// generate by iconfont-componentized

import React from 'react';
import { ImageProps } from '@tarojs/components';

export type IconFontName = 'jia' | 'briefcase' | 'anonymous-iconfont' | 'jiesuan' | 'canju-yongcan';

import IconFontJia from './IconFontJia';
import IconFontBriefcase from './IconFontBriefcase';
import IconFontAnonymousIconfont from './IconFontAnonymousIconfont';
import IconFontJiesuan from './IconFontJiesuan';
import IconFontCanjuYongcan from './IconFontCanjuYongcan';

export { IconFontJia };
export { IconFontBriefcase };
export { IconFontAnonymousIconfont };
export { IconFontJiesuan };
export { IconFontCanjuYongcan };

declare var IconFont: React.FC<ImageProps & { name: IconFontName, size?: number | string }>;

export default IconFont;
Loading

0 comments on commit d4e3772

Please sign in to comment.