[MIG] document_url: Migration to 17.0

This commit is contained in:
Franco Leyes 2024-05-22 15:42:24 -03:00 committed by Bhavesh Heliconia
parent 7c1a3cff02
commit 2ee541112c
4 changed files with 94 additions and 91 deletions

View File

@ -2,7 +2,7 @@
# Copyright 2020 Tecnativa - Manuel Calero
{
"name": "URL attachment",
"version": "16.0.1.0.4",
"version": "17.0.1.0.0",
"category": "Tools",
"author": "Tecnativa, Odoo Community Association (OCA)",
"website": "https://github.com/OCA/knowledge",

View File

@ -1,47 +1,51 @@
/** @odoo-module **/
import {registerPatch} from "@mail/model/model_core";
import {AttachmentCard} from "@mail/components/attachment_card/attachment_card";
import {patch} from "web.utils";
import {Chatter} from "@mail/core/web/chatter";
import {patch} from "@web/core/utils/patch";
import {url} from "@web/core/utils/urls";
import {AttachmentList} from "@mail/core/common/attachment_list";
registerPatch({
name: "AttachmentBoxView",
recordMethods: {
_onAddUrl(event) {
event.preventDefault();
event.stopPropagation();
this.env.services.action.doAction(
"document_url.action_ir_attachment_add_url",
{
additionalContext: {
active_id: this.chatter.thread.id,
active_ids: [this.chatter.thread.id],
active_model: this.chatter.thread.model,
},
onClose: this._onAddedUrl.bind(this),
}
);
},
_onAddedUrl() {
this.chatter.refresh();
},
patch(Chatter.prototype, {
_onAddUrl(event) {
event.preventDefault();
event.stopPropagation();
this.action.doAction("document_url.action_ir_attachment_add_url", {
additionalContext: {
active_id: this.state.thread.id,
active_ids: [this.state.thread.id],
active_model: this.state.thread.model,
},
onClose: async () => {
await this.updateThreadAttachments();
},
});
},
async updateThreadAttachments() {
const attachments = await this.orm.call("ir.attachment", "search_read", [
[
["res_model", "=", this.state.thread.model],
["res_id", "=", this.state.thread.id],
],
["id", "name", "mimetype", "url"],
]);
this.state.thread.attachments = attachments.map((att) => ({
id: att.id,
name: att.name,
mimetype: att.mimetype,
url: att.url,
}));
},
onClickAddAttachments(ev) {
ev.stopPropagation();
this.state.isAttachmentBoxOpened = !this.state.isAttachmentBoxOpened;
if (this.state.isAttachmentBoxOpened) {
this.rootRef.el.scrollTop = 0;
this.state.thread.scrollTop = 0;
}
},
});
registerPatch({
name: "Chatter",
recordMethods: {
/**
* Handles click on the attach button.
*/
async onClickButtonAddAttachments() {
await this.onClickButtonToggleAttachments();
},
},
});
patch(AttachmentCard.prototype, "document_url/static/src/js/url.js", {
patch(AttachmentList.prototype, {
/**
* Return the url of the attachment. Temporary attachments, a.k.a. uploading
* attachments, do not have an url.
@ -50,7 +54,7 @@ patch(AttachmentCard.prototype, "document_url/static/src/js/url.js", {
*/
get attachmentUrl() {
return url("/web/content", {
id: this.attachmentCard.attachment.id,
id: this.attachment.id,
download: true,
});
},

View File

@ -4,67 +4,67 @@
License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). -->
<templates>
<t t-inherit="mail.AttachmentBox" t-inherit-mode="extension" owl="1">
<xpath
expr="//button[hasclass('o_AttachmentBox_buttonAdd')]"
position="replace"
>
<div align="center">
<button
class="o_AttachmentBox_buttonAdd btn btn-link"
type="button"
t-on-click="attachmentBoxView.onClickAddAttachment"
t-att-disabled="!attachmentBoxView.chatter.isTemporary and !attachmentBoxView.chatter.hasWriteAccess"
>
<i class="fa fa-plus-square" />
Attach files
</button>
<button
type="button"
class="o_add_url_button btn btn-link"
t-on-click="attachmentBoxView._onAddUrl"
>
<i class="fa fa-plus-square" />
Add URL
</button>
</div>
<t t-inherit="mail.Chatter" t-inherit-mode="extension">
<xpath expr="//AttachmentList//..//FileUploader/t" position="replace">
<t t-set-slot="toggler">
<div class="d-flex mx-auto">
<button
class="btn btn-link"
type="button"
t-att-disabled="!state.thread.hasWriteAccess"
>
<i class="fa fa-plus-square" />
Attach files
</button>
<button
class="btn btn-link"
type="button"
t-att-disabled="!state.thread.hasWriteAccess"
t-on-click="_onAddUrl"
>
<i class="fa fa-plus-square" />
Add URL
</button>
</div>
</t>
</xpath>
</t>
<t t-inherit="mail.AttachmentCard" t-inherit-mode="extension" owl="1">
<t t-inherit="mail.AttachmentList" t-inherit-mode="extension">
<xpath
expr="//button[hasclass('o_AttachmentCard_asideItemDownload')]"
expr="//div[contains(@class, 'o-mail-AttachmentCard-aside')]//button[@title='Download']"
position="attributes"
>
<attribute name="t-if">attachment.mimetype != 'application/link'</attribute>
</xpath>
<xpath
expr="//div[hasclass('o-mail-AttachmentCard-aside')]//button[@title='Download']"
position="after"
>
<button
class="btn d-flex justify-content-center align-items-center w-100 h-100 rounded-0"
t-attf-class="bg-300"
t-on-click="() => window.open(attachmentUrl, '_blank')"
title="Open"
t-if="attachment.mimetype === 'application/link'"
target="_blank"
>
<i class="fa fa-link" role="img" aria-label="Open" />
</button>
</xpath>
<xpath
expr="//div[hasclass('o-mail-AttachmentCard-image')]"
position="attributes"
>
<attribute
name="t-if"
>attachmentCard.attachment.mimetype != 'application/link'</attribute>
>attachment.mimetype !== 'application/link'</attribute>
</xpath>
<xpath
expr="//button[hasclass('o_AttachmentCard_asideItemDownload')]"
position="after"
>
<button
class="o_AttachmentCard_asideItem o_AttachmentCard_asideItemDownload btn d-flex justify-content-center align-items-center w-100 h-100 rounded-0 bg-300"
t-on-click="() => window.open(attachmentUrl, '_blank')"
title="Open"
t-if="attachmentCard.attachment.mimetype === 'application/link'"
target="new"
>
<i class="fa fa-link" role="img" aria-label="Open" />
</button>
</xpath>
<xpath expr="//div[hasclass('o_AttachmentCard_image')]" position="attributes">
<attribute
name="t-if"
>attachmentCard.attachment.mimetype != 'application/link'</attribute>
</xpath>
<xpath expr="//div[hasclass('o_AttachmentCard_image')]" position="before">
<xpath expr="//div[hasclass('o-mail-AttachmentCard-image')]" position="before">
<a
class="o_Attachment_url_ico o_image flex-shrink-0 m-1"
t-att-href="attachmentUrl"
target="new"
t-if="attachmentCard.attachment.mimetype=='application/link'"
target="_blank"
t-if="attachment.mimetype === 'application/link'"
>
<i class="fa fa-link fa-2x" />
</a>

View File

@ -24,8 +24,7 @@
class="oe_highlight"
type="object"
/>
or
<button special="cancel" string="Cancel" class="oe_link" />
<button special="cancel" string="Cancel" class="btn-secondary" />
</footer>
</form>
</field>