mirror of
https://github.com/OCA/knowledge.git
synced 2025-07-14 01:41:26 -06:00
[MIG] document_url: Migration to 17.0
This commit is contained in:
parent
7c1a3cff02
commit
2ee541112c
@ -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",
|
||||
|
@ -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: {
|
||||
patch(Chatter.prototype, {
|
||||
_onAddUrl(event) {
|
||||
event.preventDefault();
|
||||
event.stopPropagation();
|
||||
this.env.services.action.doAction(
|
||||
"document_url.action_ir_attachment_add_url",
|
||||
{
|
||||
this.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,
|
||||
active_id: this.state.thread.id,
|
||||
active_ids: [this.state.thread.id],
|
||||
active_model: this.state.thread.model,
|
||||
},
|
||||
onClose: this._onAddedUrl.bind(this),
|
||||
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;
|
||||
}
|
||||
);
|
||||
},
|
||||
_onAddedUrl() {
|
||||
this.chatter.refresh();
|
||||
},
|
||||
},
|
||||
});
|
||||
|
||||
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,
|
||||
});
|
||||
},
|
||||
|
@ -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">
|
||||
<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="o_AttachmentBox_buttonAdd btn btn-link"
|
||||
class="btn btn-link"
|
||||
type="button"
|
||||
t-on-click="attachmentBoxView.onClickAddAttachment"
|
||||
t-att-disabled="!attachmentBoxView.chatter.isTemporary and !attachmentBoxView.chatter.hasWriteAccess"
|
||||
t-att-disabled="!state.thread.hasWriteAccess"
|
||||
>
|
||||
<i class="fa fa-plus-square" />
|
||||
Attach files
|
||||
</button>
|
||||
<button
|
||||
class="btn btn-link"
|
||||
type="button"
|
||||
class="o_add_url_button btn btn-link"
|
||||
t-on-click="attachmentBoxView._onAddUrl"
|
||||
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"
|
||||
>attachmentCard.attachment.mimetype != 'application/link'</attribute>
|
||||
<attribute name="t-if">attachment.mimetype != 'application/link'</attribute>
|
||||
</xpath>
|
||||
<xpath
|
||||
expr="//button[hasclass('o_AttachmentCard_asideItemDownload')]"
|
||||
expr="//div[hasclass('o-mail-AttachmentCard-aside')]//button[@title='Download']"
|
||||
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"
|
||||
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="attachmentCard.attachment.mimetype === 'application/link'"
|
||||
target="new"
|
||||
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_AttachmentCard_image')]" position="attributes">
|
||||
<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="//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>
|
||||
|
@ -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>
|
||||
|
Loading…
Reference in New Issue
Block a user