178 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			178 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Vue
		
	
	
| import manifest from '@ant-design/icons/lib/manifest';
 | |
| import Category from './Category';
 | |
| import { FilledIcon, OutlinedIcon, TwoToneIcon } from './themeIcons';
 | |
| import { categories } from './fields';
 | |
| 
 | |
| const IconDisplay = {
 | |
|   cagetories: categories,
 | |
|   newIconNames: [
 | |
|     // direction
 | |
|     'border-bottom',
 | |
|     'border-horizontal',
 | |
|     'border-inner',
 | |
|     'border-outter',
 | |
|     'border-left',
 | |
|     'border-right',
 | |
|     'border-top',
 | |
|     'border-verticle',
 | |
|     'pic-center',
 | |
|     'pic-left',
 | |
|     'pic-right',
 | |
|     'radius-bottomleft',
 | |
|     'radius-bottomright',
 | |
|     'radius-upleft',
 | |
|     'radius-upleft',
 | |
|     'fullscreen',
 | |
|     'fullscreen-exit',
 | |
|     // suggestion
 | |
|     'issues-close',
 | |
|     'stop',
 | |
| 
 | |
|     // edit
 | |
|     'scissor',
 | |
|     'snippets',
 | |
|     'diff',
 | |
|     'highlight',
 | |
|     'align-center',
 | |
|     'align-left',
 | |
|     'align-right',
 | |
|     'bg-colors',
 | |
|     'bold',
 | |
|     'italic',
 | |
|     'underline',
 | |
|     'redo',
 | |
|     'undo',
 | |
|     'zoom-in',
 | |
|     'zoom-out',
 | |
|     'font-colors',
 | |
|     'font-size',
 | |
|     'line-height',
 | |
|     'colum-height',
 | |
|     'colum-width',
 | |
|     'dash',
 | |
|     'small-dash',
 | |
|     'sort-ascending',
 | |
|     'sort-descending',
 | |
|     'drag',
 | |
|     'ordered-list',
 | |
|     'radius-setting',
 | |
| 
 | |
|     // data
 | |
|     'radar-chart',
 | |
|     'heat-map',
 | |
|     'fall',
 | |
|     'rise',
 | |
|     'stock',
 | |
|     'box-plot',
 | |
|     'fund',
 | |
|     'sliders',
 | |
| 
 | |
|     // other
 | |
|     'alert',
 | |
|     'audit',
 | |
|     'batch-folding',
 | |
|     'branches',
 | |
|     'build',
 | |
|     'border',
 | |
|     'crown',
 | |
|     'experiment',
 | |
|     'fire',
 | |
|     'money-collect',
 | |
|     'property-safety',
 | |
|     'read',
 | |
|     'reconciliation',
 | |
|     'rest',
 | |
|     'security-scan',
 | |
|     'insurance',
 | |
|     'interation',
 | |
|     'safety-certificate',
 | |
|     'project',
 | |
|     'thunderbolt',
 | |
|     'block',
 | |
|     'cluster',
 | |
|     'deployment-unit',
 | |
|     'dollar',
 | |
|     'euro',
 | |
|     'pound',
 | |
|     'file-done',
 | |
|     'file-exclamation',
 | |
|     'file-protect',
 | |
|     'file-search',
 | |
|     'file-sync',
 | |
|     'gateway',
 | |
|     'gold',
 | |
|     'robot',
 | |
|     'strikethrough',
 | |
|     'shopping',
 | |
| 
 | |
|     // logo
 | |
|     'alibaba',
 | |
|     'yahoo',
 | |
|   ],
 | |
| 
 | |
|   themeTypeMapper: {
 | |
|     filled: 'fill',
 | |
|     outlined: 'outline',
 | |
|     twoTone: 'twotone',
 | |
|   },
 | |
|   data() {
 | |
|     return {
 | |
|       theme: 'outlined',
 | |
|     };
 | |
|   },
 | |
|   methods: {
 | |
|     getComputedDisplayList() {
 | |
|       return Object.keys(IconDisplay.cagetories)
 | |
|         .map(category => ({
 | |
|           category,
 | |
|           icons: IconDisplay.cagetories[category].filter(
 | |
|             name => manifest[IconDisplay.themeTypeMapper[this.theme]].indexOf(name) !== -1,
 | |
|           ),
 | |
|         }))
 | |
|         .filter(({ icons }) => Boolean(icons.length));
 | |
|     },
 | |
| 
 | |
|     handleChangeTheme(e) {
 | |
|       this.theme = e.target.value;
 | |
|     },
 | |
| 
 | |
|     renderCategories(list) {
 | |
|       return list.map(({ category, icons }) => {
 | |
|         return (
 | |
|           <Category
 | |
|             key={category}
 | |
|             title={category}
 | |
|             icons={icons}
 | |
|             theme={this.theme}
 | |
|             newIcons={IconDisplay.newIconNames}
 | |
|           />
 | |
|         );
 | |
|       });
 | |
|     },
 | |
|   },
 | |
| 
 | |
|   render() {
 | |
|     const list = this.getComputedDisplayList();
 | |
|     const message = this.$t('message');
 | |
|     return (
 | |
|       <div>
 | |
|         <h3>{message['app.docs.components.icon.pick-theme']}</h3>
 | |
|         <a-radio-group value={this.theme} onChange={this.handleChangeTheme}>
 | |
|           <a-radio-button value="outlined">
 | |
|             <a-icon component={OutlinedIcon} /> {message['app.docs.components.icon.outlined']}
 | |
|           </a-radio-button>
 | |
|           <a-radio-button value="filled">
 | |
|             <a-icon component={FilledIcon} /> {message['app.docs.components.icon.filled']}
 | |
|           </a-radio-button>
 | |
|           <a-radio-button value="twoTone">
 | |
|             <a-icon component={TwoToneIcon} /> {message['app.docs.components.icon.two-tone']}
 | |
|           </a-radio-button>
 | |
|         </a-radio-group>
 | |
|         {this.renderCategories(list)}
 | |
|       </div>
 | |
|     );
 | |
|   },
 | |
| };
 | |
| 
 | |
| export default IconDisplay;
 |