mirror of
https://github.com/lingble/chatwoot.git
synced 2026-03-20 03:52:43 +00:00
* feat: allow caching of labels in the account scope * feat: send cache keys in account json response * feat: kickstart web worker * feat: setup basic architecture for workers * feat: install idb * feat: add datamanger * fix: typos * refactor: rename method * feat: make init db a manual step * refactor: separate accountIdFromRoute * feat: cache enabled API client * feat: enable caching for inboxes and labels * feat: enable cache for team * feat: manage exceptions for team * feat: add team to data manager * feat: add a generic listener * refactor: send only cache keys * refactor: separate validate method * feat: add listeners * feat: add event for revalidate * feat: add cache keys endpoint * refactor: fetch cache keys instead of full account data * fix: key pattern * feat: don't fetch account for cache_keys * fix: cache key base class * refactor: cache keys helper * feat: add helper * fix: cache-key update logic * feat: delete indexeddb on logout * feat: remove worker.js * refactor: move data-manager * refactor: name of file * feat: add test for DataManager * refactor: add fake idb to jest setup * test: cache keys helper * test: cache keys helper * test: cache_keys in accounts controller * refactor: remove cache_keys context * feat: add policy for cache-keys
44 lines
1.0 KiB
JavaScript
44 lines
1.0 KiB
JavaScript
const { environment } = require('@rails/webpacker');
|
|
const { VueLoaderPlugin } = require('vue-loader');
|
|
const resolve = require('./resolve');
|
|
const vue = require('./loaders/vue');
|
|
|
|
environment.plugins.prepend('VueLoaderPlugin', new VueLoaderPlugin());
|
|
environment.loaders.prepend('vue', vue);
|
|
|
|
environment.loaders.append('opus-ogg', {
|
|
test: /encoderWorker\.min\.js$/,
|
|
loader: 'file-loader',
|
|
options: {
|
|
name: '[name].[ext]',
|
|
},
|
|
});
|
|
|
|
environment.loaders.append('opus-wav', {
|
|
test: /waveWorker\.min\.js$/,
|
|
loader: 'file-loader',
|
|
options: {
|
|
name: '[name].[ext]',
|
|
},
|
|
});
|
|
|
|
environment.loaders.append('audio', {
|
|
test: /\.(mp3)(\?.*)?$/,
|
|
loader: 'url-loader',
|
|
query: {
|
|
limit: 10000,
|
|
name: 'audio/[name].[ext]',
|
|
},
|
|
});
|
|
|
|
const preserveNameFor = ['sdk', 'worker'];
|
|
|
|
environment.config.merge({ resolve });
|
|
environment.config.set('output.filename', chunkData => {
|
|
return preserveNameFor.includes(chunkData.chunk.name)
|
|
? 'js/[name].js'
|
|
: 'js/[name]-[hash].js';
|
|
});
|
|
|
|
module.exports = environment;
|