mirror of
https://github.com/vuejs/vue-cli.git
synced 2026-04-21 20:08:41 -05:00
a09407dd5b
* feat: basic fonctionality, welcome and kill port widgets * fix: contrast improvements * feat: plugin/dep/vulnerability widgets design * fix: widget add/remove animation * feat: run task widget * feat: news + wip resizing * feat: nuxt * chore: removed widget example * fix: visual polish for widget transform * feat(widget): overlap detection * fix: news default/max size * feat(dashboard): sidepane transition * chore: dev api server port * fix(widget): configure tooltip * refactor(widget): generic Movable mixin * refactor(widget): resizable mixin * feat(widget): resize transition * feat(widget): resize improvements * refactor(widget): zoom factor * refactor(widget): OnGrid mixin * refactor(widget): resize handler style moved to global * chore: remove console.log * refactor: files structure * feat: improved design and layout * fix: content background vars * fix: status bar / view nav z-indexes * fix: webpack dashboard grid gap * feat(news feed): handle errors * fix(card): dimmed box shadow * fix: view nav & status bar z-index * fix: remove (wip) * feat(widget): style tweaks * feat(widget): details pane (wip) * feat: news feed widget improvements * feat(widget): custom header button * feat(news): item details pane * feat(widget): custom title * fix(news): better cache and misc fixes * feat(widget): resize left and top handles * feat(widget): transparent widget while moving/resizing * feat(news): better "big size" style * fix(news): media sizes in rich content * feat(plugin): local plugins support * fix: scrolling issue in Fx * fix: colors * fix(nav bar): more item overflowing * feat(vuln): frontend * chore: locale update * fix: image in suggestion dropdown (dev) * fix(suggestion): missing custom image * feat(view): user default plugin logo if no provided icon * feat(view): better loading UX * feat(view): button background if view is selected * feat(view): new nav indicator * feat(widget): use plugin logo as default icon * feat(widget): better widget modal * feat(widget): longDescription * fix(widget): news validate url param * feat(widget): filter widgets in add pane * feat(widget): tease upcoming widgets * chore: fix merge dev * chore: yarn install * chore: sync versions * chore: update apollo * docs: widget * fix(progress): graphql error * fix(deps): localPath * perf(plugin): faster local plugin refresh * fix(nav): center active indicator * feat(task): improved header * feat(client addon): custom component load timeout message * feat(suggestion): ping animation to improve discoverability * chore: update vue-apollo * feat(api): requestRoute * fix(suggestion): hide more info link if no link * fix(style): ul padding * test(e2e): fix plugin path * chore: change test scripts * chore(deps): upgrade * fix: build error * fix(widget): removed moving scale transform * fix(widget): resize handles style * chore(deps): unpin apollo-utilities * chore(deps): lock fix * test(e2e): fix server * fix: issue with writeQuery See: https://github.com/apollographql/apollo-client/issues/4031#issuecomment-433668473 * test(e2e): fix tests * test(e2e): missing widgets build * fix: missing widgets dep
92 lines
2.9 KiB
JavaScript
92 lines
2.9 KiB
JavaScript
const { withFilter } = require('graphql-subscriptions')
|
|
const path = require('path')
|
|
const globby = require('globby')
|
|
const merge = require('lodash.merge')
|
|
const GraphQLJSON = require('graphql-type-json')
|
|
// Channels for subscriptions
|
|
const channels = require('./channels')
|
|
// Connectors
|
|
const cwd = require('./connectors/cwd')
|
|
const progress = require('./connectors/progress')
|
|
const files = require('./connectors/files')
|
|
const clientAddons = require('./connectors/client-addons')
|
|
const sharedData = require('./connectors/shared-data')
|
|
const locales = require('./connectors/locales')
|
|
// Start ipc server
|
|
require('./util/ipc')
|
|
|
|
process.env.VUE_CLI_API_MODE = true
|
|
|
|
const resolvers = [{
|
|
JSON: GraphQLJSON,
|
|
|
|
DescribedEntity: {
|
|
__resolveType (obj, context, info) {
|
|
return null
|
|
}
|
|
},
|
|
|
|
ClientAddon: {
|
|
url: (addon, args, context) => clientAddons.getUrl(addon, context)
|
|
},
|
|
|
|
Query: {
|
|
cwd: () => cwd.get(),
|
|
progress: (root, { id }, context) => progress.get(id, context),
|
|
clientAddons: (root, args, context) => clientAddons.list(context),
|
|
sharedData: (root, args, context) => sharedData.get(args, context),
|
|
locales: (root, args, context) => locales.list(context)
|
|
},
|
|
|
|
Mutation: {
|
|
fileOpenInEditor: (root, { input }, context) => files.openInEditor(input, context),
|
|
sharedDataUpdate: (root, args, context) => sharedData.set(args, context)
|
|
},
|
|
|
|
Subscription: {
|
|
cwdChanged: {
|
|
subscribe: (parent, args, { pubsub }) => pubsub.asyncIterator(channels.CWD_CHANGED)
|
|
},
|
|
progressChanged: {
|
|
subscribe: withFilter(
|
|
// Iterator
|
|
(parent, args, { pubsub }) => pubsub.asyncIterator(channels.PROGRESS_CHANGED),
|
|
// Filter
|
|
(payload, vars) => payload.progressChanged.id === vars.id
|
|
)
|
|
},
|
|
progressRemoved: {
|
|
subscribe: withFilter(
|
|
// Iterator
|
|
(parent, args, { pubsub }) => pubsub.asyncIterator(channels.PROGRESS_REMOVED),
|
|
// Filter
|
|
(payload, vars) => payload.progressRemoved === vars.id
|
|
)
|
|
},
|
|
clientAddonAdded: {
|
|
subscribe: (parent, args, { pubsub }) => pubsub.asyncIterator(channels.CLIENT_ADDON_ADDED)
|
|
},
|
|
sharedDataUpdated: {
|
|
subscribe: withFilter(
|
|
(parent, args, { pubsub }) => pubsub.asyncIterator(channels.SHARED_DATA_UPDATED),
|
|
(payload, vars) => payload.sharedDataUpdated.id === vars.id && payload.sharedDataUpdated.projectId === vars.projectId
|
|
)
|
|
},
|
|
localeAdded: {
|
|
subscribe: (parent, args, { pubsub }) => pubsub.asyncIterator(channels.LOCALE_ADDED)
|
|
},
|
|
routeRequested: {
|
|
subscribe: (parent, args, { pubsub }) => pubsub.asyncIterator(channels.ROUTE_REQUESTED)
|
|
}
|
|
}
|
|
}]
|
|
|
|
// Load resolvers in './schema'
|
|
const paths = globby.sync([path.join(__dirname, './schema/*.js')])
|
|
paths.forEach(file => {
|
|
const { resolvers: r } = require(file)
|
|
r && resolvers.push(r)
|
|
})
|
|
|
|
module.exports = merge.apply(null, resolvers)
|