From 8cd41995553a67d8a03051db56ffc58540ffe04b Mon Sep 17 00:00:00 2001 From: Andrey Sitnik Date: Mon, 11 Sep 2017 18:37:25 +1000 Subject: [PATCH] Compress data --- .gitignore | 2 +- data/index.js | 32 ++++++++++++++++++++++++++++++++ package.json | 4 ++-- scripts/build-data.js | 26 ++++++++++++-------------- src/utils/emoji-index.js | 2 -- 5 files changed, 47 insertions(+), 19 deletions(-) create mode 100644 data/index.js diff --git a/.gitignore b/.gitignore index 4899342..f1db726 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,4 @@ node_modules/ -data/ +data/data.js dist/ bundle.js diff --git a/data/index.js b/data/index.js new file mode 100644 index 0000000..f94997b --- /dev/null +++ b/data/index.js @@ -0,0 +1,32 @@ +var buildSearch = require('../src/utils/build-search') +var data = require('./data') + +function uncompress (list) { + for (var short_name in list) { + var datum = list[short_name] + + if (!datum.short_names) datum.short_names = [] + datum.short_names.unshift(short_name) + + datum.sheet_x = datum.sheet[0] + datum.sheet_y = datum.sheet[1] + delete datum.sheet + + if (!datum.text) datum.text = '' + if (datum.added_in !== null && !datum.added_in) datum.added_in = '6.0' + + datum.search = buildSearch({ + short_names: datum.short_names, + name: datum.name, + keywords: datum.keywords, + emoticons: datum.emoticons + }) + + datum.search = datum.search.join(',') + } +} + +uncompress(data.emojis) +uncompress(data.skins) + +module.exports = data diff --git a/package.json b/package.json index 64a787f..b525bbd 100644 --- a/package.json +++ b/package.json @@ -54,7 +54,7 @@ "webpack": "1.12.14" }, "scripts": { - "clean": "rimraf data/ dist/", + "clean": "rimraf data/data.js dist/", "clean:dist": "rm -rf dist/", "build:data": "node scripts/build-data", "build:example": "node scripts/build-example", @@ -71,7 +71,7 @@ "size-limit": [ { "path": "dist/index.js", - "limit": "110 KB" + "limit": "88 KB" } ] } diff --git a/scripts/build-data.js b/scripts/build-data.js index bf60617..ded3fff 100644 --- a/scripts/build-data.js +++ b/scripts/build-data.js @@ -2,8 +2,7 @@ var fs = require('fs'), emojiData = require('emoji-datasource'), emojiLib = require('emojilib'), inflection = require('inflection'), - mkdirp = require('mkdirp'), - buildSearch = require('../src/utils/build-search') + mkdirp = require('mkdirp') var unifiedToNative = unified => String.fromCodePoint( ...unified.split('-').map(s => parseInt(s, 16)) @@ -92,18 +91,9 @@ emojiData.forEach((datum) => { delete datum.texts if (emojiLibMatch) { - keywords = emojiLibMatch.keywords + datum.keywords = emojiLibMatch.keywords } - datum.search = buildSearch({ - short_names: datum.short_names, - name: datum.name, - keywords, - emoticons: datum.emoticons - }) - - datum.search = datum.search.join(',') - if (datum.category == 'Skin Tones') { data.skins[datum.short_name] = datum } else { @@ -117,6 +107,12 @@ emojiData.forEach((datum) => { data.short_names[short_name] = datum.short_name }) + datum.short_names = datum.short_names.filter(i => i !== datum.short_name) + datum.sheet = [datum.sheet_x, datum.sheet_y] + + if (datum.text === '') delete datum.text + if (datum.added_in === '6.0') delete datum.added_in + delete datum.docomo delete datum.au delete datum.softbank @@ -125,6 +121,8 @@ emojiData.forEach((datum) => { delete datum.short_name delete datum.category delete datum.sort_order + delete datum.sheet_x + delete datum.sheet_y for (let key in datum) { let value = datum[key] @@ -141,8 +139,8 @@ flags.emojis.sort() mkdirp('data', (err) => { if (err) throw err - const stringifiedData = JSON.stringify(data).replace(/\"([A-Za-z_]+)\":/g, '$1:') - fs.writeFile('data/index.js', `export default ${stringifiedData}`, (err) => { + const stringified = JSON.stringify(data).replace(/\"([A-Za-z_]+)\":/g, '$1:') + fs.writeFile('data/data.js', `module.exports = ${stringified}`, (err) => { if (err) throw err }) }) diff --git a/src/utils/emoji-index.js b/src/utils/emoji-index.js index e1dba13..36709a0 100644 --- a/src/utils/emoji-index.js +++ b/src/utils/emoji-index.js @@ -1,5 +1,3 @@ -const extend = require('util')._extend - import data from '../../data' import { getData, getSanitizedData, intersect } from '.'