Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
c8eed07c
Commit
c8eed07c
authored
May 31, 2021
by
Tom Quirk
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Clean up storybook config
- upgrade storybook packages - add comments to webpack config
parent
633d5e0c
Changes
8
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
1611 additions
and
1653 deletions
+1611
-1653
.eslintrc.yml
.eslintrc.yml
+4
-3
.gitlab/ci/pages.gitlab-ci.yml
.gitlab/ci/pages.gitlab-ci.yml
+1
-2
app/assets/javascripts/vue_shared/components/todo_button.stories.js
.../javascripts/vue_shared/components/todo_button.stories.js
+12
-5
storybook/config/main.js
storybook/config/main.js
+1
-1
storybook/config/preview.js
storybook/config/preview.js
+0
-4
storybook/config/webpack.config.js
storybook/config/webpack.config.js
+35
-27
storybook/package.json
storybook/package.json
+8
-10
storybook/yarn.lock
storybook/yarn.lock
+1550
-1601
No files found.
.eslintrc.yml
View file @
c8eed07c
...
@@ -89,9 +89,6 @@ rules:
...
@@ -89,9 +89,6 @@ rules:
group
:
internal
group
:
internal
alphabetize
:
alphabetize
:
order
:
asc
order
:
asc
filenames/match-regex
:
-
error
-
"
^[a-z_]+(
\\
.stories|
\\
.config|
\\
.documentation|
\\
.[a-z_]+
\\
.example|
\\
.spec)?$"
overrides
:
overrides
:
-
files
:
-
files
:
-
'
**/spec/**/*'
-
'
**/spec/**/*'
...
@@ -110,3 +107,7 @@ overrides:
...
@@ -110,3 +107,7 @@ overrides:
import/no-nodejs-modules
:
off
import/no-nodejs-modules
:
off
filenames/match-regex
:
off
filenames/match-regex
:
off
no-console
:
off
no-console
:
off
-
files
:
-
'
*.stories.js'
rules
:
filenames/match-regex
:
off
.gitlab/ci/pages.gitlab-ci.yml
View file @
c8eed07c
pages
:
pages
:
extends
:
extends
:
-
.default-retry
-
.default-retry
-
.pages:rules
stage
:
pages
stage
:
pages
needs
:
needs
:
-
rspec:coverage
-
rspec:coverage
...
@@ -21,5 +22,3 @@ pages:
...
@@ -21,5 +22,3 @@ pages:
paths
:
paths
:
-
public
-
public
expire_in
:
31d
expire_in
:
31d
rules
:
-
when
:
manual
app/assets/javascripts/vue_shared/components/todo_button.stories.js
View file @
c8eed07c
...
@@ -7,10 +7,17 @@ export default {
...
@@ -7,10 +7,17 @@ export default {
title
:
'
components/todo_button
'
,
title
:
'
components/todo_button
'
,
};
};
export
const
Primary
=
(
)
=>
({
const
Template
=
(
args
,
{
argTypes
}
)
=>
({
components
:
{
TodoButton
},
components
:
{
TodoButton
},
template
:
'
<todo-button />
'
,
props
:
Object
.
keys
(
argTypes
),
argTypes
:
{
template
:
'
<todo-button v-bind="$props" v-on="$props" />
'
,
isTodo
:
{
description
:
'
True if to-do is unresolved (i.e. not "done")
'
,
control
:
'
boolean
'
},
},
});
});
export
const
Default
=
Template
.
bind
({});
Default
.
argTypes
=
{
isTodo
:
{
description
:
'
True if to-do is unresolved (i.e. not "done")
'
,
control
:
{
type
:
'
boolean
'
},
},
click
:
{
action
:
'
clicked
'
},
};
storybook/config/main.js
View file @
c8eed07c
/* eslint-disable import/no-commonjs */
/* eslint-disable import/no-commonjs */
module
.
exports
=
{
module
.
exports
=
{
stories
:
[
'
../../app/assets/javascripts/**/*.stories.js
'
],
stories
:
[
'
../../app/assets/javascripts/**/*.stories.js
'
],
addons
:
[
'
@storybook/addon-
links
'
,
'
@storybook/addon-essentials
'
,
'
@storybook/addon-controls
'
],
addons
:
[
'
@storybook/addon-
essentials
'
,
'
@storybook/addon-a11y
'
],
};
};
storybook/config/preview.js
View file @
c8eed07c
...
@@ -5,7 +5,3 @@ const stylesheetsRequireCtx = require.context(
...
@@ -5,7 +5,3 @@ const stylesheetsRequireCtx = require.context(
);
);
stylesheetsRequireCtx
(
'
./application.scss
'
);
stylesheetsRequireCtx
(
'
./application.scss
'
);
export
const
parameters
=
{
actions
:
{
argTypesRegex
:
'
^on[A-Z].*
'
},
};
storybook/config/webpack.config.js
View file @
c8eed07c
...
@@ -2,50 +2,51 @@
...
@@ -2,50 +2,51 @@
const
{
statSync
}
=
require
(
'
fs
'
);
const
{
statSync
}
=
require
(
'
fs
'
);
const
path
=
require
(
'
path
'
);
const
path
=
require
(
'
path
'
);
const
sass
=
require
(
'
node-sass
'
);
const
sass
=
require
(
'
node-sass
'
);
// eslint-disable-line import/no-unresolved
const
{
buildIncludePaths
,
resolveGlobUrl
}
=
require
(
'
node-sass-magic-importer/dist/toolbox
'
);
const
{
buildIncludePaths
,
resolveGlobUrl
}
=
require
(
'
node-sass-magic-importer/dist/toolbox
'
);
// eslint-disable-line import/no-unresolved
const
webpack
=
require
(
'
webpack
'
);
const
webpack
=
require
(
'
webpack
'
);
const
gitlabWebpackConfig
=
require
(
'
../../config/webpack.config.js
'
);
const
gitlabWebpackConfig
=
require
(
'
../../config/webpack.config.js
'
);
const
ROOT
=
path
.
resolve
(
__dirname
,
'
../../
'
);
const
TRANSPARENT_1X1_PNG
=
const
TRANSPARENT_1X1_PNG
=
'
url()
'
;
'
url()
'
;
const
SASS_INCLUDE_PATHS
=
[
'
app/assets/stylesheets
'
,
'
ee/app/assets/stylesheets
'
,
'
ee/app/assets/stylesheets/_ee
'
,
'
node_modules
'
,
].
map
((
p
)
=>
path
.
resolve
(
ROOT
,
p
));
function
smartImporter
(
url
,
prev
)
{
/**
* Custom importer for node-sass, used when LibSass encounters the `@import` directive.
* Doc source: https://github.com/sass/node-sass#importer--v200---experimental
* @param {*} url the path in import as-is, which LibSass encountered.
* @param {*} prev the previously resolved path.
* @returns {Object | null} the new import string.
*/
function
sassSmartImporter
(
url
,
prev
)
{
const
nodeSassOptions
=
this
.
options
;
const
nodeSassOptions
=
this
.
options
;
const
includePaths
=
buildIncludePaths
(
nodeSassOptions
.
includePaths
,
prev
).
filter
(
const
includePaths
=
buildIncludePaths
(
nodeSassOptions
.
includePaths
,
prev
).
filter
(
(
includePath
)
=>
!
includePath
.
includes
(
'
node_modules
'
),
(
includePath
)
=>
!
includePath
.
includes
(
'
node_modules
'
),
);
);
// if (url.startsWith('@gitlab/ui')) {
// GitLab extensively uses glob-style import paths, but
// return { file: resolveUrl(url.replace('@gitlab/ui/', ''), includePaths) };
// Sass doesn't support glob-style URLs out of the box.
// }
// Here, we try and resolve the glob URL.
// If it resolves, we update the @import statement with the resolved path.
// if (url === 'framework/variables') {
// return { contents: patchedFrameworkVariables };
// }
const
filePaths
=
resolveGlobUrl
(
url
,
includePaths
);
const
filePaths
=
resolveGlobUrl
(
url
,
includePaths
);
if
(
filePaths
)
{
if
(
filePaths
)
{
const
contents
=
filePaths
const
contents
=
filePaths
.
filter
((
file
)
=>
statSync
(
file
).
isFile
())
.
filter
((
file
)
=>
statSync
(
file
).
isFile
())
.
map
((
x
)
=>
`@import '
${
x
}
';`
)
.
map
((
x
)
=>
`@import '
${
x
}
';`
)
.
join
(
`\n`
);
.
join
(
`\n`
);
return
{
contents
};
return
{
contents
};
}
}
return
null
;
return
null
;
}
}
const
ROOT
=
path
.
resolve
(
__dirname
,
'
../../
'
);
const
sassIncludePaths
=
[
'
app/assets/stylesheets
'
,
'
ee/app/assets/stylesheets
'
,
'
ee/app/assets/stylesheets/_ee
'
,
'
node_modules
'
,
].
map
((
p
)
=>
path
.
resolve
(
ROOT
,
p
));
const
sassLoaderOptions
=
{
const
sassLoaderOptions
=
{
functions
:
{
functions
:
{
'
image-url($url)
'
:
function
sassImageUrlStub
()
{
'
image-url($url)
'
:
function
sassImageUrlStub
()
{
...
@@ -61,18 +62,17 @@ const sassLoaderOptions = {
...
@@ -61,18 +62,17 @@ const sassLoaderOptions = {
return
new
sass
.
types
.
String
(
TRANSPARENT_1X1_PNG
);
return
new
sass
.
types
.
String
(
TRANSPARENT_1X1_PNG
);
},
},
},
},
includePaths
:
sassIncludePaths
,
includePaths
:
SASS_INCLUDE_PATHS
,
importer
:
smartImporter
,
importer
:
s
assS
martImporter
,
};
};
module
.
exports
=
({
config
})
=>
{
module
.
exports
=
function
storybookWebpackConfig
({
config
})
{
// Add any missing extensions from the main GitLab webpack config
config
.
resolve
.
extensions
=
Array
.
from
(
config
.
resolve
.
extensions
=
Array
.
from
(
new
Set
([...
config
.
resolve
.
extensions
,
...
gitlabWebpackConfig
.
resolve
.
extensions
]),
new
Set
([...
config
.
resolve
.
extensions
,
...
gitlabWebpackConfig
.
resolve
.
extensions
]),
);
);
Object
.
assign
(
config
.
resolve
.
alias
,
gitlabWebpackConfig
.
resolve
.
alias
);
// Replace any Storybook-defined CSS loaders with our custom one.
delete
config
.
resolve
.
alias
[
'
@gitlab/svgs/dist/icons.svg
'
];
config
.
module
.
rules
=
[
config
.
module
.
rules
=
[
...
config
.
module
.
rules
.
filter
((
r
)
=>
!
r
.
test
.
test
(
'
.css
'
)),
...
config
.
module
.
rules
.
filter
((
r
)
=>
!
r
.
test
.
test
(
'
.css
'
)),
{
{
...
@@ -89,7 +89,15 @@ module.exports = ({ config }) => {
...
@@ -89,7 +89,15 @@ module.exports = ({ config }) => {
},
},
];
];
// Silence webpack warnings about moment/pikaday not being able to resolve.
config
.
plugins
.
push
(
new
webpack
.
IgnorePlugin
(
/moment/
,
/pikaday/
));
config
.
plugins
.
push
(
new
webpack
.
IgnorePlugin
(
/moment/
,
/pikaday/
));
// Add any missing aliases from the main GitLab webpack config
Object
.
assign
(
config
.
resolve
.
alias
,
gitlabWebpackConfig
.
resolve
.
alias
);
// The main GitLab project aliases this `icons.svg` file to app/assets/javascripts/lib/utils/icons_path.js,
// which depends on the existence of a global `gon` variable.
// By deleting the alias, imports of this path will resolve as expected.
delete
config
.
resolve
.
alias
[
'
@gitlab/svgs/dist/icons.svg
'
];
return
config
;
return
config
;
};
};
storybook/package.json
View file @
c8eed07c
{
{
"name"
:
"gitlab-storybook"
,
"private"
:
true
,
"version"
:
"1.0.0"
,
"description"
:
""
,
"scripts"
:
{
"scripts"
:
{
"test"
:
"echo
\"
Error: no test specified
\"
&& exit 1"
,
"test"
:
"echo
\"
Error: no test specified
\"
&& exit 1"
,
"start"
:
"start-storybook -p 6006 -c config"
,
"start"
:
"start-storybook -p 6006 -c config"
,
"build"
:
"build-storybook -c config"
"build"
:
"build-storybook -c config"
},
},
"
author"
:
""
,
"
dependencies"
:
{}
,
"
license"
:
"ISC"
,
"
devDependencies"
:
{
"dependencies"
:
{
"@storybook/addon-a11y"
:
"^6.2.9"
,
"@storybook/addon-
controls"
:
"^6.1.20
"
,
"@storybook/addon-
actions"
:
"^6.2.9
"
,
"@storybook/addon-
essentials"
:
"^6.1.20
"
,
"@storybook/addon-
controls"
:
"^6.2.9
"
,
"@storybook/addon-
links"
:
"^6.1.20
"
,
"@storybook/addon-
essentials"
:
"^6.2.9
"
,
"@storybook/vue"
:
"
^6.1.20
"
,
"@storybook/vue"
:
"
6.2.9
"
,
"node-sass"
:
"^4.14.1"
,
"node-sass"
:
"^4.14.1"
,
"node-sass-magic-importer"
:
"^5.3.2"
,
"node-sass-magic-importer"
:
"^5.3.2"
,
"postcss-loader"
:
"3.0.0"
,
"postcss-loader"
:
"3.0.0"
,
...
...
storybook/yarn.lock
View file @
c8eed07c
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment