由于我不够彻底,需要一些澄清。
我有贡献模块 Lazyloader。
这个补丁创建了我们不喜欢的随机 SVG 图像。所以我们想更新代码并创建一个灰色 SVG 占位符图像。使用补丁中的代码我做了一些更新,我想基本上做到以下几点:
安装懒加载
当我应用自制补丁时,会创建 3 个新目录,但这不应该发生:
该模块已经安装在 modules/contrib/lazyloader 下,应该创建的唯一目录是 modules/contrib/lazyloader/css 和文件名.css
我没有尝试任何前缀(如果我使用这个就不能应用补丁)
git diff --staged > name.patchhttps://www.drupal.org/project/lazyloader/issues/2905310
我应用补丁...
lando composer update drupal/lazyload
...但它创建了一个我没有包含在补丁中的新目录。
我发现了这个问题,但我不确定这是否会影响我的问题。
我相信这是补丁级别和cweagans/composer-patches
.
这是我的补丁
diff --git a/modules/contrib/lazyloader/css/grey_svg.css b/modules/contrib/lazyloader/css/grey_svg.css
new file mode 100644
index 000000000..573a3bb74
--- /dev/null
+++ b/modules/contrib/lazyloader/css/grey_svg.css
@@ -0,0 +1,3 @@
+.lazyload {
+ background-color: lightgrey;
+}
diff --git a/modules/contrib/lazyloader/lazyloader.libraries.yml b/modules/contrib/lazyloader/lazyloader.libraries.yml
index 99e023f00..ef4d1c6ff 100644
--- a/modules/contrib/lazyloader/lazyloader.libraries.yml
+++ b/modules/contrib/lazyloader/lazyloader.libraries.yml
@@ -15,3 +15,8 @@ lazysizes-min.cdn:
gpl-compatible: true
js:
https://cdnjs.cloudflare.com/ajax/libs/lazysizes/2.0.0/lazysizes.min.js: { type: external, minified: true }
+
+udesa-grey-svg:
+ css:
+ theme:
+ css/grey_svg.css: {}
diff --git a/modules/contrib/lazyloader/lazyloader.module b/modules/contrib/lazyloader/lazyloader.module
index 24998ed18..dc872356f 100644
--- a/modules/contrib/lazyloader/lazyloader.module
+++ b/modules/contrib/lazyloader/lazyloader.module
@@ -118,3 +118,10 @@ function lazyloader_libraries_info() {
return $libraries;
}
+
+/**
+ * Implements hook_libraries_info().
+ */
+function lazyloader_page_attachments(array &$page) {
+ $page['#attached']['library'][] = 'lazyloader/udesa-grey-svg';
+}
这也是我的 composer.json 补丁
"drupal/lazyloader": {
"Provide option to use a image style as the placeholder image": "https://www.drupal.org/files/issues/2018-11-29/lazyloader-LQIP-2905310-6.patch",
"Create black SVG as placeholder image": "patches/lazyloader/lazyloader-create-black-svg.patch"
}
补丁名称不是问题,我一直在玩弄其中几个
解决方案 > 解决方案说明了什么
1- 安装带有 --prefer source 和我想要的来自 drupal.org 的补丁的模块 2- 进入 modules/contrib/lazyloader 3- 我在分离的 head 分支中进行了补丁中的更改 4- 进行了我自己的更改,因为我需要来自 drupal.org 的第一个补丁 5-根据我的更改创建了我自己的补丁
完美运行!
您的补丁应该是模块 git repo 的本地补丁。路径必须看起来像这样:
diff --git a/lazyloader/css/grey_svg.css b/lazyloader/css/grey_svg.css
代替:
diff --git a/modules/contrib/lazyloader/css/grey_svg.css b/modules/contrib/lazyloader/css/grey_svg.css
contrib 模块的路径取自您的 composer.json (drupal/lazyloader)
确保您使用 contrib 模块 git repo 来创建补丁(不是 drupal 核心)。https://www.drupal.org/node/707484
从头开始,这个过程应该是这样的:
composer require 'drupal/lazyloader:^1.0' --prefer-source
cd web/modules/contrib/lazyloader
git diff --staged > name.patch
mv name.patch ../../../../patches/lazyloader/lazyloader-create-black-svg.patch
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句